Proxy all endpoints

This commit is contained in:
Andras Schmelczer 2024-12-10 20:31:42 +00:00
parent 161d2c7ee4
commit 66fbdbf368
No known key found for this signature in database
GPG key ID: FC8F2C3D3D1A718C
2 changed files with 208 additions and 16 deletions

View file

@ -0,0 +1,192 @@
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";
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));
}
private createClient(settings: SyncSettings) {
this.client = createClient<paths>({
baseUrl: settings.remoteUri,
});
}
public async create({
relativePath,
content,
createdDate,
}: {
content: ArrayBuffer;
relativePath: string;
createdDate: Date;
}): Promise<
components["schemas"]["DocumentVersionWithoutContent"] | undefined
> {
let contentBytes = new Uint8Array(content);
let response = await this.client.POST("/vaults/{vault_id}/documents", {
params: {
path: { vaultId: SyncServer.VAULT_ID },
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
},
},
body: {
contentBase64: plugin.bytes_to_base64(contentBytes),
createdDate: createdDate.toISOString(),
isBinary: plugin.is_binary(contentBytes),
relativePath,
},
});
Logger.getInstance().info(
"Created document " + JSON.stringify(response.data)
);
return response.data;
}
public async update({
documentId,
parentVersionId,
relativePath,
content,
createdDate,
}: {
documentId: DocumentId;
parentVersionId: DocumentVersionId;
relativePath: string;
content: ArrayBuffer;
createdDate: Date;
}): Promise<
components["schemas"]["DocumentVersionWithoutContent"] | undefined
> {
let contentBytes = new Uint8Array(content);
let response = await this.client.PUT(
"/vaults/{vault_id}/documents/{document_id}",
{
params: {
path: {
vaultId: SyncServer.VAULT_ID,
documentId,
},
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
},
},
body: {
parentVersionId,
contentBase64: plugin.bytes_to_base64(contentBytes),
createdDate: createdDate.toISOString(),
isBinary: plugin.is_binary(contentBytes),
relativePath,
},
}
);
Logger.getInstance().info(
"Updated document " + JSON.stringify(response.data)
);
return response.data;
}
public async delete({
documentId,
createdDate,
}: {
documentId: DocumentId;
createdDate: Date;
}): Promise<void> {
const response = await this.client.DELETE(
"/vaults/{vault_id}/documents/{document_id}",
{
params: {
path: {
vaultId: SyncServer.VAULT_ID,
documentId,
},
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
},
},
body: {
createdDate: createdDate.toISOString(),
},
}
);
Logger.getInstance().info(
"Updated document " + JSON.stringify(response.data)
);
return response.data;
}
public async get({
documentId,
}: {
documentId: DocumentId;
}): Promise<components["schemas"]["DocumentVersion"] | undefined> {
const response = await this.client.GET(
"/vaults/{vault_id}/documents/{document_id}",
{
params: {
path: {
vaultId: SyncServer.VAULT_ID,
documentId,
},
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
},
},
}
);
Logger.getInstance().info(
"Get document " + JSON.stringify(response.data)
);
return response.data;
}
public async getAll(): Promise<
components["schemas"]["DocumentVersionWithoutContent"][] | undefined
> {
const response = await this.client.GET("/vaults/{vault_id}/documents", {
params: {
path: {
vaultId: SyncServer.VAULT_ID,
},
header: {
authorization:
"Bearer " + this.settings.getSettings().token,
},
},
});
Logger.getInstance().info(
"Get document " + JSON.stringify(response.data)
);
return response.data;
}
}

View file

@ -0,0 +1,282 @@
/**
* This file was auto-generated by openapi-typescript.
* Do not make direct changes to the file.
*/
export interface paths {
"/vaults/{vault_id}/documents": {
parameters: {
query?: never;
header?: never;
path?: never;
cookie?: never;
};
get: {
parameters: {
query?: never;
header: {
authorization: string;
};
path: {
vaultId: string;
};
cookie?: never;
};
requestBody?: never;
responses: {
200: {
headers: {
[name: string]: unknown;
};
content: {
"application/json": components["schemas"]["DocumentVersionWithoutContent"][];
};
};
};
};
put?: never;
post: {
parameters: {
query?: never;
header: {
authorization: string;
};
path: {
vaultId: string;
};
cookie?: never;
};
requestBody: {
content: {
"application/json": components["schemas"]["CreateDocumentVersion"];
};
};
responses: {
200: {
headers: {
[name: string]: unknown;
};
content: {
"application/json": components["schemas"]["DocumentVersionWithoutContent"];
};
};
};
};
delete?: never;
options?: never;
head?: never;
patch?: never;
trace?: never;
};
"/vaults/{vault_id}/documents/{document_id}": {
parameters: {
query?: never;
header?: never;
path?: never;
cookie?: never;
};
get: {
parameters: {
query?: never;
header: {
authorization: string;
};
path: {
documentId: string;
vaultId: string;
};
cookie?: never;
};
requestBody?: never;
responses: {
200: {
headers: {
[name: string]: unknown;
};
content: {
"application/json": components["schemas"]["DocumentVersion"];
};
};
};
};
put: {
parameters: {
query?: never;
header: {
authorization: string;
};
path: {
documentId: string;
vaultId: string;
};
cookie?: never;
};
requestBody: {
content: {
"application/json": components["schemas"]["UpdateDocumentVersion"];
};
};
responses: {
200: {
headers: {
[name: string]: unknown;
};
content: {
"application/json": components["schemas"]["DocumentVersionWithoutContent"];
};
};
};
};
post?: never;
delete: {
parameters: {
query?: never;
header: {
authorization: string;
};
path: {
documentId: string;
vaultId: string;
};
cookie?: never;
};
requestBody: {
content: {
"application/json": components["schemas"]["DeleteDocumentVersion"];
};
};
responses: {
/** @description no content */
200: {
headers: {
[name: string]: unknown;
};
content?: never;
};
};
};
options?: never;
head?: never;
patch?: never;
trace?: never;
};
"/ws": {
parameters: {
query?: never;
header?: never;
path?: never;
cookie?: never;
};
get: {
parameters: {
query?: never;
header?: never;
path?: never;
cookie?: never;
};
requestBody?: never;
responses: {
/** @description websocket upgrade */
101: {
headers: {
connection?: "upgrade";
upgrade?: "websocket";
"sec-websocket-key"?: string;
"sec-websocket-protocol"?: string;
[name: string]: unknown;
};
content?: never;
};
};
};
put?: never;
post?: never;
delete?: never;
options?: never;
head?: never;
patch?: never;
trace?: never;
};
}
export type webhooks = Record<string, never>;
export interface components {
schemas: {
CreateDocumentVersion: {
contentBase64: string;
/** Format: date-time */
createdDate: string;
isBinary: boolean;
relativePath: string;
};
DeleteDocumentVersion: {
/** Format: date-time */
createdDate: string;
};
DocumentVersion: {
contentBase64: string;
/** Format: date-time */
createdDate: string;
/** Format: uuid */
documentId: string;
isBinary: boolean;
isDeleted: boolean;
relativePath: string;
/** Format: date-time */
updatedDate: string;
vaultId: string;
/** Format: int64 */
versionId: number;
};
DocumentVersionWithoutContent: {
/** Format: date-time */
createdDate: string;
/** Format: uuid */
documentId: string;
isBinary: boolean;
isDeleted: boolean;
relativePath: string;
/** Format: date-time */
updatedDate: string;
vaultId: string;
/** Format: int64 */
versionId: number;
};
PathParams: {
vaultId: string;
};
PathParams2: {
vaultId: string;
};
PathParams3: {
/** Format: uuid */
documentId: string;
vaultId: string;
};
PathParams4: {
/** Format: uuid */
documentId: string;
vaultId: string;
};
PathParams5: {
/** Format: uuid */
documentId: string;
vaultId: string;
};
UpdateDocumentVersion: {
contentBase64: string;
/** Format: date-time */
createdDate: string;
isBinary: boolean;
/** Format: int64 */
parentVersionId: number;
relativePath: string;
};
};
responses: never;
parameters: never;
requestBodies: never;
headers: never;
pathItems: never;
}
export type $defs = Record<string, never>;
export type operations = Record<string, never>;