2014-09-27 49 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);