diff --git a/sql/data_fr.sql b/sql/data_fr.sql index 8342b1aca8ccc032142d920186445d41f217b8a0..379b2d620794e1f7ebfc9dee0e1cbd5d1455e003 100755 --- a/sql/data_fr.sql +++ b/sql/data_fr.sql @@ -4,43 +4,46 @@ TRUNCATE TABLE usergroups; TRUNCATE TABLE usergroups_services; DELETE FROM usergroups WHERE group_id = 'COURRIER'; DELETE FROM usergroups_services WHERE group_id = 'COURRIER'; -INSERT INTO usergroups (group_id,group_desc, can_index, indexation_parameters) VALUES ('COURRIER', 'Opérateur de numérisation', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); +INSERT INTO usergroups (id, group_id,group_desc, can_index, indexation_parameters) VALUES (1, 'COURRIER', 'Opérateur de numérisation', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); DELETE FROM usergroups WHERE group_id = 'AGENT'; DELETE FROM usergroups_services WHERE group_id = 'AGENT'; -INSERT INTO usergroups (group_id,group_desc, can_index, indexation_parameters) VALUES ('AGENT', 'Utilisateur', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); +INSERT INTO usergroups (id, group_id,group_desc, can_index, indexation_parameters) VALUES (2, 'AGENT', 'Utilisateur', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); DELETE FROM usergroups WHERE group_id = 'RESP_COURRIER'; DELETE FROM usergroups_services WHERE group_id = 'RESP_COURRIER'; -INSERT INTO usergroups (group_id,group_desc, can_index, indexation_parameters) VALUES ('RESP_COURRIER', 'Superviseur Courrier', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); +INSERT INTO usergroups (id, group_id,group_desc, can_index, indexation_parameters) VALUES (3, 'RESP_COURRIER', 'Superviseur Courrier', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); DELETE FROM usergroups WHERE group_id = 'RESPONSABLE'; DELETE FROM usergroups_services WHERE group_id = 'RESPONSABLE'; -INSERT INTO usergroups (group_id,group_desc, can_index, indexation_parameters) VALUES ('RESPONSABLE', 'Manager', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); +INSERT INTO usergroups (id, group_id,group_desc, can_index, indexation_parameters) VALUES (4, 'RESPONSABLE', 'Manager', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); DELETE FROM usergroups WHERE group_id = 'ADMINISTRATEUR_N1'; DELETE FROM usergroups_services WHERE group_id = 'ADMINISTRATEUR_N1'; -INSERT INTO usergroups (group_id,group_desc) VALUES ('ADMINISTRATEUR_N1', 'Admin. Fonctionnel N1'); +INSERT INTO usergroups (id, group_id,group_desc) VALUES (5, 'ADMINISTRATEUR_N1', 'Admin. Fonctionnel N1'); DELETE FROM usergroups WHERE group_id = 'ADMINISTRATEUR_N2'; DELETE FROM usergroups_services WHERE group_id = 'ADMINISTRATEUR_N2'; -INSERT INTO usergroups (group_id,group_desc) VALUES ('ADMINISTRATEUR_N2', 'Admin. Fonctionnel N2'); +INSERT INTO usergroups (id, group_id,group_desc) VALUES (6, 'ADMINISTRATEUR_N2', 'Admin. Fonctionnel N2'); DELETE FROM usergroups WHERE group_id = 'DIRECTEUR'; DELETE FROM usergroups_services WHERE group_id = 'DIRECTEUR'; -INSERT INTO usergroups (group_id,group_desc) VALUES ('DIRECTEUR', 'Directeur'); +INSERT INTO usergroups (id, group_id,group_desc) VALUES (7, 'DIRECTEUR', 'Directeur'); DELETE FROM usergroups WHERE group_id = 'ELU'; DELETE FROM usergroups_services WHERE group_id = 'ELU'; -INSERT INTO usergroups (group_id,group_desc) VALUES ('ELU', 'Elu'); +INSERT INTO usergroups (id, group_id,group_desc) VALUES (8, 'ELU', 'Elu'); DELETE FROM usergroups WHERE group_id = 'CABINET'; DELETE FROM usergroups_services WHERE group_id = 'CABINET'; -INSERT INTO usergroups (group_id,group_desc) VALUES ('CABINET', 'Cabinet'); +INSERT INTO usergroups (id, group_id,group_desc) VALUES (9, 'CABINET', 'Cabinet'); DELETE FROM usergroups WHERE group_id = 'ARCHIVISTE'; DELETE FROM usergroups_services WHERE group_id = 'ARCHIVISTE'; -INSERT INTO usergroups (group_id,group_desc) VALUES ('ARCHIVISTE', 'Archiviste'); +INSERT INTO usergroups (id, group_id,group_desc) VALUES (10, 'ARCHIVISTE', 'Archiviste'); DELETE FROM usergroups WHERE group_id = 'MAARCHTOGEC'; DELETE FROM usergroups_services WHERE group_id = 'MAARCHTOGEC'; -INSERT INTO usergroups (group_id,group_desc) VALUES ('MAARCHTOGEC', 'Envoi dématérialisé'); +INSERT INTO usergroups (id, group_id,group_desc) VALUES (11, 'MAARCHTOGEC', 'Envoi dématérialisé'); DELETE FROM usergroups WHERE group_id = 'SERVICE'; DELETE FROM usergroups_services WHERE group_id = 'SERVICE'; -INSERT INTO usergroups (group_id,group_desc) VALUES ('SERVICE', 'Service'); +INSERT INTO usergroups (id, group_id,group_desc) VALUES (12, 'SERVICE', 'Service'); DELETE FROM usergroups WHERE group_id = 'WEBSERVICE'; DELETE FROM usergroups_services WHERE group_id = 'WEBSERVICE'; -INSERT INTO usergroups (group_id,group_desc, can_index, indexation_parameters) VALUES ('WEBSERVICE', 'Utilisateurs de WebService', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); +INSERT INTO usergroups (id, group_id,group_desc, can_index, indexation_parameters) VALUES (13, 'WEBSERVICE', 'Utilisateurs de WebService', TRUE, '{"actions":["21"], "entities":[], "keywords":["ALL_ENTITIES"]}'); + +select setval('usergroups_id_seq', (select max(id)+1 from usergroups), false); + INSERT INTO usergroups_services (group_id, service_id) VALUES ('COURRIER', 'adv_search_mlb'); INSERT INTO usergroups_services (group_id, service_id) VALUES ('COURRIER', 'create_contacts'); INSERT INTO usergroups_services (group_id, service_id) VALUES ('COURRIER', 'update_contacts'); @@ -821,7 +824,7 @@ VALUES ('ACKNOWLEDGEMENT_RECEIPTS', 'ACKNOWLEDGEMENT_RECEIPTS', 'Dépôt des AR' --SUPERADMIN USER ------------ DELETE FROM users WHERE user_id='superadmin'; -INSERT INTO users (user_id, password, firstname, lastname, phone, mail, custom_t2, custom_t3, status, loginmode) VALUES ('superadmin', '$2y$10$Vq244c5s2zmldjblmMXEN./Q2qZrqtGVgrbz/l1WfsUJbLco4E.e.', 'Super', 'ADMIN', '0147245159', 'support@maarch.fr', NULL, NULL, 'OK', 'standard'); +INSERT INTO users (user_id, password, firstname, lastname, phone, mail, status, loginmode) VALUES ('superadmin', '$2y$10$Vq244c5s2zmldjblmMXEN./Q2qZrqtGVgrbz/l1WfsUJbLco4E.e.', 'Super', 'ADMIN', '0147245159', 'support@maarch.fr', 'OK', 'standard'); --MAARCH2GEC USER DELETE FROM users WHERE user_id = 'cchaplin'; INSERT INTO users (user_id, password, firstname, lastname, mail, status, loginmode) VALUES ('cchaplin', '$2y$10$C.QSslBKD3yNMfRPuZfcaubFwPKiCkqqOUyAdOr5FSGKPaePwuEjG', 'Charlie', 'CHAPLIN', 'support@maarch.fr', 'OK', 'restMode'); @@ -845,21 +848,26 @@ INSERT INTO contacts VALUES (9, 'title1', 'Eric', 'MACKIN', '', '', '', '13', 'r INSERT INTO contacts VALUES (10, 'title1', 'Carole', 'COTIN', 'MAARCH', '', 'Directrice Administrative et Qualité', '11', 'Boulevard du Sud-Est', NULL, '', '99000', 'MAARCH LES BAINS', 'FRANCE', 'info@maarch.org', '', NULL, 'Editeur du logiciel libre Maarch', 21, '2015-04-24 12:43:54.97424', '2016-07-25 16:28:38.498185', true, '{}'); INSERT INTO contacts VALUES (11, 'title1', 'Martin Donald', 'PELLE', '', '', '', '17', 'rue de la Demande', NULL, '', '99000', 'MAARCH-LES-BAINS', '', 'info@maarch.org', '01 23 24 21 22', NULL, '', 21, '2019-03-20 13:59:09.23436', NULL, true, '{}'); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (7, 'civility', false, false, false, false); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (8, 'firstname', false, true, true, true); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (9, 'lastname', true, true, true, true); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (10, 'company', true, false, true, true); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (11, 'department', false, false, false, false); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (12, 'function', false, false, false, false); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (13, 'address_number', false, false, true, true); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (14, 'address_street', false, true, true, true); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (15, 'address_additional1', false, false, false, false); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (16, 'address_additional2', false, false, false, false); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (17, 'address_postcode', false, true, true, true); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (18, 'address_town', false, true, true, true); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (19, 'address_country', false, false, false, false); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (20, 'email', false, true, false, false); -INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (21, 'phone', false, true, false, false); +select setval('contacts_id_seq', (select max(id)+1 from contacts), false); + +TRUNCATE TABLE contacts_parameters; +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (1, 'civility', false, false, false, false); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (2, 'firstname', false, true, true, true); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (3, 'lastname', true, true, true, true); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (4, 'company', true, false, true, true); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (5, 'department', false, false, false, false); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (6, 'function', false, false, false, false); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (7, 'address_number', false, false, true, true); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (8, 'address_street', false, true, true, true); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (9, 'address_additional1', false, false, false, false); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (10, 'address_additional2', false, false, false, false); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (11, 'address_postcode', false, true, true, true); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (12, 'address_town', false, true, true, true); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (13, 'address_country', false, false, false, false); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (14, 'email', false, true, false, false); +INSERT INTO contacts_parameters (id, identifier, mandatory, filling, searchable, displayable) VALUES (15, 'phone', false, true, false, false); + +select setval('contacts_parameters_id_seq', (select max(id)+1 from contacts_parameters), false); ------------ --STATUS- diff --git a/sql/structure.sql b/sql/structure.sql index f239a859c449eaf43573a50947f0142b4681428a..2dfb82baaa7ce25f8292e1f8a2d107ead1c99a55 100755 --- a/sql/structure.sql +++ b/sql/structure.sql @@ -261,11 +261,11 @@ CREATE TABLE res_attachments effective_date timestamp without time zone, work_batch bigint, origin character varying(50) DEFAULT NULL::character varying, - dest_user_id INTEGER, res_id_master bigint, origin_id INTEGER, attachment_type character varying(255) DEFAULT NULL::character varying, - contact_id integer, + recipient_id integer, + recipient_type character varying(256), in_signature_book boolean DEFAULT FALSE, in_send_attach boolean DEFAULT FALSE, signatory_user_serial_id int, diff --git a/src/app/contact/controllers/ContactGroupController.php b/src/app/contact/controllers/ContactGroupController.php index c7357075352d60d3e29f5c8fe2911f736d1691f7..1099f2c7b56d5e160c94eb415c0afdc63a119490 100755 --- a/src/app/contact/controllers/ContactGroupController.php +++ b/src/app/contact/controllers/ContactGroupController.php @@ -184,7 +184,7 @@ class ContactGroupController public function addContacts(Request $request, Response $response, array $aArgs) { - $contactsGroup = ContactGroupModel::getById(['select' => ['owner', 'label'], 'id' => $aArgs['id']]); + $contactsGroup = ContactGroupModel::getById(['id' => $aArgs['id']]); if (empty($contactsGroup)) { return $response->withStatus(400)->withJson(['errors' => 'Contacts Group does not exist']); } @@ -221,7 +221,6 @@ class ContactGroupController 'eventId' => 'contactsGroupListCreation', ]); - $contactsGroup = ContactGroupModel::getById(['id' => $aArgs['id']]); $contactsGroup['labelledOwner'] = UserModel::getLabelledUserById(['id' => $contactsGroup['owner']]); $contactsGroup['contacts'] = ContactGroupController::getFormattedListById(['id' => $aArgs['id']])['list']; @@ -261,16 +260,15 @@ class ContactGroupController $contacts = []; $position = 0; foreach ($list as $listItem) { - $contact = ContactModel::get([ + $contact = ContactModel::getById([ 'select' => [ 'id', 'firstname', 'lastname', 'company', 'address_number', 'address_street', 'address_town', 'address_postcode' ], - 'where' => ['id = ?'], - 'data' => [$listItem['contact_id']] + 'id' => $listItem['contact_id'] ]); - if (!empty($contact[0])) { - $contact = ContactController::getFormattedContactWithAddress(['contact' => $contact[0], 'position' => $position])['contact']; + if (!empty($contact)) { + $contact = ContactController::getFormattedContactWithAddress(['contact' => $contact, 'position' => $position])['contact']; $contact['position'] = !empty($position) ? $position : 0; $contacts[] = $contact; ++$position; diff --git a/test/unitTests/app/contact/ContactControllerTest.php b/test/unitTests/app/contact/ContactControllerTest.php index c3327d94f0bab4bfd2be335ab3bbc1448ad9be1b..4ea961670bab1896ec06589dfa587eaf3c5e8dda 100755 --- a/test/unitTests/app/contact/ContactControllerTest.php +++ b/test/unitTests/app/contact/ContactControllerTest.php @@ -242,36 +242,36 @@ class ContactControllerTest extends TestCase } - public function testControlLengthNameAfnor() - { - $name = \Contact\controllers\ContactController::controlLengthNameAfnor(['civility' => 'title1', 'fullName' => 'Prénom NOM', 'strMaxLength' => 38]); + public function testControlLengthNameAfnor() + { + $name = \Contact\controllers\ContactController::controlLengthNameAfnor(['civility' => 'title1', 'fullName' => 'Prénom NOM', 'strMaxLength' => 38]); - $this->assertSame('Monsieur Prénom NOM', $name); + $this->assertSame('Monsieur Prénom NOM', $name); - $name = \Contact\controllers\ContactController::controlLengthNameAfnor(['civility' => 'title3', 'fullName' => 'Prénom NOM TROP LOOOOOOOOOOOOONG', 'strMaxLength' => 38]); + $name = \Contact\controllers\ContactController::controlLengthNameAfnor(['civility' => 'title3', 'fullName' => 'Prénom NOM TROP LOOOOOOOOOOOOONG', 'strMaxLength' => 38]); - $this->assertSame('Mlle Prénom NOM TROP LOOOOOOOOOOOOONG', $name); - } + $this->assertSame('Mlle Prénom NOM TROP LOOOOOOOOOOOOONG', $name); + } - public function testAvailableReferential() - { - $contactController = new \Contact\controllers\ContactController(); - $availableReferential = $contactController->availableReferential(); - $this->assertInternalType('array', $availableReferential); - $this->assertNotEmpty($availableReferential); - } + public function testAvailableReferential() + { + $contactController = new \Contact\controllers\ContactController(); + $availableReferential = $contactController->availableReferential(); + $this->assertInternalType('array', $availableReferential); + $this->assertNotEmpty($availableReferential); + } - public function testGetFilling() - { - $environment = \Slim\Http\Environment::mock(['REQUEST_METHOD' => 'GET']); - $request = \Slim\Http\Request::createFromEnvironment($environment); + public function testGetContactsParameters() + { + $environment = \Slim\Http\Environment::mock(['REQUEST_METHOD' => 'GET']); + $request = \Slim\Http\Request::createFromEnvironment($environment); - $contactController = new \Contact\controllers\ContactController(); - $response = $contactController->getFilling($request, new \Slim\Http\Response()); - $responseBody = json_decode((string)$response->getBody()); + $contactController = new \Contact\controllers\ContactController(); + $response = $contactController->getContactsParameters($request, new \Slim\Http\Response()); + $responseBody = json_decode((string)$response->getBody()); - $this->assertInternalType('array', (array)$responseBody->contactsFilling); - } + $this->assertInternalType('array', (array)$responseBody->contactsFilling); + } // public function testUpdateFilling() // { diff --git a/test/unitTests/app/contact/ContactGroupControllerTest.php b/test/unitTests/app/contact/ContactGroupControllerTest.php index 903995a35c80f5dc285925c7dc397d24c23d2ef5..aaae94abe392e5996980a9a7c37e420d4e273437 100755 --- a/test/unitTests/app/contact/ContactGroupControllerTest.php +++ b/test/unitTests/app/contact/ContactGroupControllerTest.php @@ -127,7 +127,7 @@ class ContactGroupControllerTest extends TestCase $this->assertSame(self::$id, $responseBody->contactsGroup->id); $this->assertNotEmpty($responseBody->contactsGroup); $this->assertNotEmpty($responseBody->contactsGroup->contacts); - $this->assertSame($contacts[0]['id'], $responseBody->contactsGroup->contacts[0]->addressId); + $this->assertSame($contacts[0]['id'], $responseBody->contactsGroup->contacts[0]->id); $this->assertSame(0, $responseBody->contactsGroup->contacts[0]->position); $this->assertInternalType('string', $responseBody->contactsGroup->contacts[0]->contact); $this->assertInternalType('string', $responseBody->contactsGroup->contacts[0]->address); @@ -148,7 +148,7 @@ class ContactGroupControllerTest extends TestCase $environment = \Slim\Http\Environment::mock(['REQUEST_METHOD' => 'DELETE']); $request = \Slim\Http\Request::createFromEnvironment($environment); - $response = $contactGroupController->deleteContact($request, new \Slim\Http\Response(), ['id' => self::$id, 'addressId' => $contacts[0]['id']]); + $response = $contactGroupController->deleteContact($request, new \Slim\Http\Response(), ['id' => self::$id, 'contactId' => $contacts[0]['id']]); $responseBody = json_decode((string)$response->getBody()); $this->assertSame('success', $responseBody->success); diff --git a/test/unitTests/core/AutocompleteControllerTest.php b/test/unitTests/core/AutocompleteControllerTest.php index f9c0fbb358b54f7ce1ddbe18195085967de7691f..4ecf10b38ae05bed77b03859e4ad68151933ab33 100755 --- a/test/unitTests/core/AutocompleteControllerTest.php +++ b/test/unitTests/core/AutocompleteControllerTest.php @@ -34,7 +34,6 @@ class AutocompleteControllerTest extends TestCase $this->assertNotEmpty($responseBody); foreach ($responseBody as $value) { - $this->assertInternalType('int', $value->position); $this->assertInternalType('int', $value->id); $this->assertInternalType('string', $value->contact); $this->assertInternalType('string', $value->address);