ChatGPT-Next-Web/app/store/access.ts

94 lines
2.3 KiB
TypeScript
Raw Normal View History

import { create } from "zustand";
import { persist } from "zustand/middleware";
2023-04-26 18:00:22 +00:00
import { StoreKey } from "../constant";
import { getHeaders } from "../client/api";
2023-05-03 15:08:37 +00:00
import { BOT_HELLO } from "./chat";
import { ALL_MODELS } from "./config";
export interface AccessControlStore {
accessCode: string;
2023-03-26 11:58:25 +00:00
token: string;
2023-04-10 18:54:31 +00:00
needCode: boolean;
hideUserApiKey: boolean;
openaiUrl: string;
2023-04-10 18:54:31 +00:00
2023-03-26 11:58:25 +00:00
updateToken: (_: string) => void;
updateCode: (_: string) => void;
enabledAccessControl: () => boolean;
2023-04-09 15:51:12 +00:00
isAuthorized: () => boolean;
2023-04-10 18:54:31 +00:00
fetch: () => void;
}
2023-04-10 18:54:31 +00:00
let fetchState = 0; // 0 not fetch, 1 fetching, 2 done
export const useAccessStore = create<AccessControlStore>()(
persist(
(set, get) => ({
2023-03-26 11:58:25 +00:00
token: "",
accessCode: "",
2023-04-10 18:54:31 +00:00
needCode: true,
hideUserApiKey: false,
openaiUrl: "/api/openai/",
enabledAccessControl() {
2023-04-10 18:54:31 +00:00
get().fetch();
return get().needCode;
},
updateCode(code: string) {
set(() => ({ accessCode: code }));
},
2023-03-26 11:58:25 +00:00
updateToken(token: string) {
set(() => ({ token }));
2023-03-26 11:58:25 +00:00
},
2023-04-09 15:51:12 +00:00
isAuthorized() {
2023-05-05 14:49:41 +00:00
get().fetch();
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-04-10 18:54:31 +00:00
fetch() {
if (fetchState > 0) return;
fetchState = 1;
fetch("/api/config", {
method: "post",
body: null,
2023-05-11 15:21:16 +00:00
headers: {
...getHeaders(),
},
2023-04-10 18:54:31 +00:00
})
.then((res) => res.json())
.then((res: DangerConfig) => {
console.log("[Config] got config from server", res);
set(() => ({ ...res }));
if (!res.enableGPT4) {
ALL_MODELS.forEach((model) => {
if (model.name.startsWith("gpt-4")) {
(model as any).available = false;
}
});
}
if ((res as any).botHello) {
BOT_HELLO.content = (res as any).botHello;
}
2023-04-10 18:54:31 +00:00
})
.catch(() => {
console.error("[Config] failed to fetch config");
})
.finally(() => {
fetchState = 2;
});
},
}),
{
2023-04-26 18:00:22 +00:00
name: StoreKey.Access,
version: 1,
2023-04-09 15:51:12 +00:00
},
),
);