mirror of
https://github.com/antebudimir/feishin.git
synced 2025-12-31 18:13:31 +00:00
* initial implementation for password saving * support restoring password in interceptor * Fix modal overflow and position styles * warn about 429, better error handling --------- Co-authored-by: jeffvli <jeffvictorli@gmail.com> Co-authored-by: Jeff <42182408+jeffvli@users.noreply.github.com>
40 lines
1.2 KiB
TypeScript
40 lines
1.2 KiB
TypeScript
import { AxiosHeaders } from 'axios';
|
|
import { z } from 'zod';
|
|
import { toast } from '/@/renderer/components';
|
|
import { useAuthStore } from '/@/renderer/store';
|
|
import { ServerListItem } from '/@/renderer/types';
|
|
|
|
// Since ts-rest client returns a strict response type, we need to add the headers to the body object
|
|
export const resultWithHeaders = <ItemType extends z.ZodTypeAny>(itemSchema: ItemType) => {
|
|
return z.object({
|
|
data: itemSchema,
|
|
headers: z.instanceof(AxiosHeaders),
|
|
});
|
|
};
|
|
|
|
export const resultSubsonicBaseResponse = <ItemType extends z.ZodRawShape>(
|
|
itemSchema: ItemType,
|
|
) => {
|
|
return z.object({
|
|
'subsonic-response': z
|
|
.object({
|
|
status: z.string(),
|
|
version: z.string(),
|
|
})
|
|
.extend(itemSchema),
|
|
});
|
|
};
|
|
|
|
export const authenticationFailure = (currentServer: ServerListItem | null) => {
|
|
toast.error({
|
|
message: 'Your session has expired.',
|
|
});
|
|
|
|
if (currentServer) {
|
|
const serverId = currentServer.id;
|
|
const token = currentServer.ndCredential;
|
|
console.log(`token is expired: ${token}`);
|
|
useAuthStore.getState().actions.updateServer(serverId, { ndCredential: undefined });
|
|
useAuthStore.getState().actions.setCurrentServer(null);
|
|
}
|
|
};
|