forked from OpenWF/SpaceNinjaServer
		
	feat: leave alliance/kick alliance members (#1459)
Reviewed-on: OpenWF/SpaceNinjaServer#1459 Co-authored-by: Sainan <63328889+Sainan@users.noreply.github.com> Co-committed-by: Sainan <63328889+Sainan@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									d94b4fd946
								
							
						
					
					
						commit
						23267aa641
					
				
							
								
								
									
										38
									
								
								src/controllers/api/removeFromAllianceController.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/controllers/api/removeFromAllianceController.ts
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,38 @@
 | 
			
		||||
import { AllianceMember, Guild, GuildMember } from "@/src/models/guildModel";
 | 
			
		||||
import { deleteAlliance } from "@/src/services/guildService";
 | 
			
		||||
import { getAccountForRequest } from "@/src/services/loginService";
 | 
			
		||||
import { GuildPermission } from "@/src/types/guildTypes";
 | 
			
		||||
import { RequestHandler } from "express";
 | 
			
		||||
 | 
			
		||||
export const removeFromAllianceController: RequestHandler = async (req, res) => {
 | 
			
		||||
    // Check requester is a warlord in their guild
 | 
			
		||||
    const account = await getAccountForRequest(req);
 | 
			
		||||
    const guildMember = (await GuildMember.findOne({ accountId: account._id, status: 0 }))!;
 | 
			
		||||
    if (guildMember.rank > 1) {
 | 
			
		||||
        res.status(400).json({ Error: 104 });
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    let allianceMember = (await AllianceMember.findOne({ guildId: guildMember.guildId }))!;
 | 
			
		||||
    if (!guildMember.guildId.equals(req.query.guildId as string)) {
 | 
			
		||||
        // Removing a guild that is not our own needs additional permissions
 | 
			
		||||
        if (!(allianceMember.Permissions & GuildPermission.Ruler)) {
 | 
			
		||||
            res.status(400).json({ Error: 104 });
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // Update allianceMember to point to the alliance to kick
 | 
			
		||||
        allianceMember = (await AllianceMember.findOne({ guildId: req.query.guildId }))!;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (allianceMember.Permissions & GuildPermission.Ruler) {
 | 
			
		||||
        await deleteAlliance(allianceMember.allianceId);
 | 
			
		||||
    } else {
 | 
			
		||||
        await Promise.all([
 | 
			
		||||
            await Guild.updateOne({ _id: allianceMember.guildId }, { $unset: { AllianceId: "" } }),
 | 
			
		||||
            await AllianceMember.deleteOne({ _id: allianceMember._id })
 | 
			
		||||
        ]);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    res.end();
 | 
			
		||||
};
 | 
			
		||||
@ -92,6 +92,7 @@ import { purchaseController } from "@/src/controllers/api/purchaseController";
 | 
			
		||||
import { queueDojoComponentDestructionController } from "@/src/controllers/api/queueDojoComponentDestructionController";
 | 
			
		||||
import { redeemPromoCodeController } from "@/src/controllers/api/redeemPromoCodeController";
 | 
			
		||||
import { releasePetController } from "@/src/controllers/api/releasePetController";
 | 
			
		||||
import { removeFromAllianceController } from "@/src/controllers/api/removeFromAllianceController";
 | 
			
		||||
import { removeFromGuildController } from "@/src/controllers/api/removeFromGuildController";
 | 
			
		||||
import { rerollRandomModController } from "@/src/controllers/api/rerollRandomModController";
 | 
			
		||||
import { retrievePetFromStasisController } from "@/src/controllers/api/retrievePetFromStasisController";
 | 
			
		||||
@ -173,6 +174,7 @@ apiRouter.get("/marketRecommendations.php", marketRecommendationsController);
 | 
			
		||||
apiRouter.get("/marketSearchRecommendations.php", marketRecommendationsController);
 | 
			
		||||
apiRouter.get("/modularWeaponSale.php", modularWeaponSaleController);
 | 
			
		||||
apiRouter.get("/queueDojoComponentDestruction.php", queueDojoComponentDestructionController);
 | 
			
		||||
apiRouter.get("/removeFromAlliance.php", removeFromAllianceController);
 | 
			
		||||
apiRouter.get("/setActiveQuest.php", setActiveQuestController);
 | 
			
		||||
apiRouter.get("/setActiveShip.php", setActiveShipController);
 | 
			
		||||
apiRouter.get("/setBootLocation.php", setBootLocationController);
 | 
			
		||||
 | 
			
		||||
@ -1,7 +1,7 @@
 | 
			
		||||
import { Request } from "express";
 | 
			
		||||
import { getAccountIdForRequest } from "@/src/services/loginService";
 | 
			
		||||
import { getInventory } from "@/src/services/inventoryService";
 | 
			
		||||
import { AllianceMember, Guild, GuildAd, GuildMember, TGuildDatabaseDocument } from "@/src/models/guildModel";
 | 
			
		||||
import { Alliance, AllianceMember, Guild, GuildAd, GuildMember, TGuildDatabaseDocument } from "@/src/models/guildModel";
 | 
			
		||||
import { TInventoryDatabaseDocument } from "@/src/models/inventoryModels/inventoryModel";
 | 
			
		||||
import {
 | 
			
		||||
    GuildPermission,
 | 
			
		||||
@ -613,9 +613,26 @@ export const deleteGuild = async (guildId: Types.ObjectId): Promise<void> => {
 | 
			
		||||
 | 
			
		||||
    await GuildAd.deleteOne({ GuildId: guildId });
 | 
			
		||||
 | 
			
		||||
    await AllianceMember.deleteMany({ guildId });
 | 
			
		||||
    // If guild is the creator of an alliance, delete that as well.
 | 
			
		||||
    const allianceMember = await AllianceMember.findOne({ guildId, Pending: false });
 | 
			
		||||
    if (allianceMember) {
 | 
			
		||||
        if (allianceMember.Permissions & GuildPermission.Ruler) {
 | 
			
		||||
            await deleteAlliance(allianceMember.allianceId);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // TODO: If this guild was the founding guild of an alliance (ruler permission), that would need to be forcefully deleted now as well.
 | 
			
		||||
    await AllianceMember.deleteMany({ guildId });
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export const deleteAlliance = async (allianceId: Types.ObjectId): Promise<void> => {
 | 
			
		||||
    const allianceMembers = await AllianceMember.find({ allianceId, Pending: false });
 | 
			
		||||
    await parallelForeach(allianceMembers, async allianceMember => {
 | 
			
		||||
        await Guild.updateOne({ _id: allianceMember.guildId }, { $unset: { AllianceId: "" } });
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    await AllianceMember.deleteMany({ allianceId });
 | 
			
		||||
 | 
			
		||||
    await Alliance.deleteOne({ _id: allianceId });
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export const getAllianceClient = async (
 | 
			
		||||
 | 
			
		||||
@ -71,11 +71,11 @@ export interface ILongMOTD {
 | 
			
		||||
 | 
			
		||||
// 32 seems to be reserved
 | 
			
		||||
export enum GuildPermission {
 | 
			
		||||
    Ruler = 1, // Clan: Change hierarchy. Alliance: Kick clans.
 | 
			
		||||
    Ruler = 1, // Clan: Change hierarchy. Alliance (Creator only): Kick clans.
 | 
			
		||||
    Advertiser = 8192,
 | 
			
		||||
    Recruiter = 2, // Send invites (Clans & Alliances)
 | 
			
		||||
    Regulator = 4, // Kick members
 | 
			
		||||
    Promoter = 8, // Clan: Promote and demote members. Alliance: Change clan permissions.
 | 
			
		||||
    Promoter = 8, // Clan: Promote and demote members. Alliance (Creator only): Change clan permissions.
 | 
			
		||||
    Architect = 16, // Create and destroy rooms
 | 
			
		||||
    Decorator = 1024, // Create and destroy decos
 | 
			
		||||
    Treasurer = 64, // Clan: Contribute from vault and edit tax rate. Alliance: Divvy vault.
 | 
			
		||||
@ -318,5 +318,4 @@ export interface IAllianceMemberDatabase {
 | 
			
		||||
    Permissions: number;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// TODO: GET /api/removeFromAlliance.php?accountId=6633b81e9dba0b714f28ff02&nonce=5702391171614479&ct=MSI&guildId=663e9be9f741eeb5782f9df0
 | 
			
		||||
// TODO: GET /api/setAllianceGuildPermissions.php?accountId=6633b81e9dba0b714f28ff02&nonce=5702391171614479&ct=MSI&guildId=000000000000000000000042&perms=2
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user