Handle file events

This commit is contained in:
Andras Schmelczer 2024-12-10 21:37:45 +00:00
parent b57a0ac0d4
commit 6173320f81
No known key found for this signature in database
GPG key ID: FC8F2C3D3D1A718C
2 changed files with 151 additions and 41 deletions

View file

@ -1,22 +1,22 @@
import {
SettingsContainer,
SyncSettings,
} from "src/database/settings/settings.js";
import * as plugin from "../../../backend/sync_lib/pkg/sync_lib.js";
import createClient, { Client } from "openapi-fetch";
import type { components, paths } from "./types.js"; // generated by openapi-typescript
import { Logger } from "src/logger.js";
import { DocumentId, DocumentVersionId } from "src/database/database.js";
import {
Database,
DocumentId,
DocumentVersionId,
SyncSettings,
} from "src/database/database.js";
export class SyncServer {
private static VAULT_ID = "default";
private client: Client<paths>;
public constructor(private settings: SettingsContainer) {
this.createClient(settings.getSettings());
settings.onChange((s) => this.createClient(s));
public constructor(private database: Database) {
this.createClient(database.getSettings());
database.addOnSettingsChangeHandlers((s) => this.createClient(s));
}
private createClient(settings: SyncSettings) {
@ -25,6 +25,20 @@ export class SyncServer {
});
}
public async ping(): Promise<components["schemas"]["PingResponse"]> {
const response = await this.client.GET("/ping");
Logger.getInstance().info(
"Ping response: " + JSON.stringify(response.data)
);
if (!response.data) {
throw new Error(`Failed to ping server: ${response.error}`);
}
return response.data;
}
public async create({
relativePath,
content,
@ -33,16 +47,14 @@ export class SyncServer {
content: ArrayBuffer;
relativePath: string;
createdDate: Date;
}): Promise<
components["schemas"]["DocumentVersionWithoutContent"] | undefined
> {
}): Promise<components["schemas"]["DocumentVersionWithoutContent"]> {
let contentBytes = new Uint8Array(content);
let response = await this.client.POST("/vaults/{vault_id}/documents", {
params: {
path: { vaultId: SyncServer.VAULT_ID },
path: { vault_id: SyncServer.VAULT_ID },
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
"Bearer " + this.database.getSettings().token,
},
},
body: {
@ -53,6 +65,10 @@ export class SyncServer {
},
});
if (!response.data) {
throw new Error(`Failed to create document: ${response.error}`);
}
Logger.getInstance().info(
"Created document " + JSON.stringify(response.data)
);
@ -72,9 +88,7 @@ export class SyncServer {
relativePath: string;
content: ArrayBuffer;
createdDate: Date;
}): Promise<
components["schemas"]["DocumentVersionWithoutContent"] | undefined
> {
}): Promise<components["schemas"]["DocumentVersionWithoutContent"]> {
let contentBytes = new Uint8Array(content);
let response = await this.client.PUT(
@ -82,12 +96,12 @@ export class SyncServer {
{
params: {
path: {
vaultId: SyncServer.VAULT_ID,
documentId,
vault_id: SyncServer.VAULT_ID,
document_id: documentId,
},
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
"Bearer " + this.database.getSettings().token,
},
},
body: {
@ -100,6 +114,10 @@ export class SyncServer {
}
);
if (!response.data) {
throw new Error(`Failed to create document: ${response.error}`);
}
Logger.getInstance().info(
"Updated document " + JSON.stringify(response.data)
);
@ -119,12 +137,12 @@ export class SyncServer {
{
params: {
path: {
vaultId: SyncServer.VAULT_ID,
documentId,
vault_id: SyncServer.VAULT_ID,
document_id: documentId,
},
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
"Bearer " + this.database.getSettings().token,
},
},
body: {
@ -133,6 +151,11 @@ export class SyncServer {
}
);
// Response will be empty if successful
// if (!response.data) {
// throw new Error(`Failed to delete document: ${response.error}`);
// }
Logger.getInstance().info(
"Updated document " + JSON.stringify(response.data)
);
@ -144,23 +167,27 @@ export class SyncServer {
documentId,
}: {
documentId: DocumentId;
}): Promise<components["schemas"]["DocumentVersion"] | undefined> {
}): Promise<components["schemas"]["DocumentVersion"]> {
const response = await this.client.GET(
"/vaults/{vault_id}/documents/{document_id}",
{
params: {
path: {
vaultId: SyncServer.VAULT_ID,
documentId,
vault_id: SyncServer.VAULT_ID,
document_id: documentId,
},
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
"Bearer " + this.database.getSettings().token,
},
},
}
);
if (!response.data) {
throw new Error(`Failed to get document: ${response.error}`);
}
Logger.getInstance().info(
"Get document " + JSON.stringify(response.data)
);
@ -169,20 +196,24 @@ export class SyncServer {
}
public async getAll(): Promise<
components["schemas"]["DocumentVersionWithoutContent"][] | undefined
components["schemas"]["DocumentVersionWithoutContent"][]
> {
const response = await this.client.GET("/vaults/{vault_id}/documents", {
params: {
path: {
vaultId: SyncServer.VAULT_ID,
vault_id: SyncServer.VAULT_ID,
},
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
"Bearer " + this.database.getSettings().token,
},
},
});
if (!response.data) {
throw new Error(`Failed to get documents: ${response.error}`);
}
Logger.getInstance().info(
"Get document " + JSON.stringify(response.data)
);