mirror of
https://github.com/khairul169/garage-webui.git
synced 2025-06-17 22:29:32 +07:00
104 lines
2.9 KiB
TypeScript
104 lines
2.9 KiB
TypeScript
|
import { useParams } from "react-router-dom";
|
||
|
import { useBucket, useDenyKey } from "../hooks";
|
||
|
import { Card, Checkbox, Table } from "react-daisyui";
|
||
|
import Button from "@/components/ui/button";
|
||
|
import { Trash } from "lucide-react";
|
||
|
import AllowKeyDialog from "./allow-key-dialog";
|
||
|
import { useMemo } from "react";
|
||
|
import { toast } from "sonner";
|
||
|
import { handleError } from "@/lib/utils";
|
||
|
|
||
|
const PermissionsTab = () => {
|
||
|
const { id } = useParams();
|
||
|
const { data, refetch } = useBucket(id);
|
||
|
|
||
|
const denyKey = useDenyKey(id, {
|
||
|
onSuccess: () => {
|
||
|
toast.success("Key removed!");
|
||
|
refetch();
|
||
|
},
|
||
|
onError: handleError,
|
||
|
});
|
||
|
|
||
|
const keys = useMemo(() => {
|
||
|
return data?.keys.filter(
|
||
|
(key) =>
|
||
|
key.permissions.read !== false ||
|
||
|
key.permissions.write !== false ||
|
||
|
key.permissions.owner !== false
|
||
|
);
|
||
|
}, [data?.keys]);
|
||
|
|
||
|
const onRemove = (id: string) => {
|
||
|
if (window.confirm("Are you sure you want to remove this key?")) {
|
||
|
denyKey.mutate({
|
||
|
keyId: id,
|
||
|
permissions: { read: true, write: true, owner: true },
|
||
|
});
|
||
|
}
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
<div>
|
||
|
<Card className="card-body">
|
||
|
<div className="flex flex-row items-center gap-2">
|
||
|
<Card.Title className="flex-1 truncate">Access Keys</Card.Title>
|
||
|
<AllowKeyDialog
|
||
|
id={id}
|
||
|
currentKeys={keys?.map((key) => key.accessKeyId)}
|
||
|
/>
|
||
|
</div>
|
||
|
|
||
|
<div className="overflow-x-auto">
|
||
|
<Table zebra size="sm">
|
||
|
<Table.Head>
|
||
|
<span>#</span>
|
||
|
<span>Key</span>
|
||
|
<span>Read</span>
|
||
|
<span>Write</span>
|
||
|
<span>Owner</span>
|
||
|
<span />
|
||
|
</Table.Head>
|
||
|
|
||
|
<Table.Body>
|
||
|
{keys?.map((key, idx) => (
|
||
|
<Table.Row>
|
||
|
<span>{idx + 1}</span>
|
||
|
<span>{key.name || key.accessKeyId?.substring(0, 8)}</span>
|
||
|
<span>
|
||
|
<Checkbox
|
||
|
checked={key.permissions?.read}
|
||
|
color="primary"
|
||
|
className="cursor-default"
|
||
|
/>
|
||
|
</span>
|
||
|
<span>
|
||
|
<Checkbox
|
||
|
checked={key.permissions?.write}
|
||
|
color="primary"
|
||
|
className="cursor-default"
|
||
|
/>
|
||
|
</span>
|
||
|
<span>
|
||
|
<Checkbox
|
||
|
checked={key.permissions?.owner}
|
||
|
color="primary"
|
||
|
className="cursor-default"
|
||
|
/>
|
||
|
</span>
|
||
|
<Button
|
||
|
icon={Trash}
|
||
|
onClick={() => onRemove(key.accessKeyId)}
|
||
|
/>
|
||
|
</Table.Row>
|
||
|
))}
|
||
|
</Table.Body>
|
||
|
</Table>
|
||
|
</div>
|
||
|
</Card>
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default PermissionsTab;
|