已删除记录的Extbase属性映射

时间:2016-06-07 06:44:56

标签: typo3 extbase typo3-7.6.x

我想为创建表单构建预览页面。我在previewAction时将记录的“已删除”属性设置为“1”,因为在BE中列表模块用于批准插入的记录 - 所以如果记录从未最终保存,则无论如何都要删除。

问题:我可以创建记录(deleted=1) - 我可以跳回到表单(没有历史记录,因为我必须保留创建的对象)。但如果我再次提交属性映射告诉我

未找到标识“3”的MyModel类型的对象。

当然那是因为它被删除了。存储库中忽略已删除的设置未在此处执行操作。

是的,我可以通过手动填写所有内容来绕过Extbase魔法,但这不是我想要的。

以下是了解我正在尝试的行动

 /**
 * action preview
 *
 * @param MyModel
 * @return void
 */
public function previewAction(MyModel $newModel)
{
    //check if model was already saved
    $uid = $this->request->hasArgument('uid') ? this->request->getArgument('uid') : 0;
    if($uid){
        $newModel = $this->myRepository->findDeletedByUid($uid);
        $this->myRepository->update($newModel);
    }
    else{
        $newModel->setDeleted(true);
        $this->myRepository->add($newModel);
    }

    $this->view->assign('ad', $newModel);
    $this->persistenceManager->persistAll();

    $uid = $this->persistenceManager->getIdentifierByObject($newModel);
    $this->view->assign('uid', $uid);
}

有什么想法吗?

4 个答案:

答案 0 :(得分:4)

Extbase默认查询设置会禁止删除的对象。

由于您已在存储库中声明了自定义查询findDeletedByUid(),因此您只需将其设置为包含已删除的记录。但是,重要的是,如果要使用对象调用控制器操作,则必须在调用操作之前检索它。使用初始化操作。初始化将在动作之前自动调用。

如果要设置删除对象,您还需要在域模型中定义属性,getter和setter以及在tca中定义一个正确的定义,以使数据映射器能够访问列。

在存储库中:

public function findDeletedByUid($uid) {
    $query = $this->createQuery();
    $query->getQuerySettings()->setIncludeDeleted(true);
    $query->matching(
        $query->equals('uid',$uid)
    );
    return $query->execute();
}

在您的Controller类中:

/**
 * initialize action previewAction
 * Overrides the default initializeAction with one that can retrieve deleted objects
 */
public function initializePreviewAction(){
    if( $this->request->hasArgument('mymodel') ){
      $uid = $this->request->getArgument('mymodel');
      if( $mymodel = $this->mymodelRepository->findDeletedByUid($uid) ){
          $this->request->setArgument($mymodel);
      } else {
          // handle non retrievable object here
      }
    } else {
      // handle missing argument here
    }
}

在您的域模型中:

...
/**
 * @var bool
 */
protected $deleted;

/**
 * @return bool
 */
public function getDeleted() {
    return $this->deleted;
}

/**
 * @param bool $deleted
 */
public function setDeleted($deleted) {
    $this->deleted = $deleted;
}

在你的tca.php中

...
'deleted' => array(
    'exclude' => 1,
    'label' => 'LLL:EXT:lang/locallang_general.xlf:LGL.deleted',
    'config' => array(
        'type' => 'check',
    ),
),

答案 1 :(得分:0)

您应该使用隐藏字段来允许编辑者预览文档,而不是删除任何魔法。 您可以告诉您的查询在存储库中包含隐藏的记录。

答案 2 :(得分:0)

你的findDeletedByUid($uid)功能引起了我的注意。如果它不是自定义函数,是应该将findByDeleted(TRUE)findByDeleted(1)->getFirst()->findByUid()结合使用?您可以在Extbase manual referenceRepository __call() function API部分找到讨论。

答案 3 :(得分:0)

感谢所有提示。

我认为根据答案,如果没有绕过extbase属性映射魔法,它是不可能的。所以我认为一般来说这样做并不是一个好主意。

所以我现在把我自己的旗帜"存储"到模型。

在BE列表模块中,不存储"存储"对象仍然可见,但使用自己的BE模块或删除not"存储" cron-job的对象应该可以胜任。

如果有人有床位想法,请随时分享: - )