Commit ed042b9a8c2de3c5770bb065ca26fb73d5de089b

Authored by Adhidarma Hadiwinoto
1 parent 888bed490e
Exists in master

debug

Showing 2 changed files with 2 additions and 1 deletions Inline Diff

sinkronisasi.include.php
1 <?php 1 <?php
2 2
3 function sinkronisasi_get_terms($vocabulary) { 3 function sinkronisasi_get_terms($vocabulary) {
4 $entity_type = "taxonomy_term"; 4 $entity_type = "taxonomy_term";
5 5
6 $query = new EntityFieldQuery(); 6 $query = new EntityFieldQuery();
7 $query->entityCondition('entity_type', $entity_type); 7 $query->entityCondition('entity_type', $entity_type);
8 $query->propertyCondition('vid', $vocabulary->vid); 8 $query->propertyCondition('vid', $vocabulary->vid);
9 9
10 $result = $query->execute(); 10 $result = $query->execute();
11 if (!$result) { 11 if (!$result) {
12 return; 12 return;
13 } 13 }
14 14
15 $tids = array_keys($result[$entity_type]); 15 $tids = array_keys($result[$entity_type]);
16 $terms = taxonomy_term_load_multiple($tids); 16 $terms = taxonomy_term_load_multiple($tids);
17 return $terms; 17 return $terms;
18 } 18 }
19 19
20 function sinkronisasi_export_iterate($terms) { 20 function sinkronisasi_export_iterate($terms) {
21 foreach ($terms as $tid => $term) { 21 foreach ($terms as $tid => $term) {
22 unset($term->rdf_mapping); 22 unset($term->rdf_mapping);
23 $term = sinkronisasi_taxonomy_term_denormalization($term); 23 $term = sinkronisasi_taxonomy_term_denormalization($term);
24 $term = sinkronisasi_export_set_parent($term); 24 $term = sinkronisasi_export_set_parent($term);
25 25
26 $terms[$tid] = $term; 26 $terms[$tid] = $term;
27 } 27 }
28 return $terms; 28 return $terms;
29 } 29 }
30 30
31 function sinkronisasi_export_set_parent($term) { 31 function sinkronisasi_export_set_parent($term) {
32 $parent_terms = taxonomy_get_parents($term->tid); 32 $parent_terms = taxonomy_get_parents($term->tid);
33 $parent_term = array_shift($parent_terms); 33 $parent_term = array_shift($parent_terms);
34 $term->_parent = $parent_term->tid; 34 $term->_parent = $parent_term->tid;
35 35
36 return $term; 36 return $term;
37 } 37 }
38 38
39 function sinkronisasi_taxonomy_term_denormalization($term) { 39 function sinkronisasi_taxonomy_term_denormalization($term) {
40 foreach ($term as $field_name => $field_value) { 40 foreach ($term as $field_name => $field_value) {
41 41
42 $field = field_info_field($field_name); 42 $field = field_info_field($field_name);
43 43
44 44
45 if (!$field) continue; 45 if (!$field) continue;
46 46
47 if ($field['type'] == "taxonomy_term_reference") { 47 if ($field['type'] == "taxonomy_term_reference") {
48 48
49 foreach ($field_value as $language => $values_per_language) { 49 foreach ($field_value as $language => $values_per_language) {
50 foreach ($values_per_language as $idx => $value) { 50 foreach ($values_per_language as $idx => $value) {
51 51
52 if (empty($value['tid'])) { 52 if (empty($value['tid'])) {
53 continue; 53 continue;
54 } 54 }
55 55
56 $foreign_term = taxonomy_term_load($value['tid']); 56 $foreign_term = taxonomy_term_load($value['tid']);
57 if (isset($foreign_term->name)) { 57 if (isset($foreign_term->name)) {
58 $term->{"$field_name"}[$language][$idx]['_name'] = $foreign_term->name; 58 $term->{"$field_name"}[$language][$idx]['_name'] = $foreign_term->name;
59 } 59 }
60 } 60 }
61 } 61 }
62 } 62 }
63 63
64 } 64 }
65 return $term; 65 return $term;
66 } 66 }
67 67
68 function sinkronisasi_delete_taxonomy_term_field_type($term) { 68 function sinkronisasi_delete_taxonomy_term_field_type($term) {
69 foreach ($term as $field_name => $field_value) { 69 foreach ($term as $field_name => $field_value) {
70 70
71 $field = field_info_field($field_name); 71 $field = field_info_field($field_name);
72 72
73 73
74 if (!$field) continue; 74 if (!$field) continue;
75 75
76 if ($field['type'] == "taxonomy_term_reference") { 76 if ($field['type'] == "taxonomy_term_reference") {
77 unset($term->{"$field_name"}); 77 unset($term->{"$field_name"});
78 } 78 }
79 } 79 }
80 return $term; 80 return $term;
81 } 81 }
82 82
83 function sinkronisasi_taxonomy_term_normalization($term) { 83 function sinkronisasi_taxonomy_term_normalization($term) {
84 foreach ($term as $field_name => $field_value) { 84 foreach ($term as $field_name => $field_value) {
85 85
86 $field = field_info_field($field_name); 86 $field = field_info_field($field_name);
87 87
88 88
89 if (!$field) continue; 89 if (!$field) continue;
90 90
91 if ($field['type'] == "taxonomy_term_reference") { 91 if ($field['type'] == "taxonomy_term_reference") {
92 92
93 foreach ($field_value as $language => $values_per_language) { 93 foreach ($field_value as $language => $values_per_language) {
94 foreach ($values_per_language as $idx => $value) { 94 foreach ($values_per_language as $idx => $value) {
95 95
96 if (empty($value['_name'])) { 96 if (empty($value['_name'])) {
97 continue; 97 continue;
98 } 98 }
99 99
100 $foreign_terms = taxonomy_get_term_by_name($value['_name']); 100 $foreign_terms = taxonomy_get_term_by_name($value['_name']);
101 $foreign_terms = taxonomy_term_load_multiple(array_keys($foreign_terms)); 101 $foreign_terms = taxonomy_term_load_multiple(array_keys($foreign_terms));
102 $foreign_term = array_shift($foreign_terms); 102 $foreign_term = array_shift($foreign_terms);
103 103
104 if (isset($foreign_term->name)) { 104 if (isset($foreign_term->name)) {
105 if ($foreign_term->name != $value['_name']) { 105 if ($foreign_term->name != $value['_name']) {
106 drush_die("213AB2 foreign term name is not match!"); 106 drush_die("213AB2 foreign term name is not match!");
107 } 107 }
108 108
109 $term->{"$field_name"}[$language][$idx]['tid'] = $foreign_term->tid; 109 $term->{"$field_name"}[$language][$idx]['tid'] = $foreign_term->tid;
110 } 110 }
111 } 111 }
112 } 112 }
113 } 113 }
114 114
115 } 115 }
116 return $term; 116 return $term;
117 } 117 }
118 118
119 119
120 function sinkronisasi_fix_vid($term) { 120 function sinkronisasi_fix_vid($term) {
121 $vocabulary = taxonomy_vocabulary_machine_name_load($term->vocabulary_machine_name); 121 $vocabulary = taxonomy_vocabulary_machine_name_load($term->vocabulary_machine_name);
122 if (!$vocabulary) { 122 if (!$vocabulary) {
123 var_dump($term);
124 echo "\n";
123 drush_die("CD231A vocabulary not found!"); 125 drush_die("CD231A vocabulary not found!");
124 } 126 }
125 127
126 $term->vid = $vocabulary->vid; 128 $term->vid = $vocabulary->vid;
127 return $term; 129 return $term;
128 } 130 }
129 131
130 function sinkronisasi_import($terms) { 132 function sinkronisasi_import($terms) {
131 sinkronisasi_import_iterate_insert($terms); 133 sinkronisasi_import_iterate_insert($terms);
132 sinkronisasi_import_iterate_update($terms); 134 sinkronisasi_import_iterate_update($terms);
133 } 135 }
134 136
135 function sinkronisasi_import_iterate_insert($terms) { 137 function sinkronisasi_import_iterate_insert($terms) {
136 foreach ($terms as $tid => $_term) { 138 foreach ($terms as $tid => $_term) {
137 $term = sinkronisasi_fix_vid($term); 139 $term = sinkronisasi_fix_vid($term);
138 $term = sinkronisasi_delete_taxonomy_term_field_type($term); 140 $term = sinkronisasi_delete_taxonomy_term_field_type($term);
139 $term = sinkronisasi_set_field_original_tid($term); 141 $term = sinkronisasi_set_field_original_tid($term);
140 142
141 unset($term->tid); 143 unset($term->tid);
142 taxonomy_term_save($term); 144 taxonomy_term_save($term);
143 echo $term->tid . " inserted\n"; 145 echo $term->tid . " inserted\n";
144 } 146 }
145 } 147 }
146 148
147 function sinkronisasi_import_iterate_update($terms) { 149 function sinkronisasi_import_iterate_update($terms) {
148 foreach ($terms as $tid => $term) { 150 foreach ($terms as $tid => $term) {
149 $term = sinkronisasi_fix_vid($term); 151 $term = sinkronisasi_fix_vid($term);
150 $term = sinkronisasi_taxonomy_term_normalization($term); 152 $term = sinkronisasi_taxonomy_term_normalization($term);
151 $term = sinkronisasi_set_field_original_tid($term); 153 $term = sinkronisasi_set_field_original_tid($term);
152 $term = sinkronisasi_pair_with_original($term); 154 $term = sinkronisasi_pair_with_original($term);
153 $term = sinkronisasi_pair_with_parent($term); 155 $term = sinkronisasi_pair_with_parent($term);
154 156
155 taxonomy_term_save($term); 157 taxonomy_term_save($term);
156 echo $term->tid . " updated\n"; 158 echo $term->tid . " updated\n";
157 } 159 }
158 } 160 }
159 161
160 function sinkronisasi_pair_with_original($term) { 162 function sinkronisasi_pair_with_original($term) {
161 $tid = $term->tid; 163 $tid = $term->tid;
162 $original_term = sinkronisasi_get_term_by_field_original_tid($tid); 164 $original_term = sinkronisasi_get_term_by_field_original_tid($tid);
163 if (!$original_term) { 165 if (!$original_term) {
164 drush_die("ED0129 Error getting term with original tid is $tid!\n"); 166 drush_die("ED0129 Error getting term with original tid is $tid!\n");
165 } 167 }
166 168
167 $term->tid = $original_term->tid; 169 $term->tid = $original_term->tid;
168 return $term; 170 return $term;
169 } 171 }
170 172
171 function sinkronisasi_pair_with_parent($term) { 173 function sinkronisasi_pair_with_parent($term) {
172 if ($term->_parent) { 174 if ($term->_parent) {
173 $term->parent = $term->_parent; 175 $term->parent = $term->_parent;
174 unset($term->_parent); 176 unset($term->_parent);
175 } 177 }
176 178
177 return $term; 179 return $term;
178 } 180 }
179 181
180 function sinkronisasi_get_term_by_field_original_tid($tid) { 182 function sinkronisasi_get_term_by_field_original_tid($tid) {
181 $entity_type = "taxonomy_term"; 183 $entity_type = "taxonomy_term";
182 184
183 $query = new EntityFieldQuery(); 185 $query = new EntityFieldQuery();
184 $query->entityCondition('entity_type', $entity_type); 186 $query->entityCondition('entity_type', $entity_type);
185 $query->fieldCondition('field_original_tid', 'value', $tid); 187 $query->fieldCondition('field_original_tid', 'value', $tid);
186 188
187 $result = $query->execute(); 189 $result = $query->execute();
188 if (!$result) { 190 if (!$result) {
189 return; 191 return;
190 } 192 }
191 193
192 $tids = array_keys($result[$entity_type]); 194 $tids = array_keys($result[$entity_type]);
193 $terms = taxonomy_term_load_multiple($tids); 195 $terms = taxonomy_term_load_multiple($tids);
194 196
195 $term = array_shift($terms); 197 $term = array_shift($terms);
196 return $term; 198 return $term;
197 } 199 }
198 200
199 function sinkronisasi_set_field_original_tid($term) { 201 function sinkronisasi_set_field_original_tid($term) {
200 $term->field_original_tid['und'][0]['value'] = $term->tid; 202 $term->field_original_tid['und'][0]['value'] = $term->tid;
201 return $term; 203 return $term;
202 } 204 }
203 205
204 function sinkronisasi_export($vocabulary_machine_name) { 206 function sinkronisasi_export($vocabulary_machine_name) {
205 $vocabulary = taxonomy_vocabulary_machine_name_load($vocabulary_machine_name); 207 $vocabulary = taxonomy_vocabulary_machine_name_load($vocabulary_machine_name);
206 $terms = sinkronisasi_get_terms($vocabulary); 208 $terms = sinkronisasi_get_terms($vocabulary);
207 $terms = sinkronisasi_export_iterate($terms); 209 $terms = sinkronisasi_export_iterate($terms);
208 210
209 return $terms; 211 return $terms;
210 } 212 }
211 213
212 function delete_all_terms_by_vid($vid) { 214 function delete_all_terms_by_vid($vid) {
213 215
214 $query = new EntityFieldQuery(); 216 $query = new EntityFieldQuery();
215 $query->entityCondition('entity_type', 'taxonomy_term'); 217 $query->entityCondition('entity_type', 'taxonomy_term');
216 218
217 if (!$vid) { 219 if (!$vid) {
218 drush_die("Unknown vid"); 220 drush_die("Unknown vid");
219 } 221 }
220 222
221 $query->propertyCondition('vid', $vid); 223 $query->propertyCondition('vid', $vid);
222 $result = $query->execute(); 224 $result = $query->execute();
223 if (!$result) { 225 if (!$result) {
224 return; 226 return;
225 } 227 }
226 228
227 foreach ($result['taxonomy_term'] as $term) { 229 foreach ($result['taxonomy_term'] as $term) {
228 echo "Deleting "; 230 echo "Deleting ";
229 echo $term->tid; 231 echo $term->tid;
230 echo "-> "; 232 echo "-> ";
231 echo taxonomy_term_delete($term->tid); 233 echo taxonomy_term_delete($term->tid);
232 echo "\n"; 234 echo "\n";
233 } 235 }
234 } 236 }
235 237
sinkronisasi_import.php
1 <?php 1 <?php
2 2
3 require("sinkronisasi.include.php"); 3 require("sinkronisasi.include.php");
4 4
5 if (function_exists('drush_main')) { 5 if (function_exists('drush_main')) {
6 $machine_name = "jenis_kantor"; 6 $machine_name = "jenis_kantor";
7 7
8 $vocabulary = taxonomy_vocabulary_machine_name_load($machine_name); 8 $vocabulary = taxonomy_vocabulary_machine_name_load($machine_name);
9 9
10 echo "Delete data\n"; 10 echo "Delete data\n";
11 delete_all_terms_by_vid($vocabulary->vid); 11 delete_all_terms_by_vid($vocabulary->vid);
12 12
13 $data = file_get_contents("adhisimon/sinkronisasi-drupal/$machine_name.txt"); 13 $data = file_get_contents("adhisimon/sinkronisasi-drupal/$machine_name.txt");
14 14
15 echo "Insert new data\n"; 15 echo "Insert new data\n";
16 $terms = unserialize($data); 16 $terms = unserialize($data);
17
18 sinkronisasi_import_iterate_insert($terms); 17 sinkronisasi_import_iterate_insert($terms);
19 18
20 echo "Update data\n"; 19 echo "Update data\n";
21 $terms = unserialize($data); 20 $terms = unserialize($data);
22 sinkronisasi_import_iterate_update($terms); 21 sinkronisasi_import_iterate_update($terms);
23 } 22 }
24 23