forked from administration/panel
				
			feat: allow adding users to a server
							parent
							
								
									cf71aa49cb
								
							
						
					
					
						commit
						c3f18cec9b
					
				|  | @ -14,18 +14,21 @@ import { | ||||||
| import { Check, ChevronsUpDown } from "lucide-react"; | import { Check, ChevronsUpDown } from "lucide-react"; | ||||||
| import { cn } from "@/lib/utils"; | import { cn } from "@/lib/utils"; | ||||||
| import { useState } from "react"; | import { useState } from "react"; | ||||||
| import { updateServerDiscoverability, updateServerFlags, updateServerOwner } from "@/lib/actions"; | import { addServerMember, updateServerDiscoverability, updateServerFlags, updateServerOwner } from "@/lib/actions"; | ||||||
| import { useToast } from "../../ui/use-toast"; | import { useToast } from "../../ui/use-toast"; | ||||||
| import Link from "next/link"; | import Link from "next/link"; | ||||||
| import { DropdownMenu, DropdownMenuContent } from "@/components/ui/dropdown-menu"; | import { DropdownMenu, DropdownMenuContent } from "@/components/ui/dropdown-menu"; | ||||||
| import { DropdownMenuTrigger } from "@radix-ui/react-dropdown-menu"; | import { DropdownMenuTrigger } from "@radix-ui/react-dropdown-menu"; | ||||||
| import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle, AlertDialogTrigger } from "@/components/ui/alert-dialog"; | import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle, AlertDialogTrigger } from "@/components/ui/alert-dialog"; | ||||||
| import { Input } from "@/components/ui/input"; | import { Input } from "@/components/ui/input"; | ||||||
|  | import { Checkbox } from "@/components/ui/checkbox"; | ||||||
| 
 | 
 | ||||||
| export function ServerActions({ server }: { server: Server }) { | export function ServerActions({ server }: { server: Server }) { | ||||||
|   const [selectBadges, setSelectBadges] = useState(false); |   const [selectBadges, setSelectBadges] = useState(false); | ||||||
|   const [serverDraft, setDraft] = useState(server); |   const [serverDraft, setDraft] = useState(server); | ||||||
|   const [newOwner, setNewOwner] = useState(""); |   const [newOwner, setNewOwner] = useState(""); | ||||||
|  |   const [newMember, setNewMember] = useState(""); | ||||||
|  |   const [newMemberEvent, setNewMemberEvent] = useState(true); | ||||||
|   const { toast } = useToast(); |   const { toast } = useToast(); | ||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|  | @ -194,6 +197,51 @@ export function ServerActions({ server }: { server: Server }) { | ||||||
|               </AlertDialogFooter> |               </AlertDialogFooter> | ||||||
|             </AlertDialogContent> |             </AlertDialogContent> | ||||||
|           </AlertDialog> |           </AlertDialog> | ||||||
|  | 
 | ||||||
|  |           <AlertDialog> | ||||||
|  |             <AlertDialogTrigger asChild> | ||||||
|  |               <Button variant="ghost"> | ||||||
|  |                 Add member | ||||||
|  |               </Button> | ||||||
|  |             </AlertDialogTrigger> | ||||||
|  |             <AlertDialogContent> | ||||||
|  |               <AlertDialogHeader> | ||||||
|  |                 <AlertDialogTitle> | ||||||
|  |                   Add member to server | ||||||
|  |                 </AlertDialogTitle> | ||||||
|  |                 <AlertDialogDescription className="flex flex-col gap-2"> | ||||||
|  |                   Enter the ID of the user you want to add. | ||||||
|  |                   <Input | ||||||
|  |                     placeholder="01EXAF3KX65608AJ4NG27YG1HM" | ||||||
|  |                     value={newMember} | ||||||
|  |                     onChange={(e) => setNewMember(e.currentTarget.value)} | ||||||
|  |                   /> | ||||||
|  |                   <Checkbox checked={newMemberEvent} onChange={(state) => setNewMemberEvent(state === true)}>Publish join event</Checkbox> | ||||||
|  |                 </AlertDialogDescription> | ||||||
|  |               </AlertDialogHeader> | ||||||
|  |               <AlertDialogFooter> | ||||||
|  |                 <AlertDialogCancel>Cancel</AlertDialogCancel> | ||||||
|  |                 <AlertDialogAction | ||||||
|  |                   disabled={newMember.length != 26} | ||||||
|  |                   onClick={async () => { | ||||||
|  |                     try { | ||||||
|  |                       await addServerMember(server._id, newMember, newMemberEvent); | ||||||
|  |                       setNewMember(""); | ||||||
|  |                       toast({ title: "User added to server" }); | ||||||
|  |                     } catch(e) { | ||||||
|  |                       toast({ | ||||||
|  |                         title: "Failed to add user", | ||||||
|  |                         description: String(e), | ||||||
|  |                         variant: "destructive", | ||||||
|  |                       }); | ||||||
|  |                     } | ||||||
|  |                   }} | ||||||
|  |                 > | ||||||
|  |                   Update | ||||||
|  |                 </AlertDialogAction> | ||||||
|  |               </AlertDialogFooter> | ||||||
|  |             </AlertDialogContent> | ||||||
|  |           </AlertDialog> | ||||||
|         </DropdownMenuContent> |         </DropdownMenuContent> | ||||||
|       </DropdownMenu> |       </DropdownMenu> | ||||||
|     </div> |     </div> | ||||||
|  |  | ||||||
|  | @ -37,7 +37,7 @@ type Permission = | ||||||
|   | `servers${ |   | `servers${ | ||||||
|       | "" |       | "" | ||||||
|       | `/fetch${"" | "/by-id"}` |       | `/fetch${"" | "/by-id"}` | ||||||
|       | `/update${"" | "/flags" | "/discoverability" | "/owner"}`}` |       | `/update${"" | "/flags" | "/discoverability" | "/owner" | "/add-member"}`}` | ||||||
|   | `users${ |   | `users${ | ||||||
|       | "" |       | "" | ||||||
|       | `/fetch${ |       | `/fetch${ | ||||||
|  | @ -113,6 +113,7 @@ const PermissionSets = { | ||||||
|     "users/update/badges", |     "users/update/badges", | ||||||
| 
 | 
 | ||||||
|     "servers/update/owner", |     "servers/update/owner", | ||||||
|  |     "servers/update/add-member", | ||||||
| 
 | 
 | ||||||
|     "accounts/fetch/by-id", |     "accounts/fetch/by-id", | ||||||
|     "accounts/fetch/by-email", |     "accounts/fetch/by-email", | ||||||
|  |  | ||||||
|  | @ -25,6 +25,7 @@ import { | ||||||
|   User, |   User, | ||||||
| } from "revolt-api"; | } from "revolt-api"; | ||||||
| import { checkPermission } from "./accessPermissions"; | import { checkPermission } from "./accessPermissions"; | ||||||
|  | import { Long } from "mongodb"; | ||||||
| 
 | 
 | ||||||
| export async function sendAlert(userId: string, content: string) { | export async function sendAlert(userId: string, content: string) { | ||||||
|   await checkPermission("users/create/alert", userId, { content }); |   await checkPermission("users/create/alert", userId, { content }); | ||||||
|  | @ -609,6 +610,44 @@ export async function updateServerOwner(serverId: string, userId: string) { | ||||||
|   }); |   }); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | export async function addServerMember(serverId: string, userId: string, withEvent: boolean) { | ||||||
|  |   const server = await mongo() | ||||||
|  |     .db("revolt") | ||||||
|  |     .collection<Server>("servers") | ||||||
|  |     .findOne({ _id: serverId }); | ||||||
|  | 
 | ||||||
|  |   const channels = await mongo() | ||||||
|  |     .db("revolt") | ||||||
|  |     .collection<Channel>("channels") | ||||||
|  |     .find({ server: serverId }) | ||||||
|  |     .toArray(); | ||||||
|  | 
 | ||||||
|  |   if (!server) throw new Error("server doesn't exist"); | ||||||
|  | 
 | ||||||
|  |   await mongo() | ||||||
|  |     .db("revolt") | ||||||
|  |     .collection<Member>("server_members") | ||||||
|  |     .insertOne({ | ||||||
|  |       _id: { server: serverId, user: userId }, | ||||||
|  |       joined_at: Long.fromNumber(Date.now()) as unknown as string, | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |   await publishMessage(userId, { | ||||||
|  |     type: "ServerCreate", | ||||||
|  |     id: serverId, | ||||||
|  |     channels: channels, | ||||||
|  |     server: server, | ||||||
|  |   }); | ||||||
|  | 
 | ||||||
|  |   if (withEvent) { | ||||||
|  |     await publishMessage(serverId, { | ||||||
|  |       type: "ServerMemberJoin", | ||||||
|  |       id: serverId, | ||||||
|  |       user: userId, | ||||||
|  |     }); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| export async function deleteInvite(invite: string) { | export async function deleteInvite(invite: string) { | ||||||
|   await checkPermission("channels/update/invites", invite); |   await checkPermission("channels/update/invites", invite); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue