Go to the documentation of this file.00001 <?php
00002
00010 class oxI18n extends oxBase
00011 {
00012
00018 protected $_sClassName = 'oxI18n';
00019
00025 protected $_iLanguage = null;
00026
00033 protected $_blEmployMultilanguage = true;
00034
00038 public function __construct()
00039 {
00040 parent::__construct();
00041
00042
00043
00044
00045 if ($this->_sCacheKey) {
00046 $this->_sCacheKey .= "_i18n";
00047 }
00048 }
00049
00055 public function setLanguage($iLang = null)
00056 {
00057 $this->_iLanguage = (int) $iLang;
00058
00059 $this->_sViewTable = false;
00060 }
00061
00067 public function getLanguage()
00068 {
00069 if ($this->_iLanguage === null) {
00070 $this->_iLanguage = oxRegistry::getLang()->getBaseLanguage();
00071 }
00072
00073 return $this->_iLanguage;
00074 }
00075
00082 public function setEnableMultilang($blEmployMultilanguage)
00083 {
00084 if ($this->_blEmployMultilanguage != $blEmployMultilanguage) {
00085 $this->_blEmployMultilanguage = $blEmployMultilanguage;
00086 if (!$blEmployMultilanguage) {
00087
00088 $this->modifyCacheKey("_nonml");
00089 }
00090
00091 $this->_sViewTable = false;
00092 if (count($this->_aFieldNames) > 1) {
00093 $this->_initDataStructure();
00094 }
00095 }
00096 }
00097
00106 public function isMultilingualField($sFieldName)
00107 {
00108 $sFieldName = strtolower($sFieldName);
00109 if (isset($this->_aFieldNames[$sFieldName])) {
00110 return (bool) $this->_aFieldNames[$sFieldName];
00111 }
00112
00113
00114
00115 startProfile('!__CACHABLE2__!');
00116 $blIsMultilang = (bool) $this->_getFieldStatus($sFieldName);
00117 stopProfile('!__CACHABLE2__!');
00118
00119 return (bool) $blIsMultilang;
00120 }
00121
00128 public function isMultilang()
00129 {
00130 return true;
00131 }
00132
00141 public function loadInLang($iLanguage, $sOxid)
00142 {
00143
00144 $this->setLanguage($iLanguage);
00145
00146 $this->_sViewTable = false;
00147
00148 return $this->load($sOxid);
00149 }
00150
00157 public function modifyCacheKey($sCacheKey, $blOverride = false)
00158 {
00159 if ($blOverride) {
00160 $this->_sCacheKey = $sCacheKey . "|i18n";
00161 } else {
00162 $this->_sCacheKey .= $sCacheKey;
00163 }
00164
00165 if (!$sCacheKey) {
00166 $this->_sCacheKey = null;
00167 }
00168 }
00169
00176 public function getAvailableInLangs()
00177 {
00178 $aLanguages = oxRegistry::getLang()->getLanguageNames();
00179
00180 $aObjFields = $this->_getTableFields(
00181 getViewName($this->_sCoreTable, -1, -1),
00182 true
00183 );
00184 $aMultiLangFields = array();
00185
00186
00187 foreach ($aObjFields as $sKey => $sValue) {
00188
00189
00190 if (preg_match('/^oxactive(_(\d{1,2}))?$/', $sKey)) {
00191 continue;
00192 }
00193
00194 $iFieldLang = $this->_getFieldLang($sKey);
00195
00196
00197 if ($this->isMultilingualField($sKey) || $iFieldLang > 0) {
00198 $sNewKey = preg_replace('/_(\d{1,2})$/', '', $sKey);
00199 $aMultiLangFields[$sNewKey][] = (int) $iFieldLang;
00200 }
00201 }
00202
00203
00204 if (count($aMultiLangFields) < 1) {
00205 return $aLanguages;
00206 }
00207
00208
00209 $oDb = oxDb::getDb(oxDb::FETCH_MODE_ASSOC);
00210 $query = "select * from " . getViewName($this->_sCoreTable, -1, -1) . " where oxid = " . $oDb->quote($this->getId());
00211 $rs = $oDb->getAll($query);
00212
00213 $aNotInLang = $aLanguages;
00214
00215
00216
00217 if (is_array($rs) && count($rs[0])) {
00218 foreach ($aMultiLangFields as $sFieldId => $aMultiLangIds) {
00219
00220 foreach ($aMultiLangIds as $sMultiLangId) {
00221 $sFieldName = ($sMultiLangId == 0) ? $sFieldId : $sFieldId . '_' . $sMultiLangId;
00222 if ($rs['0'][strtoupper($sFieldName)]) {
00223 unset($aNotInLang[$sMultiLangId]);
00224 continue;
00225 }
00226 }
00227 }
00228 }
00229
00230 $aIsInLang = array_diff($aLanguages, $aNotInLang);
00231
00232 return $aIsInLang;
00233 }
00234
00243 protected function _getFieldStatus($sFieldName)
00244 {
00245 $aAllField = $this->_getAllFields(true);
00246 if (isset($aAllField[strtolower($sFieldName) . "_1"])) {
00247 return 1;
00248 }
00249
00250 return 0;
00251 }
00252
00264 protected function _getNonCachedFieldNames($blForceFullStructure = false)
00265 {
00266
00267
00268 $aFields = parent::_getNonCachedFieldNames($blForceFullStructure);
00269
00270 if (!$this->_blEmployMultilanguage) {
00271 return $aFields;
00272 }
00273
00274
00275 if ($aFields) {
00276
00277 $aWorkingFields = & $aFields;
00278 } else {
00279
00280 $aWorkingFields = & $this->_aFieldNames;
00281 }
00282
00283
00284 foreach ($aWorkingFields as $sName => $sVal) {
00285 if ($this->_getFieldLang($sName)) {
00286 unset($aWorkingFields[$sName]);
00287 } else {
00288 $aWorkingFields[$sName] = $this->_getFieldStatus($sName);
00289 }
00290 }
00291
00292 return $aWorkingFields;
00293 }
00294
00302 protected function _getFieldLang($sFieldName)
00303 {
00304 if (false === strpos($sFieldName, '_')) {
00305 return 0;
00306 }
00307 if (preg_match('/_(\d{1,2})$/', $sFieldName, $aRegs)) {
00308 return $aRegs[1];
00309 } else {
00310 return 0;
00311 }
00312 }
00313
00321 public function getUpdateSqlFieldName($sField)
00322 {
00323 $iLang = $this->getLanguage();
00324 if ($iLang && $this->_blEmployMultilanguage && $this->isMultilingualField($sField)) {
00325 $sField .= "_" . $iLang;
00326 }
00327
00328 return $sField;
00329 }
00330
00339 protected function _getUpdateFieldsForTable($sTable, $blUseSkipSaveFields = true)
00340 {
00341 $sCoreTable = $this->getCoreTableName();
00342
00343 $blSkipMultilingual = false;
00344 $blSkipCoreFields = false;
00345
00346 if ($sTable != $sCoreTable) {
00347 $blSkipCoreFields = true;
00348 }
00349 if ($this->_blEmployMultilanguage) {
00350 if ($sTable != getLangTableName($sCoreTable, $this->getLanguage())) {
00351 $blSkipMultilingual = true;
00352 }
00353 }
00354
00355 $sSql = '';
00356 $blSep = false;
00357 foreach (array_keys($this->_aFieldNames) as $sKey) {
00358 $sKeyLowercase = strtolower($sKey);
00359 if ($sKeyLowercase != 'oxid') {
00360 if ($this->_blEmployMultilanguage) {
00361 if ($blSkipMultilingual && $this->isMultilingualField($sKey)) {
00362 continue;
00363 }
00364 if ($blSkipCoreFields && !$this->isMultilingualField($sKey)) {
00365 continue;
00366 }
00367 } else {
00368
00369 $iFieldLang = $this->_getFieldLang($sKey);
00370 if ($iFieldLang) {
00371 if ($sTable != getLangTableName($sCoreTable, $iFieldLang)) {
00372 continue;
00373 }
00374 } elseif ($blSkipCoreFields) {
00375 continue;
00376 }
00377 }
00378 }
00379
00380 $sLongName = $this->_getFieldLongName($sKey);
00381 $oField = $this->$sLongName;
00382
00383 if (!$blUseSkipSaveFields || ($blUseSkipSaveFields && !in_array($sKeyLowercase, $this->_aSkipSaveFields))) {
00384 $sKey = $this->getUpdateSqlFieldName($sKey);
00385 $sSql .= (($blSep) ? ',' : '') . $sKey . " = " . $this->_getUpdateFieldValue($sKey, $oField);
00386 $blSep = true;
00387 }
00388 }
00389
00390 return $sSql;
00391 }
00392
00402 protected function _getUpdateFields($blUseSkipSaveFields = true)
00403 {
00404 return $this->_getUpdateFieldsForTable($this->getCoreTableName(), $blUseSkipSaveFields);
00405 }
00406
00417 protected function _update()
00418 {
00419 $blRet = parent::_update();
00420
00421 if ($blRet) {
00422
00423 $aUpdateTables = array();
00424 if ($this->_blEmployMultilanguage) {
00425 $sCoreTable = $this->getCoreTableName();
00426 $sLangTable = getLangTableName($sCoreTable, $this->getLanguage());
00427 if ($sCoreTable != $sLangTable) {
00428 $aUpdateTables[] = $sLangTable;
00429 }
00430 } else {
00431 $aUpdateTables = $this->_getLanguageSetTables();
00432 }
00433 foreach ($aUpdateTables as $sLangTable) {
00434 $sUpdate = "insert into $sLangTable set " . $this->_getUpdateFieldsForTable($sLangTable, $this->getUseSkipSaveFields()) .
00435 " on duplicate key update " . $this->_getUpdateFieldsForTable($sLangTable);
00436
00437 $blRet = (bool) oxDb::getDb()->execute($sUpdate);
00438 }
00439 }
00440
00441
00442
00443 if ($blRet && $this->_blIsSeoObject && $this->isAdmin()) {
00444
00445 oxRegistry::get("oxSeoEncoder")->markAsExpired($this->getId(), null, 1, $this->getLanguage());
00446 }
00447
00448 return $blRet;
00449 }
00450
00458 protected function _getLanguageSetTables($sCoreTableName = null)
00459 {
00460 $sCoreTableName = $sCoreTableName ? $sCoreTableName : $this->getCoreTableName();
00461
00462 return oxNew('oxDbMetaDataHandler')->getAllMultiTables($sCoreTableName);
00463 }
00464
00472 protected function _insert()
00473 {
00474 $blRet = parent::_insert();
00475
00476 if ($blRet) {
00477
00478 foreach ($this->_getLanguageSetTables() as $sTable) {
00479 $sSq = "insert into $sTable set " . $this->_getUpdateFieldsForTable($sTable, $this->getUseSkipSaveFields());
00480 $blRet = $blRet && (bool) oxDb::getDb()->execute($sSq);
00481 }
00482 }
00483
00484 return $blRet;
00485 }
00486
00495 protected function _getObjectViewName($sTable, $sShopID = null)
00496 {
00497 if (!$this->_blEmployMultilanguage) {
00498 return parent::_getObjectViewName($sTable, $sShopID);
00499 }
00500
00501 return getViewName($sTable, $this->getLanguage(), $sShopID);
00502 }
00503
00515 protected function _getAllFields($blReturnSimple = false)
00516 {
00517 if ($this->_blEmployMultilanguage) {
00518 return parent::_getAllFields($blReturnSimple);
00519 } else {
00520 $sViewName = $this->getViewName();
00521 if (!$sViewName) {
00522 return array();
00523 }
00524
00525 return $this->_getTableFields($sViewName, $blReturnSimple);
00526 }
00527 }
00528
00539 protected function _addField($sName, $sStatus, $sType = null, $sLength = null)
00540 {
00541 if ($this->_blEmployMultilanguage && $this->_getFieldLang($sName)) {
00542 return;
00543 }
00544
00545 return parent::_addField($sName, $sStatus, $sType, $sLength);
00546 }
00547
00559 protected function _canFieldBeNull($sFieldName)
00560 {
00561 $sFieldName = preg_replace('/_\d{1,2}$/', '', $sFieldName);
00562
00563 return parent::_canFieldBeNull($sFieldName);
00564 }
00565
00573 public function delete($sOXID = null)
00574 {
00575 $blDeleted = parent::delete($sOXID);
00576 if ($blDeleted) {
00577 $oDB = oxDb::getDb();
00578 $sOXID = $oDB->quote($sOXID);
00579
00580
00581 foreach ($this->_getLanguageSetTables() as $sSetTbl) {
00582 $oDB->execute("delete from {$sSetTbl} where oxid = {$sOXID}");
00583 }
00584 }
00585
00586 return $blDeleted;
00587 }
00588 }