2023-03-26 06:53:40 +00:00
|
|
|
import { create } from "zustand";
|
|
|
|
import { persist } from "zustand/middleware";
|
2023-04-10 17:21:34 +00:00
|
|
|
import { getClientSideConfig } from "../config/client";
|
2023-03-26 06:53:40 +00:00
|
|
|
|
|
|
|
export interface AccessControlStore {
|
|
|
|
accessCode: string;
|
2023-03-26 11:58:25 +00:00
|
|
|
token: string;
|
2023-03-26 06:53:40 +00:00
|
|
|
|
2023-03-26 11:58:25 +00:00
|
|
|
updateToken: (_: string) => void;
|
2023-03-26 06:53:40 +00:00
|
|
|
updateCode: (_: string) => void;
|
|
|
|
enabledAccessControl: () => boolean;
|
2023-04-09 15:51:12 +00:00
|
|
|
isAuthorized: () => boolean;
|
2023-03-26 06:53:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export const ACCESS_KEY = "access-control";
|
|
|
|
|
|
|
|
export const useAccessStore = create<AccessControlStore>()(
|
|
|
|
persist(
|
|
|
|
(set, get) => ({
|
2023-03-26 11:58:25 +00:00
|
|
|
token: "",
|
2023-03-26 06:53:40 +00:00
|
|
|
accessCode: "",
|
|
|
|
enabledAccessControl() {
|
2023-04-10 17:21:34 +00:00
|
|
|
return !!getClientSideConfig()?.needCode;
|
2023-03-26 06:53:40 +00:00
|
|
|
},
|
|
|
|
updateCode(code: string) {
|
|
|
|
set((state) => ({ accessCode: code }));
|
|
|
|
},
|
2023-03-26 11:58:25 +00:00
|
|
|
updateToken(token: string) {
|
|
|
|
set((state) => ({ token }));
|
|
|
|
},
|
2023-04-09 15:51:12 +00:00
|
|
|
isAuthorized() {
|
2023-04-10 02:57:16 +00:00
|
|
|
// has token or has code or disabled access control
|
2023-04-10 17:21:34 +00:00
|
|
|
return (
|
|
|
|
!!get().token || !!get().accessCode || !get().enabledAccessControl()
|
|
|
|
);
|
2023-04-09 15:51:12 +00:00
|
|
|
},
|
2023-03-26 06:53:40 +00:00
|
|
|
}),
|
|
|
|
{
|
|
|
|
name: ACCESS_KEY,
|
|
|
|
version: 1,
|
2023-04-09 15:51:12 +00:00
|
|
|
},
|
|
|
|
),
|
2023-03-26 06:53:40 +00:00
|
|
|
);
|