mirror of
https://github.com/immich-app/immich.git
synced 2025-05-31 20:26:27 -04:00
* implement method to read config file * getConfig returns config file if present * return isConfigFile for http requests * disable elements if config file is used, show message if config file is set, copy existing config to clipboard * fix allowing partial configuration files * add new env variable to docs * fix tests * minor refactoring, address review * adapt config type in frontend * remove unnecessary imports * move config file reading to system-config repo * add documentation * fix code formatting in system settings page * add validator for config file * fix formatting in docs * update generated files * throw error when trying to update config. e.g. via cli or api * switch to feature flags for isConfigFile * refactoring * refactor: config file * chore: open api * feat: always show copy/export buttons * fix: default flags * refactor: copy to clipboard --------- Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
50 lines
1.7 KiB
TypeScript
50 lines
1.7 KiB
TypeScript
import type { AxiosError, AxiosPromise } from 'axios';
|
|
import {
|
|
notificationController,
|
|
NotificationType,
|
|
} from '../lib/components/shared-components/notification/notification';
|
|
import { handleError } from '../lib/utils/handle-error';
|
|
import { api } from './api';
|
|
import type { UserResponseDto } from './open-api';
|
|
|
|
export type ApiError = AxiosError<{ message: string }>;
|
|
|
|
export const copyToClipboard = async (secret: string) => {
|
|
try {
|
|
await navigator.clipboard.writeText(secret);
|
|
notificationController.show({ message: 'Copied to clipboard!', type: NotificationType.Info });
|
|
} catch (error) {
|
|
handleError(error, 'Cannot copy to clipboard, make sure you are accessing the page through https');
|
|
}
|
|
};
|
|
|
|
export const oauth = {
|
|
isCallback: (location: Location) => {
|
|
const search = location.search;
|
|
return search.includes('code=') || search.includes('error=');
|
|
},
|
|
isAutoLaunchDisabled: (location: Location) => {
|
|
const values = ['autoLaunch=0', 'password=1', 'password=true'];
|
|
for (const value of values) {
|
|
if (location.search.includes(value)) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
},
|
|
getConfig: (location: Location) => {
|
|
const redirectUri = location.href.split('?')[0];
|
|
console.log(`OAuth Redirect URI: ${redirectUri}`);
|
|
return api.oauthApi.generateConfig({ oAuthConfigDto: { redirectUri } });
|
|
},
|
|
login: (location: Location) => {
|
|
return api.oauthApi.callback({ oAuthCallbackDto: { url: location.href } });
|
|
},
|
|
link: (location: Location): AxiosPromise<UserResponseDto> => {
|
|
return api.oauthApi.link({ oAuthCallbackDto: { url: location.href } });
|
|
},
|
|
unlink: () => {
|
|
return api.oauthApi.unlink();
|
|
},
|
|
};
|