before(function (Request $request) use ($app) { $app['firewall']->requireAuthentication() ->requireRight('addrecord') ->requireRight('deleterecord'); }); $controllers->post('/', 'controller.prod.move-collection:displayForm') ->bind('prod_move_collection'); $controllers->post('/apply/', 'controller.prod.move-collection:apply') ->bind('prod_move_collection_apply'); return $controllers; } public function displayForm(Application $app, Request $request) { $records = RecordsRequest::fromRequest($app, $request, false, ['candeleterecord']); $sbas_ids = array_map(function (\databox $databox) { return $databox->get_sbas_id(); }, $records->databoxes()); $collections = $app['acl']->get($app['authentication']->getUser()) ->get_granted_base(['canaddrecord'], $sbas_ids); $parameters = [ 'records' => $records, 'message' => '', 'collections' => $collections, ]; return $app['twig']->render('prod/actions/collection_default.html.twig', $parameters); } public function apply(Application $app, Request $request) { $records = RecordsRequest::fromRequest($app, $request, false, ['candeleterecord']); $datas = [ 'success' => false, 'message' => '', ]; try { if (null === $request->request->get('base_id')) { $datas['message'] = _('Missing target collection'); return $app->json($datas); } if (!$app['acl']->get($app['authentication']->getUser())->has_right_on_base($request->request->get('base_id'), 'canaddrecord')) { $datas['message'] = sprintf(_("You do not have the permission to move records to %s"), \phrasea::bas_labels($move->getBaseIdDestination(), $app)); return $app->json($datas); } try { $collection = \collection::get_from_base_id($app, $request->request->get('base_id')); } catch (\Exception_Databox_CollectionNotFound $e) { $datas['message'] = _('Invalid target collection'); return $app->json($datas); } foreach ($records as $record) { $record->move_to_collection($collection, $app['phraseanet.appbox']); if ($request->request->get("chg_coll_son") == "1") { foreach ($record->get_children() as $child) { if ($app['acl']->get($app['authentication']->getUser())->has_right_on_base($child->get_base_id(), 'candeleterecord')) { $child->move_to_collection($collection, $app['phraseanet.appbox']); } } } } $ret = [ 'success' => true, 'message' => _('Records have been successfuly moved'), ]; } catch (\Exception $e) { $ret = [ 'success' => false, 'message' => _('An error occured'), ]; } return $app->json($ret); } }