mirror of
https://github.com/CommunitySolidServer/CommunitySolidServer.git
synced 2024-10-03 14:55:10 +00:00
98 lines
4.1 KiB
TypeScript
98 lines
4.1 KiB
TypeScript
import { copyFileSync, mkdirSync } from 'fs';
|
|
import { join } from 'path';
|
|
import * as rimraf from 'rimraf';
|
|
import { FileDataAccessor } from '../../src/storage/accessors/FileDataAccessor';
|
|
import { ExtensionBasedMapper } from '../../src/storage/ExtensionBasedMapper';
|
|
import { MetadataController } from '../../src/util/MetadataController';
|
|
import { ensureTrailingSlash } from '../../src/util/Util';
|
|
import { AuthenticatedDataAccessorBasedConfig } from '../configs/AuthenticatedDataAccessorBasedConfig';
|
|
import { AuthenticatedFileResourceStoreConfig } from '../configs/AuthenticatedFileResourceStoreConfig';
|
|
import type { ServerConfig } from '../configs/ServerConfig';
|
|
import { BASE, getRootFilePath } from '../configs/Util';
|
|
import { AclTestHelper, FileTestHelper } from '../util/TestHelpers';
|
|
|
|
const fileResourceStore: [string, (rootFilePath: string) => ServerConfig] = [
|
|
'AuthenticatedFileResourceStore',
|
|
(rootFilePath: string): ServerConfig => new AuthenticatedFileResourceStoreConfig(BASE, rootFilePath),
|
|
];
|
|
const dataAccessorStore: [string, (rootFilePath: string) => ServerConfig] = [
|
|
'AuthenticatedFileDataAccessorBasedStore',
|
|
(rootFilePath: string): ServerConfig => new AuthenticatedDataAccessorBasedConfig(BASE,
|
|
new FileDataAccessor(new ExtensionBasedMapper(BASE, rootFilePath), new MetadataController())),
|
|
];
|
|
|
|
describe.each([ fileResourceStore, dataAccessorStore ])('A server using a %s', (name, configFn): void => {
|
|
describe('with acl', (): void => {
|
|
let config: ServerConfig;
|
|
let aclHelper: AclTestHelper;
|
|
let fileHelper: FileTestHelper;
|
|
let rootFilePath: string;
|
|
|
|
beforeAll(async(): Promise<void> => {
|
|
rootFilePath = getRootFilePath(name);
|
|
mkdirSync(rootFilePath, { recursive: true });
|
|
config = configFn(rootFilePath);
|
|
aclHelper = new AclTestHelper(config.store, ensureTrailingSlash(BASE));
|
|
fileHelper = new FileTestHelper(config.getHttpHandler(), new URL(ensureTrailingSlash(BASE)));
|
|
|
|
// Make sure the root directory exists
|
|
mkdirSync(rootFilePath, { recursive: true });
|
|
copyFileSync(join(__dirname, '../assets/permanent.txt'), `${rootFilePath}/permanent.txt`);
|
|
});
|
|
|
|
afterAll(async(): Promise<void> => {
|
|
rimraf.sync(rootFilePath, { glob: false });
|
|
});
|
|
|
|
it('can add a file to the store, read it and delete it if allowed.', async(): Promise<
|
|
void
|
|
> => {
|
|
// Set acl
|
|
await aclHelper.setSimpleAcl({ read: true, write: true, append: true }, 'agent');
|
|
|
|
// Create file
|
|
let response = await fileHelper.createFile('../assets/testfile2.txt', 'testfile2.txt', 'text/plain');
|
|
const id = response._getHeaders().location;
|
|
|
|
// Get file
|
|
response = await fileHelper.getFile(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getHeaders().location).toBe(id);
|
|
expect(response._getBuffer().toString()).toContain('TESTFILE2');
|
|
|
|
// DELETE file
|
|
await fileHelper.deleteFile(id);
|
|
await fileHelper.shouldNotExist(id);
|
|
});
|
|
|
|
it('can not add a file to the store if not allowed.', async():
|
|
Promise<void> => {
|
|
// Set acl
|
|
await aclHelper.setSimpleAcl({ read: true, write: true, append: true }, 'authenticated');
|
|
|
|
// Try to create file
|
|
const response = await fileHelper.createFile('../assets/testfile2.txt', 'testfile2.txt', 'text/plain', true);
|
|
expect(response.statusCode).toBe(401);
|
|
});
|
|
|
|
it('can not add/delete, but only read files if allowed.', async():
|
|
Promise<void> => {
|
|
// Set acl
|
|
await aclHelper.setSimpleAcl({ read: true, write: false, append: false }, 'agent');
|
|
|
|
// Try to create file
|
|
let response = await fileHelper.createFile('../assets/testfile2.txt', 'testfile2.txt', 'text/plain', true);
|
|
expect(response.statusCode).toBe(401);
|
|
|
|
// GET permanent file
|
|
response = await fileHelper.getFile('http://test.com/permanent.txt');
|
|
expect(response._getHeaders().location).toBe('http://test.com/permanent.txt');
|
|
expect(response._getBuffer().toString()).toContain('TEST');
|
|
|
|
// Try to delete permanent file
|
|
response = await fileHelper.deleteFile('http://test.com/permanent.txt', true);
|
|
expect(response.statusCode).toBe(401);
|
|
});
|
|
});
|
|
});
|