mirror of
				https://github.com/xfarrow/blink
				synced 2025-06-27 09:03:02 +02:00 
			
		
		
		
	update removeOrganizationAdmin
This commit is contained in:
		| @@ -565,10 +565,10 @@ async function addOrganizationAdmin(req, res){ | |||||||
|  * DELETE Request |  * DELETE Request | ||||||
|  *  |  *  | ||||||
|  * Deletes a Person from the list of Administrators of an Organization. |  * Deletes a Person from the list of Administrators of an Organization. | ||||||
|  * The logged user can only remove themselves. |  * The logged user can only remove themselves. If no more Administrators | ||||||
|  |  * are left, the Organization is removed. | ||||||
|  *  |  *  | ||||||
|  * Required field(s): organization_id |  * Required field(s): organization_id | ||||||
|  * @returns  |  | ||||||
|  */ |  */ | ||||||
| async function removeOrganizationAdmin(req, res){ | async function removeOrganizationAdmin(req, res){ | ||||||
|    |    | ||||||
| @@ -578,26 +578,31 @@ async function removeOrganizationAdmin(req, res){ | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     try{ |     try{ | ||||||
|       knex.transaction(async (trx) => { |       const transaction = await knex.transaction(); | ||||||
|         await trx('OrganizationAdministrator') |  | ||||||
|  |       // We lock the table to ensure that we won't have concurrency issues | ||||||
|  |       // while checking remainingAdministrators. | ||||||
|  |       // TODO: Understand whether a lock on the table is necessary | ||||||
|  |       await transaction.raw('LOCK TABLE "OrganizationAdministrator" IN SHARE MODE'); | ||||||
|  |        | ||||||
|  |       await transaction('OrganizationAdministrator') | ||||||
|         .where('id_person', req.jwt.person_id) |         .where('id_person', req.jwt.person_id) | ||||||
|         .where('id_organization', req.body.organization_id) |         .where('id_organization', req.body.organization_id) | ||||||
|         .del(); |         .del(); | ||||||
|  |  | ||||||
|           // Delete Organization if there are no admins left. |       // TODO: If the user instead deletes their entire profile, the organization will not be deleted. Fix. (database schema) | ||||||
|           // TODO: If the user instead deletes their entire profile, the organization will not be deleted. Fix. |       const remainingAdministrators = await transaction('OrganizationAdministrator') | ||||||
|           // TODO: Check what level of transaction we are using to avoid inconsistencies. Update: it is READ COMMITTED see https://www.geeksforgeeks.org/transaction-isolation-levels-dbms/ |         .where({ id_organization: req.body.organization_id }); | ||||||
|           const count = await trx('OrganizationAdministrator') |  | ||||||
|             .count('id as count') |  | ||||||
|             .where('id', req.body.organization_id); |  | ||||||
|  |  | ||||||
|           if(count[0].count == 1){ |       if (remainingAdministrators.length === 0) { | ||||||
|             await trx('Organization') |         // If no more users, delete the organization | ||||||
|  |         await transaction('Organization') | ||||||
|             .where('id', req.body.organization_id) |             .where('id', req.body.organization_id) | ||||||
|             .del(); |             .del(); | ||||||
|       } |       } | ||||||
|  |  | ||||||
|  |       await transaction.commit(); | ||||||
|       return res.status(200).json({success : true}); |       return res.status(200).json({success : true}); | ||||||
|       }); |  | ||||||
|     } |     } | ||||||
|     catch (error){ |     catch (error){ | ||||||
|       console.error(error); |       console.error(error); | ||||||
|   | |||||||
| @@ -9,7 +9,6 @@ CREATE TABLE IF NOT EXISTS public."OrganizationPost" | |||||||
|     content text COLLATE pg_catalog."default" NOT NULL, |     content text COLLATE pg_catalog."default" NOT NULL, | ||||||
|     created_at timestamp without time zone DEFAULT now(), |     created_at timestamp without time zone DEFAULT now(), | ||||||
|     original_author integer NOT NULL, |     original_author integer NOT NULL, | ||||||
|     CONSTRAINT "OrganizationPost_pkey" PRIMARY KEY (id), |  | ||||||
|     CONSTRAINT "AuthorIdFK" FOREIGN KEY (original_author) |     CONSTRAINT "AuthorIdFK" FOREIGN KEY (original_author) | ||||||
|         REFERENCES public."Person" (id) MATCH SIMPLE |         REFERENCES public."Person" (id) MATCH SIMPLE | ||||||
|         ON UPDATE NO ACTION |         ON UPDATE NO ACTION | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user