| 1 |
<?php |
|---|
| 2 |
|
|---|
| 3 |
|
|---|
| 4 |
|
|---|
| 5 |
|
|---|
| 6 |
|
|---|
| 7 |
|
|---|
| 8 |
|
|---|
| 9 |
|
|---|
| 10 |
|
|---|
| 11 |
|
|---|
| 12 |
|
|---|
| 13 |
|
|---|
| 14 |
|
|---|
| 15 |
|
|---|
| 16 |
|
|---|
| 17 |
|
|---|
| 18 |
|
|---|
| 19 |
|
|---|
| 20 |
|
|---|
| 21 |
|
|---|
| 22 |
function midcom_helper_replicator_serialize(&$object) |
|---|
| 23 |
{ |
|---|
| 24 |
|
|---|
| 25 |
/** |
|---|
| 26 |
* Workaround for bug #259 |
|---|
| 27 |
*/ |
|---|
| 28 |
if ( !isset($object->lang) |
|---|
| 29 |
|| $object->lang === 0) |
|---|
| 30 |
{ |
|---|
| 31 |
|
|---|
| 32 |
$stat = midgard_replicator::serialize($object); |
|---|
| 33 |
return midcom_helper_replicator_serialize_check_bug244($stat, $object); |
|---|
| 34 |
} |
|---|
| 35 |
$current_language = (int)$_MIDGARD['lang']; |
|---|
| 36 |
$current_default_language = mgd_get_default_lang(); |
|---|
| 37 |
mgd_set_lang(0); |
|---|
| 38 |
mgd_set_default_lang(0); |
|---|
| 39 |
$object_class = get_class($object); |
|---|
| 40 |
$object_lang0 = new $object_class($object->guid); |
|---|
| 41 |
if ( !$object_lang0 |
|---|
| 42 |
|| !isset($object_lang0->guid) |
|---|
| 43 |
|| empty($object_lang0->guid)) |
|---|
| 44 |
{ |
|---|
| 45 |
|
|---|
| 46 |
$errno = mgd_errno(); |
|---|
| 47 |
mgd_set_default_lang($current_default_language); |
|---|
| 48 |
mgd_set_lang($current_language); |
|---|
| 49 |
mgd_set_errno($errno); |
|---|
| 50 |
unset($object_class, $object_lang0, $current_language, $current_default_language, $errno); |
|---|
| 51 |
return false; |
|---|
| 52 |
} |
|---|
| 53 |
else |
|---|
| 54 |
{ |
|---|
| 55 |
$stat = midgard_replicator::serialize($object_lang0); |
|---|
| 56 |
} |
|---|
| 57 |
$errno = mgd_errno(); |
|---|
| 58 |
mgd_set_default_lang($current_default_language); |
|---|
| 59 |
mgd_set_lang($current_language); |
|---|
| 60 |
mgd_set_errno($errno); |
|---|
| 61 |
unset($object_class, $object_lang0, $current_language, $current_default_language, $errno); |
|---|
| 62 |
return midcom_helper_replicator_serialize_check_bug244($stat, $object); |
|---|
| 63 |
} |
|---|
| 64 |
|
|---|
| 65 |
|
|---|
| 66 |
|
|---|
| 67 |
|
|---|
| 68 |
|
|---|
| 69 |
|
|---|
| 70 |
|
|---|
| 71 |
|
|---|
| 72 |
function midcom_helper_replicator_serialize_check_bug244(&$serialized, &$object) |
|---|
| 73 |
{ |
|---|
| 74 |
|
|---|
| 75 |
if (!preg_match_all('%<[^>]+?lang="[^"]+"[^>]+?>%', $serialized, $matches)) |
|---|
| 76 |
{ |
|---|
| 77 |
|
|---|
| 78 |
/* |
|---|
| 79 |
debug_add('no lang matches'); |
|---|
| 80 |
debug_pop(); |
|---|
| 81 |
*/ |
|---|
| 82 |
return $serialized; |
|---|
| 83 |
} |
|---|
| 84 |
|
|---|
| 85 |
$langs = count($matches[0]); |
|---|
| 86 |
unset($matches); |
|---|
| 87 |
if ($langs <= 1) |
|---|
| 88 |
{ |
|---|
| 89 |
|
|---|
| 90 |
/* |
|---|
| 91 |
debug_add("\$langs <= 1, does not trigger bug #244"); |
|---|
| 92 |
debug_pop(); |
|---|
| 93 |
*/ |
|---|
| 94 |
unset($langs); |
|---|
| 95 |
return $serialized; |
|---|
| 96 |
} |
|---|
| 97 |
if ($langs % 2 == 0) |
|---|
| 98 |
{ |
|---|
| 99 |
|
|---|
| 100 |
$total_langs = $langs+1; |
|---|
| 101 |
$class = get_class($object); |
|---|
| 102 |
$object_url = $_MIDCOM->get_host_prefix() . "__mfa/asgard/object/view/{$object->guid}/"; |
|---|
| 103 |
$msg = "Object <a target='_blank' href='{$object_url}'>{$class} #{$object->id}</a> has {$total_langs} languages, this triggers <a target='_blank' href='http://trac.midgard-project.org/ticket/244'>bug #244</a>."; |
|---|
| 104 |
$msg .= " Object will not be replicated, please go add one more language to the object in <a target='_blank' href='{$object_url}'>Asgard</a>."; |
|---|
| 105 |
$_MIDCOM->uimessages->add('midcom.helper.replicator', $msg, 'error'); |
|---|
| 106 |
$GLOBALS['midcom_helper_replicator_logger']->log_object($object, "has {$total_langs} languages, this triggers bug #244, preventing export.", MIDCOM_LOG_ERROR); |
|---|
| 107 |
unset($class, $object_url, $msg, $total_langs, $langs); |
|---|
| 108 |
|
|---|
| 109 |
return false; |
|---|
| 110 |
} |
|---|
| 111 |
|
|---|
| 112 |
debug_add("\$langs % 2 != 0, does not trigger bug #244"); |
|---|
| 113 |
debug_pop(); |
|---|
| 114 |
*/ |
|---|
| 115 |
unset($langs); |
|---|
| 116 |
return $serialized; |
|---|
| 117 |
} |
|---|
| 118 |
|
|---|
| 119 |
|
|---|
| 120 |
|
|---|
| 121 |
|
|---|
| 122 |
|
|---|
| 123 |
|
|---|
| 124 |
|
|---|
| 125 |
|
|---|
| 126 |
|
|---|
| 127 |
|
|---|
| 128 |
|
|---|
| 129 |
|
|---|
| 130 |
function midcom_helper_replicator_serialize_blob(&$object) |
|---|
| 131 |
{ |
|---|
| 132 |
if (is_callable(array('midgard_replicator', 'serialize_blob'))) |
|---|
| 133 |
{ |
|---|
| 134 |
|
|---|
| 135 |
return midgard_replicator::serialize_blob($object); |
|---|
| 136 |
} |
|---|
| 137 |
|
|---|
| 138 |
return midgard_replicator::export_blob($object); |
|---|
| 139 |
} |
|---|
| 140 |
|
|---|
| 141 |
|
|---|
| 142 |
|
|---|
| 143 |
|
|---|
| 144 |
|
|---|
| 145 |
|
|---|
| 146 |
|
|---|
| 147 |
|
|---|
| 148 |
|
|---|
| 149 |
|
|---|
| 150 |
|
|---|
| 151 |
|
|---|
| 152 |
function midcom_helper_replicator_unserialize(&$xml, $use_force = false) |
|---|
| 153 |
{ |
|---|
| 154 |
if ($use_force) |
|---|
| 155 |
{ |
|---|
| 156 |
return midgard_replicator::unserialize($xml, $use_force); |
|---|
| 157 |
} |
|---|
| 158 |
return midgard_replicator::unserialize($xml); |
|---|
| 159 |
} |
|---|
| 160 |
|
|---|
| 161 |
|
|---|
| 162 |
|
|---|
| 163 |
|
|---|
| 164 |
|
|---|
| 165 |
|
|---|
| 166 |
|
|---|
| 167 |
|
|---|
| 168 |
|
|---|
| 169 |
|
|---|
| 170 |
|
|---|
| 171 |
function midcom_helper_replicator_import_object(&$object, $use_force = false) |
|---|
| 172 |
{ |
|---|
| 173 |
if ($use_force) |
|---|
| 174 |
{ |
|---|
| 175 |
return midgard_replicator::import_object($object, $use_force); |
|---|
| 176 |
} |
|---|
| 177 |
return midgard_replicator::import_object($object); |
|---|
| 178 |
} |
|---|
| 179 |
|
|---|
| 180 |
|
|---|
| 181 |
|
|---|
| 182 |
|
|---|
| 183 |
|
|---|
| 184 |
|
|---|
| 185 |
|
|---|
| 186 |
|
|---|
| 187 |
|
|---|
| 188 |
function midcom_helper_replicator_import_from_xml(&$xml, $use_force = false) |
|---|
| 189 |
{ |
|---|
| 190 |
if ($use_force) |
|---|
| 191 |
{ |
|---|
| 192 |
return midgard_replicator::import_from_xml($xml, $use_force); |
|---|
| 193 |
} |
|---|
| 194 |
return midgard_replicator::import_from_xml($xml); |
|---|
| 195 |
} |
|---|
| 196 |
?> |
|---|