public function executeSave(sfWebRequest $request) { $role = RolePeer::retrieveByPK($request->getParameter('id')); $this->forward404Unless($role); $perms = $request->getParameter('permissions'); if (!is_array($perms)) { $perms = array(); } # remove rights $c = new Criteria(); $c->add(RolePermissionPeer::ROLE_ID, $role->getId()); RolePermissionPeer::doDelete($c); # save new rights foreach ($perms as $perm) { $role_permission = new RolePermission(); $role_permission->setPermissionId($perm); $role_permission->setRoleId($role->getId()); $role_permission->save(); } return $this->renderText('Rights for \'' . $role->getTitle() . '\' have successfully saved!'); }
/** * Removes this object from datastore and sets delete attribute. * * @param PropelPDO $con * @return void * @throws PropelException * @see BaseObject::setDeleted() * @see BaseObject::isDeleted() */ public function delete(PropelPDO $con = null) { foreach (sfMixer::getCallables('BaseRolePermission:delete:pre') as $callable) { $ret = call_user_func($callable, $this, $con); if ($ret) { return; } } if ($this->isDeleted()) { throw new PropelException("This object has already been deleted."); } if ($con === null) { $con = Propel::getConnection(RolePermissionPeer::DATABASE_NAME, Propel::CONNECTION_WRITE); } $con->beginTransaction(); try { RolePermissionPeer::doDelete($this, $con); $this->setDeleted(true); $con->commit(); } catch (PropelException $e) { $con->rollBack(); throw $e; } foreach (sfMixer::getCallables('BaseRolePermission:delete:post') as $callable) { call_user_func($callable, $this, $con); } }