2025-02-21 04:37:57 +00:00
|
|
|
import { sql } from 'kysely';
|
2025-03-07 16:03:34 -05:00
|
|
|
import { AssetStatus, AssetType, Permission } from 'src/enum';
|
2025-02-12 15:23:08 -05:00
|
|
|
|
|
|
|
export type AuthUser = {
|
|
|
|
id: string;
|
|
|
|
isAdmin: boolean;
|
|
|
|
name: string;
|
|
|
|
email: string;
|
|
|
|
quotaUsageInBytes: number;
|
|
|
|
quotaSizeInBytes: number | null;
|
|
|
|
};
|
|
|
|
|
2025-03-08 13:44:36 -05:00
|
|
|
export type Library = {
|
|
|
|
id: string;
|
|
|
|
ownerId: string;
|
|
|
|
createdAt: Date;
|
|
|
|
updatedAt: Date;
|
|
|
|
updateId: string;
|
|
|
|
name: string;
|
|
|
|
importPaths: string[];
|
|
|
|
exclusionPatterns: string[];
|
|
|
|
deletedAt: Date | null;
|
|
|
|
refreshedAt: Date | null;
|
|
|
|
assets?: Asset[];
|
|
|
|
};
|
|
|
|
|
2025-02-12 15:23:08 -05:00
|
|
|
export type AuthApiKey = {
|
|
|
|
id: string;
|
|
|
|
permissions: Permission[];
|
|
|
|
};
|
|
|
|
|
2025-03-10 12:04:35 -04:00
|
|
|
export type ApiKey = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
userId: string;
|
|
|
|
createdAt: Date;
|
|
|
|
updatedAt: Date;
|
|
|
|
permissions: Permission[];
|
|
|
|
};
|
|
|
|
|
2025-03-07 15:20:04 -05:00
|
|
|
export type User = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
email: string;
|
|
|
|
profileImagePath: string;
|
|
|
|
profileChangedAt: Date;
|
|
|
|
};
|
|
|
|
|
2025-03-07 16:03:34 -05:00
|
|
|
export type Asset = {
|
|
|
|
createdAt: Date;
|
|
|
|
updatedAt: Date;
|
|
|
|
deletedAt: Date | null;
|
|
|
|
id: string;
|
|
|
|
updateId: string;
|
|
|
|
status: AssetStatus;
|
|
|
|
checksum: Buffer<ArrayBufferLike>;
|
|
|
|
deviceAssetId: string;
|
|
|
|
deviceId: string;
|
|
|
|
duplicateId: string | null;
|
|
|
|
duration: string | null;
|
|
|
|
encodedVideoPath: string | null;
|
|
|
|
fileCreatedAt: Date | null;
|
|
|
|
fileModifiedAt: Date | null;
|
|
|
|
isArchived: boolean;
|
|
|
|
isExternal: boolean;
|
|
|
|
isFavorite: boolean;
|
|
|
|
isOffline: boolean;
|
|
|
|
isVisible: boolean;
|
|
|
|
libraryId: string | null;
|
|
|
|
livePhotoVideoId: string | null;
|
|
|
|
localDateTime: Date | null;
|
|
|
|
originalFileName: string;
|
|
|
|
originalPath: string;
|
|
|
|
ownerId: string;
|
|
|
|
sidecarPath: string | null;
|
|
|
|
stackId: string | null;
|
|
|
|
thumbhash: Buffer<ArrayBufferLike> | null;
|
|
|
|
type: AssetType;
|
|
|
|
};
|
|
|
|
|
2025-02-12 15:23:08 -05:00
|
|
|
export type AuthSharedLink = {
|
|
|
|
id: string;
|
|
|
|
expiresAt: Date | null;
|
|
|
|
userId: string;
|
|
|
|
showExif: boolean;
|
|
|
|
allowUpload: boolean;
|
|
|
|
allowDownload: boolean;
|
|
|
|
password: string | null;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type AuthSession = {
|
|
|
|
id: string;
|
|
|
|
};
|
|
|
|
|
2025-01-15 23:31:26 -05:00
|
|
|
export const columns = {
|
2025-02-21 04:37:57 +00:00
|
|
|
ackEpoch: (columnName: 'createdAt' | 'updatedAt' | 'deletedAt') =>
|
|
|
|
sql.raw<string>(`extract(epoch from "${columnName}")::text`).as('ackEpoch'),
|
2025-02-12 15:23:08 -05:00
|
|
|
authUser: [
|
|
|
|
'users.id',
|
|
|
|
'users.name',
|
|
|
|
'users.email',
|
|
|
|
'users.isAdmin',
|
|
|
|
'users.quotaUsageInBytes',
|
|
|
|
'users.quotaSizeInBytes',
|
|
|
|
],
|
|
|
|
authApiKey: ['api_keys.id', 'api_keys.permissions'],
|
|
|
|
authSession: ['sessions.id', 'sessions.updatedAt'],
|
|
|
|
authSharedLink: [
|
|
|
|
'shared_links.id',
|
|
|
|
'shared_links.userId',
|
|
|
|
'shared_links.expiresAt',
|
|
|
|
'shared_links.showExif',
|
|
|
|
'shared_links.allowUpload',
|
|
|
|
'shared_links.allowDownload',
|
|
|
|
'shared_links.password',
|
|
|
|
],
|
2025-01-15 23:31:26 -05:00
|
|
|
userDto: ['id', 'name', 'email', 'profileImagePath', 'profileChangedAt'],
|
2025-03-03 13:41:19 -05:00
|
|
|
tagDto: ['id', 'value', 'createdAt', 'updatedAt', 'color', 'parentId'],
|
2025-02-12 15:23:08 -05:00
|
|
|
apiKey: ['id', 'name', 'userId', 'createdAt', 'updatedAt', 'permissions'],
|
2025-03-10 12:05:39 -04:00
|
|
|
syncAsset: [
|
|
|
|
'id',
|
|
|
|
'ownerId',
|
|
|
|
'thumbhash',
|
|
|
|
'checksum',
|
|
|
|
'fileCreatedAt',
|
|
|
|
'fileModifiedAt',
|
|
|
|
'localDateTime',
|
|
|
|
'type',
|
|
|
|
'deletedAt',
|
|
|
|
'isFavorite',
|
|
|
|
'isVisible',
|
|
|
|
'updateId',
|
|
|
|
],
|
|
|
|
syncAssetExif: [
|
|
|
|
'exif.assetId',
|
|
|
|
'exif.description',
|
|
|
|
'exif.exifImageWidth',
|
|
|
|
'exif.exifImageHeight',
|
|
|
|
'exif.fileSizeInByte',
|
|
|
|
'exif.orientation',
|
|
|
|
'exif.dateTimeOriginal',
|
|
|
|
'exif.modifyDate',
|
|
|
|
'exif.timeZone',
|
|
|
|
'exif.latitude',
|
|
|
|
'exif.longitude',
|
|
|
|
'exif.projectionType',
|
|
|
|
'exif.city',
|
|
|
|
'exif.state',
|
|
|
|
'exif.country',
|
|
|
|
'exif.make',
|
|
|
|
'exif.model',
|
|
|
|
'exif.lensModel',
|
|
|
|
'exif.fNumber',
|
|
|
|
'exif.focalLength',
|
|
|
|
'exif.iso',
|
|
|
|
'exif.exposureTime',
|
|
|
|
'exif.profileDescription',
|
|
|
|
'exif.rating',
|
|
|
|
'exif.fps',
|
|
|
|
'exif.updateId',
|
|
|
|
],
|
2025-01-15 23:31:26 -05:00
|
|
|
} as const;
|