Proxy all endpoints
This commit is contained in:
parent
161d2c7ee4
commit
66fbdbf368
2 changed files with 208 additions and 16 deletions
192
plugin/src/services/sync_service.ts
Normal file
192
plugin/src/services/sync_service.ts
Normal 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;
|
||||
}
|
||||
}
|
||||
282
plugin/src/services/types.ts
Normal file
282
plugin/src/services/types.ts
Normal 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>;
|
||||
Loading…
Add table
Add a link
Reference in a new issue