mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-16 16:30:15 +01:00
* chore: bump vite, vitejs/plugin-react, mark client package as esm, move react-query as a peer dep in data-provider * chore: import changes due to new data-provider export strategy, also fix type imports where applicable * chore: export react-query services as separate to avoid react dependencies in /api/ * chore: suppress sourcemap warnings and polyfill node:path which is used by filenamify TODO: replace filenamify with an alternative and REMOVE polyfill * chore: /api/ changes to support `librechat-data-provider` * refactor: rewrite Dockerfile.multi in light of /api/ changes to support `librechat-data-provider` * chore: remove volume mapping to node_modules directories in default compose file * chore: remove schemas from /api/ as is no longer needed with use of `librechat-data-provider` * fix(ci): jest `librechat-data-provider/react-query` module resolution
60 lines
1.4 KiB
TypeScript
60 lines
1.4 KiB
TypeScript
import { useMemo, useCallback } from 'react';
|
|
import {
|
|
useUserKeyQuery,
|
|
useGetEndpointsQuery,
|
|
useUpdateUserKeysMutation,
|
|
} from 'librechat-data-provider/react-query';
|
|
|
|
const useUserKey = (endpoint: string) => {
|
|
const { data: endpointsConfig } = useGetEndpointsQuery();
|
|
const config = endpointsConfig?.[endpoint];
|
|
|
|
const { azure } = config ?? {};
|
|
let keyEndpoint = endpoint;
|
|
|
|
if (azure) {
|
|
keyEndpoint = 'azureOpenAI';
|
|
} else if (keyEndpoint === 'gptPlugins') {
|
|
keyEndpoint = 'openAI';
|
|
}
|
|
|
|
const updateKey = useUpdateUserKeysMutation();
|
|
const checkUserKey = useUserKeyQuery(keyEndpoint);
|
|
const getExpiry = useCallback(() => {
|
|
if (checkUserKey.data) {
|
|
return checkUserKey.data.expiresAt;
|
|
}
|
|
}, [checkUserKey.data]);
|
|
|
|
const checkExpiry = useCallback(() => {
|
|
const expiresAt = getExpiry();
|
|
if (!expiresAt) {
|
|
return false;
|
|
}
|
|
|
|
const expiresAtDate = new Date(expiresAt);
|
|
if (expiresAtDate < new Date()) {
|
|
return false;
|
|
}
|
|
return true;
|
|
}, [getExpiry]);
|
|
|
|
const saveUserKey = useCallback(
|
|
(value: string, expiresAt: number) => {
|
|
const dateStr = new Date(expiresAt).toISOString();
|
|
updateKey.mutate({
|
|
name: keyEndpoint,
|
|
value,
|
|
expiresAt: dateStr,
|
|
});
|
|
},
|
|
[updateKey, keyEndpoint],
|
|
);
|
|
|
|
return useMemo(
|
|
() => ({ getExpiry, checkExpiry, saveUserKey }),
|
|
[getExpiry, checkExpiry, saveUserKey],
|
|
);
|
|
};
|
|
|
|
export default useUserKey;
|