2014-09-27 50 views
1

我在TYPO3 6.2中創建了一個extbase插件。在一個表中,我有一個字段「fuid」,我想存儲fe_users uid,知道哪個用戶可以編輯這條記錄。TYPO3 Extbase fe_user自己的模型中的UID

我設置createAction的 「FUID」:

$newLocation->setFuID((int) $GLOBALS['TSFE']->fe_user->user['uid']); 

這項工作。在數據庫中是正確的UID。

但在editAction:

$location->getFuID() 
returns null 

爲什麼?

TCA:

fu_i_d' => array(
      'exclude' => 1, 
      'label' => 'LLL:EXT:pitss24/Resources/Private/Language/locallang_db.xlf:tx_pitss24_domain_model_location.fu_i_d', 
      'config' => array(
       'type' => 'select', 
       'items' => array (
         array('',0), 
       ), 
       'foreign_table' => 'fe_users', 
       'foreign_class' => '\TYPO3\CMS\Extbase\Domain\Model\FrontendUser', 
       'minitems' => 0, 
       'maxitems' => 1, 
       'size' => 10, 
       'appearance' => array(
        'collapseAll' => 0, 
        'levelLinksPosition' => 'top', 
        'showSynchronizationLink' => 1, 
        'showPossibleLocalizationRecords' => 1, 
        'showAllLocalizationLink' => 1 
       ), 
      ), 
     ), 

在後端/ TYPO3是一切OK!

回答

1

我發現錯誤!該extensionBuilder示範寫入錯誤數據:

正確的價值觀是:

型號:

/* 
* 
* @var TYPO3\CMS\Extbase\Domain\Model\FrontendUser 
*/ 
protected $fuID = NULL; 

... 
... 
... 

/** 
* Returns the fuID 
* 
* @return TYPO3\CMS\Extbase\Domain\Model\FrontendUser fuID 
*/ 
public function getFuID() { 
    return $this->fuID; 
} 

/* 
* Sets the fuID 
* 
* @param string $fuID 
* @return TYPO3\CMS\Extbase\Domain\Model\FrontendUser fuID 
*/ 
public function setFuID(TYPO3\CMS\Extbase\Domain\Model\FrontendUser $fuID) { 
    $this->fuID = $fuID; 
} 

控制器:

/** 
    * User Repository 
    * 
    * @var \TYPO3\CMS\Extbase\Domain\Repository\FrontendUserRepository 
    * @inject 
    */ 
    protected $userRepository; 

    /** 
    * Den aktuell angemeldeten User auslesen 
    * 
    * @return \TYPO3\CMS\Extbase\Domain\Repository\FrontendUserRepository 
    */ 
    public function getCurrentUser() { 
     if ($this->currentUser == NULL && $GLOBALS['TSFE']->fe_user->user['uid'] > 0) { 
      $this->currentUser = $this->userRepository->findByUid($GLOBALS['TSFE']->fe_user->user['uid']); 
     } 

     return $this->currentUser; 
    } 
0

很難說沒有適當的模型視圖。很可能你的模型和TCA之間不匹配:一方面你使用的是整數(setFuID()),另一方面你有一個對象(foreign_table/foreign_class)。也許它已經調整後,這是相同的工作。

+0

從$位置的保護值爲NULL了。它不會加載數據庫中的值。我不知道爲什麼extensionBuilder命名了某些時候的fuid函數,但是mysql字段是fu_i_d,這兩者的映射在哪裏? – Burner 2014-09-27 17:35:06

+1

如果遵循編碼約定,則會自動進行映射(在正常情況下)。 lowerCamelCase get的轉換爲lower_cased_underscored(lowerCase => lower_case),反之亦然。 – RoyalKnight 2014-09-27 17:38:47

+0

您需要什麼信息?我也在這個擴展的其他插件上也有相同的錯誤。大多數事情都是來自擴展管理器的默認設置。我不知道哪裏可以找到這個錯誤。 – Burner 2014-10-11 07:58:59

2

在模型文件。

/** 
* feuseruid 
* 
* @var \TYPO3\CMS\Extbase\Domain\Model\FrontendUser 
*/ 
protected $feuseruid; 

// GET and SET Methods 

/** 
* Returns the feuseruid 
* 
* @return \TYPO3\CMS\Extbase\Domain\Model\FrontendUser feuseruid 
*/ 
public function getFeuseruid() { 
    return $this->feuseruid; 
} 

/* 
* Sets the feuseruid 
* 
* @param string $feuseruid 
* @return \TYPO3\CMS\Extbase\Domain\Model\FrontendUser feuseruid 
*/ 
public function setFeuseruid(\TYPO3\CMS\Extbase\Domain\Model\FrontendUser $feuseruid) { 
    $this->feuseruid = $feuseruid; 
} 

在TCA文件

'feuseruid' => array(
    'exclude' => 1, 
    'label' => 'Feuser Id', 
    'config' => array(
     'type' => 'inline', 
     'foreign_table' => 'fe_users', 
     'minitems' => 0, 
     'maxitems' => 1, 
     'appearance' => array(
      'collapseAll' => 0, 
      'levelLinksPosition' => 'top', 
      'showSynchronizationLink' => 1, 
      'showPossibleLocalizationRecords' => 1, 
      'showAllLocalizationLink' => 1 
     ), 
    ), 
), 

在Sql.php

feuseruid int(11) unsigned DEFAULT '0' NOT NULL, 

在控制器

/** 
* User Repository 
* 
* @var \TYPO3\CMS\Extbase\Domain\Repository\FrontendUserRepository 
* @inject 
*/ 
protected $userRepository; 

$userObject = $this->userRepository->findByUid($GLOBALS['TSFE']->fe_user->user['uid']); 
$orders->setFeuseruid($userObject); 
$this->yourRepository->add($orders);