mirror of
https://github.com/immich-app/immich.git
synced 2025-01-12 15:32:36 +02:00
fix(server): dot files (#4625)
This commit is contained in:
parent
3e3598fd92
commit
5921ec9a58
@ -125,7 +125,12 @@ export class AuditService {
|
|||||||
const fullPath = (filename: string) => resolve(filename);
|
const fullPath = (filename: string) => resolve(filename);
|
||||||
const hasFile = (items: Set<string>, filename: string) => items.has(filename) || items.has(fullPath(filename));
|
const hasFile = (items: Set<string>, filename: string) => items.has(filename) || items.has(fullPath(filename));
|
||||||
const crawl = async (folder: StorageFolder) =>
|
const crawl = async (folder: StorageFolder) =>
|
||||||
new Set(await this.storageRepository.crawl({ pathsToCrawl: [StorageCore.getBaseFolder(folder)] }));
|
new Set(
|
||||||
|
await this.storageRepository.crawl({
|
||||||
|
includeHidden: true,
|
||||||
|
pathsToCrawl: [StorageCore.getBaseFolder(folder)],
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
|
||||||
const uploadFiles = await crawl(StorageFolder.UPLOAD);
|
const uploadFiles = await crawl(StorageFolder.UPLOAD);
|
||||||
const libraryFiles = await crawl(StorageFolder.LIBRARY);
|
const libraryFiles = await crawl(StorageFolder.LIBRARY);
|
||||||
|
@ -25,7 +25,7 @@ import {
|
|||||||
NotFoundException,
|
NotFoundException,
|
||||||
} from '@nestjs/common';
|
} from '@nestjs/common';
|
||||||
import { InjectRepository } from '@nestjs/typeorm';
|
import { InjectRepository } from '@nestjs/typeorm';
|
||||||
import { Response as Res } from 'express';
|
import { Response as Res, Response } from 'express';
|
||||||
import { constants } from 'fs';
|
import { constants } from 'fs';
|
||||||
import fs from 'fs/promises';
|
import fs from 'fs/promises';
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
@ -52,6 +52,9 @@ import { CheckExistingAssetsResponseDto } from './response-dto/check-existing-as
|
|||||||
import { CuratedLocationsResponseDto } from './response-dto/curated-locations-response.dto';
|
import { CuratedLocationsResponseDto } from './response-dto/curated-locations-response.dto';
|
||||||
import { CuratedObjectsResponseDto } from './response-dto/curated-objects-response.dto';
|
import { CuratedObjectsResponseDto } from './response-dto/curated-objects-response.dto';
|
||||||
|
|
||||||
|
type SendFile = Parameters<Response['sendFile']>;
|
||||||
|
type SendFileOptions = SendFile[1];
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class AssetService {
|
export class AssetService {
|
||||||
readonly logger = new Logger(AssetService.name);
|
readonly logger = new Logger(AssetService.name);
|
||||||
@ -436,7 +439,10 @@ export class AssetService {
|
|||||||
|
|
||||||
private async sendFile(res: Res, filepath: string): Promise<void> {
|
private async sendFile(res: Res, filepath: string): Promise<void> {
|
||||||
await fs.access(filepath, constants.R_OK);
|
await fs.access(filepath, constants.R_OK);
|
||||||
const options = path.isAbsolute(filepath) ? {} : { root: process.cwd() };
|
const options: SendFileOptions = { dotfiles: 'allow' };
|
||||||
|
if (!path.isAbsolute(filepath)) {
|
||||||
|
options.root = process.cwd();
|
||||||
|
}
|
||||||
|
|
||||||
res.set('Cache-Control', 'private, max-age=86400, no-transform');
|
res.set('Cache-Control', 'private, max-age=86400, no-transform');
|
||||||
res.header('Content-Type', mimeTypes.lookup(filepath));
|
res.header('Content-Type', mimeTypes.lookup(filepath));
|
||||||
|
@ -117,7 +117,7 @@ export class FilesystemProvider implements IStorageRepository {
|
|||||||
}
|
}
|
||||||
|
|
||||||
crawl(crawlOptions: CrawlOptionsDto): Promise<string[]> {
|
crawl(crawlOptions: CrawlOptionsDto): Promise<string[]> {
|
||||||
const { pathsToCrawl, exclusionPatterns } = crawlOptions;
|
const { pathsToCrawl, exclusionPatterns, includeHidden } = crawlOptions;
|
||||||
if (!pathsToCrawl) {
|
if (!pathsToCrawl) {
|
||||||
return Promise.resolve([]);
|
return Promise.resolve([]);
|
||||||
}
|
}
|
||||||
@ -129,6 +129,7 @@ export class FilesystemProvider implements IStorageRepository {
|
|||||||
absolute: true,
|
absolute: true,
|
||||||
nocase: true,
|
nocase: true,
|
||||||
nodir: true,
|
nodir: true,
|
||||||
|
dot: includeHidden,
|
||||||
ignore: exclusionPatterns,
|
ignore: exclusionPatterns,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user