import { Button, IconButton } from "@mui/joy"; import axios from "axios"; import copy from "copy-to-clipboard"; import { useEffect, useState } from "react"; import { toast } from "react-hot-toast"; import { ListUserAccessTokensResponse, UserAccessToken } from "@/types/proto/api/v2/user_service_pb"; import useUserStore from "../../stores/v1/user"; import { showCommonDialog } from "../Alert"; import CreateAccessTokenDialog from "../CreateAccessTokenDialog"; import Icon from "../Icon"; const listAccessTokens = async (userId: number) => { const { data } = await axios.get(`/api/v2/users/${userId}/access_tokens`); return data.accessTokens; }; const AccessTokenSection = () => { const currentUser = useUserStore().getCurrentUser(); const [userAccessTokens, setUserAccessTokens] = useState([]); const [showCreateDialog, setShowCreateDialog] = useState(false); useEffect(() => { listAccessTokens(currentUser.id).then((accessTokens) => { setUserAccessTokens(accessTokens); }); }, []); const handleCreateAccessTokenDialogConfirm = async () => { const accessTokens = await listAccessTokens(currentUser.id); setUserAccessTokens(accessTokens); }; const copyAccessToken = (accessToken: string) => { copy(accessToken); toast.success("Access token copied to clipboard"); }; const handleDeleteAccessToken = async (accessToken: string) => { showCommonDialog({ title: "Delete Access Token", content: `Are you sure to delete access token \`${getFormatedAccessToken(accessToken)}\`? You cannot undo this action.`, style: "danger", onConfirm: async () => { await axios.delete(`/api/v2/users/${currentUser.id}/access_tokens/${accessToken}`); setUserAccessTokens(userAccessTokens.filter((token) => token.accessToken !== accessToken)); }, }); }; const getFormatedAccessToken = (accessToken: string) => { return `${accessToken.slice(0, 4)}****${accessToken.slice(-4)}`; }; return ( <>

Access Tokens

A list of all access tokens for your account.

{userAccessTokens.map((userAccessToken) => ( ))}
Token Description Created At Expires At Delete
{getFormatedAccessToken(userAccessToken.accessToken)} {userAccessToken.description} {String(userAccessToken.issuedAt)} {String(userAccessToken.expiresAt ?? "Never")} { handleDeleteAccessToken(userAccessToken.accessToken); }} >
{showCreateDialog && ( setShowCreateDialog(false)} onConfirm={handleCreateAccessTokenDialogConfirm} /> )} ); }; export default AccessTokenSection;