Files
colanode/packages/client/src/handlers/queries/files/file-url-get.ts
Hakan Shehu 30e15e4bd3 Web version (#43)
* Create client package
* Create the UI package
* Init web app
* Use isomorphic 'ws' for web sockets
* File and asset implementations
* Use Opfs SAH version of sqlite in browser
* Generate Svg sprites for emojis and icons
* Include emojis sprite
* Improve and refactor assets
* More assets improvements
* Implement emoji and icons db import as readonly
* Improve import paths
* Handle concurrency limits for sqlite
* Fix event broadcast in web
* Pass windowId for subscribe and unsubscribe queries in desktop
* Remove asset context
* Implement avatar upload/download with the new structure
* Improve file handlings
* Move the necessary dependencies to client and ui packages
* Update packages
* Improve open file dialog
* Make sure database files are deleted in browser
* Improve avatar loading
* Improve file loading
* Fix some assets
* Implement asset caching for offline access
* Small fixes and improvements
* Use server instead of pre signed urls for file upload/download
* Cleanup some client related metadata
* Switch Axios with ky
* Refactor mutation results
* Minor concurrency fix
* Refactor web sockets
* Improve file uploading
* Handle connection close on server
* Use stream for downloading the file
* Add config options for cors
* Update document in all tabs on local change
* Include necessary icons for web
* Update docker compose
* Implement server upgrade required component
* Use correct client type and platform in web and desktop
* Improve service worker
* Improve versioning
* Fix an import
* Minor fixes
* Update some user endpoints
* Minor endpoint changes
* Enable app badge for desktop
* Add error handling in some database operations
* Update mutation naming convention
* Update query naming convention
* Update event and some metadata naming conventions
* Update event and job naming conventions in server
* Update Github workflow files
* Restructure assets directory
* Update packages
* Upgrade to Zod v4
* Upgrade to react 19
* Upgrade to tailwind v4
* Minor ui improvements
* Fix some cursor pointers
* Add browser not supported message in web
* Enhance server create flow, allow insecure connections and custom api paths
* Execute electron-rebuild as postinstall command
* Update docker compose
2025-06-11 00:14:17 +02:00

110 lines
2.5 KiB
TypeScript

import { ChangeCheckResult, QueryHandler } from '@colanode/client/lib/types';
import {
FileUrlGetQueryInput,
FileUrlGetQueryOutput,
} from '@colanode/client/queries/files/file-url-get';
import { AppService } from '@colanode/client/services';
import { Event } from '@colanode/client/types/events';
export class FileUrlGetQueryHandler
implements QueryHandler<FileUrlGetQueryInput>
{
private readonly app: AppService;
constructor(app: AppService) {
this.app = app;
}
public async handleQuery(
input: FileUrlGetQueryInput
): Promise<FileUrlGetQueryOutput> {
return await this.buildFileUrl(input);
}
public async checkForChanges(
event: Event,
input: FileUrlGetQueryInput,
_: FileUrlGetQueryOutput
): Promise<ChangeCheckResult<FileUrlGetQueryInput>> {
if (
event.type === 'workspace.deleted' &&
event.workspace.accountId === input.accountId &&
event.workspace.id === input.workspaceId
) {
return {
hasChanges: true,
result: {
url: null,
},
};
}
if (
event.type === 'file.state.updated' &&
event.accountId === input.accountId &&
event.workspaceId === input.workspaceId &&
event.fileState.id === input.id
) {
const output = await this.handleQuery(input);
return {
hasChanges: true,
result: output,
};
}
if (
event.type === 'node.deleted' &&
event.accountId === input.accountId &&
event.workspaceId === input.workspaceId &&
event.node.id === input.id
) {
return {
hasChanges: true,
result: {
url: null,
},
};
}
if (
event.type === 'node.created' &&
event.accountId === input.accountId &&
event.workspaceId === input.workspaceId &&
event.node.id === input.id
) {
const newOutput = await this.handleQuery(input);
return {
hasChanges: true,
result: newOutput,
};
}
return {
hasChanges: false,
};
}
private async buildFileUrl(
input: FileUrlGetQueryInput
): Promise<FileUrlGetQueryOutput> {
const filePath = this.app.path.workspaceFile(
input.accountId,
input.workspaceId,
input.id,
input.extension
);
const exists = await this.app.fs.exists(filePath);
if (!exists) {
return {
url: null,
};
}
const url = await this.app.fs.url(filePath);
return {
url,
};
}
}