mirror of
https://github.com/AutoMaker-Org/automaker.git
synced 2026-03-23 12:03:07 +00:00
Changes from fix/event-hook-endpoint
This commit is contained in:
@@ -2763,6 +2763,21 @@ export class HttpApiClient implements ElectronAPI {
|
|||||||
headers?: Record<string, string>;
|
headers?: Record<string, string>;
|
||||||
enabled?: boolean;
|
enabled?: boolean;
|
||||||
}>;
|
}>;
|
||||||
|
eventHooks?: Array<{
|
||||||
|
id: string;
|
||||||
|
trigger: string;
|
||||||
|
enabled: boolean;
|
||||||
|
action: Record<string, unknown>;
|
||||||
|
name?: string;
|
||||||
|
}>;
|
||||||
|
ntfyEndpoints?: Array<{
|
||||||
|
id: string;
|
||||||
|
name: string;
|
||||||
|
serverUrl: string;
|
||||||
|
topic: string;
|
||||||
|
authType: string;
|
||||||
|
enabled: boolean;
|
||||||
|
}>;
|
||||||
};
|
};
|
||||||
error?: string;
|
error?: string;
|
||||||
}> => this.get('/api/settings/global'),
|
}> => this.get('/api/settings/global'),
|
||||||
|
|||||||
@@ -613,7 +613,10 @@ function RootLayoutContent() {
|
|||||||
// Reconcile ntfy endpoints from server (same rationale as eventHooks)
|
// Reconcile ntfy endpoints from server (same rationale as eventHooks)
|
||||||
const serverEndpoints = (finalSettings as GlobalSettings).ntfyEndpoints ?? [];
|
const serverEndpoints = (finalSettings as GlobalSettings).ntfyEndpoints ?? [];
|
||||||
const currentEndpoints = useAppStore.getState().ntfyEndpoints;
|
const currentEndpoints = useAppStore.getState().ntfyEndpoints;
|
||||||
if (JSON.stringify(serverEndpoints) !== JSON.stringify(currentEndpoints)) {
|
if (
|
||||||
|
JSON.stringify(serverEndpoints) !== JSON.stringify(currentEndpoints) &&
|
||||||
|
serverEndpoints.length > 0
|
||||||
|
) {
|
||||||
logger.info(
|
logger.info(
|
||||||
`[FAST_HYDRATE] Reconciling ntfyEndpoints from server (server=${serverEndpoints.length}, store=${currentEndpoints.length})`
|
`[FAST_HYDRATE] Reconciling ntfyEndpoints from server (server=${serverEndpoints.length}, store=${currentEndpoints.length})`
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1506,7 +1506,11 @@ export const useAppStore = create<AppState & AppActions>()((set, get) => ({
|
|||||||
set({ eventHooks: hooks });
|
set({ eventHooks: hooks });
|
||||||
try {
|
try {
|
||||||
const httpApi = getHttpApiClient();
|
const httpApi = getHttpApiClient();
|
||||||
await httpApi.settings.updateGlobal({ eventHooks: hooks });
|
await httpApi.settings.updateGlobal({
|
||||||
|
eventHooks: hooks,
|
||||||
|
// Signal the server that an empty array is intentional (not a wipe from stale state)
|
||||||
|
...(hooks.length === 0 ? { __allowEmptyEventHooks: true } : {}),
|
||||||
|
});
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
logger.error('Failed to sync event hooks:', error);
|
logger.error('Failed to sync event hooks:', error);
|
||||||
}
|
}
|
||||||
@@ -1517,7 +1521,11 @@ export const useAppStore = create<AppState & AppActions>()((set, get) => ({
|
|||||||
set({ ntfyEndpoints: endpoints });
|
set({ ntfyEndpoints: endpoints });
|
||||||
try {
|
try {
|
||||||
const httpApi = getHttpApiClient();
|
const httpApi = getHttpApiClient();
|
||||||
await httpApi.settings.updateGlobal({ ntfyEndpoints: endpoints });
|
await httpApi.settings.updateGlobal({
|
||||||
|
ntfyEndpoints: endpoints,
|
||||||
|
// Signal the server that an empty array is intentional (not a wipe from stale state)
|
||||||
|
...(endpoints.length === 0 ? { __allowEmptyNtfyEndpoints: true } : {}),
|
||||||
|
});
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
logger.error('Failed to sync ntfy endpoints:', error);
|
logger.error('Failed to sync ntfy endpoints:', error);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user