[ADF-1097] Don't upload file if extension is not acceptable (#2143)

* FileModel's extension getter

* Filter out not supported extension from upload
This commit is contained in:
Popovics András
2017-07-27 14:32:37 +01:00
committed by Eugenio Romano
parent f336aeceac
commit 004516527e
4 changed files with 147 additions and 6 deletions

View File

@@ -0,0 +1,48 @@
/*!
* @license
* Copyright 2016 Alfresco Software, Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { FileModel } from './file.model';
describe('FileModel', () => {
describe('extension', () => {
it('should return the extension if file has it', () => {
const file = new FileModel(<File> { name: 'tyrion-lannister.doc' });
expect(file.extension).toBe('doc');
});
it('should return the empty string if file has NOT got it', () => {
const file = new FileModel(<File> { name: 'daenerys-targaryen' });
expect(file.extension).toBe('');
});
it('should return the empty string if file is starting with . and doesn\'t have extension', () => {
const file = new FileModel(<File> { name: '.white-walkers' });
expect(file.extension).toBe('');
});
it('should return the last extension string if file contains many dot', () => {
const file = new FileModel(<File> { name: 'you.know.nothing.jon.snow.exe' });
expect(file.extension).toBe('exe');
});
});
});

View File

@@ -73,4 +73,8 @@ export class FileModel {
return v.toString(16); return v.toString(16);
}); });
} }
get extension(): string {
return this.name.slice((Math.max(0, this.name.lastIndexOf('.')) || Infinity) + 1);
}
} }

View File

@@ -261,4 +261,60 @@ describe('UploadButtonComponent', () => {
fixture.detectChanges(); fixture.detectChanges();
expect(compiled.querySelector('#uploadFolder-label-static').textContent).toEqual('test-text'); expect(compiled.querySelector('#uploadFolder-label-static').textContent).toEqual('test-text');
}); });
describe('uploadFiles', () => {
const files: File[] = [
<File> { name: 'phobos.jpg' },
<File> { name: 'deimos.png' },
<File> { name: 'ganymede.bmp' }
];
let addToQueueSpy;
beforeEach(() => {
addToQueueSpy = spyOn(uploadService, 'addToQueue');
});
it('should filter out file, which is not part of the acceptedFilesType', () => {
component.acceptedFilesType = '.jpg';
component.uploadFiles(files);
const filesCalledWith = addToQueueSpy.calls.mostRecent().args;
expect(filesCalledWith.length).toBe(1, 'Files should contain only one element');
expect(filesCalledWith[0].name).toBe('phobos.jpg', 'png file should be filtered out');
});
it('should filter out files, which are not part of the acceptedFilesType', () => {
component.acceptedFilesType = '.jpg,.png';
component.uploadFiles(files);
const filesCalledWith = addToQueueSpy.calls.mostRecent().args;
expect(filesCalledWith.length).toBe(2, 'Files should contain two elements');
expect(filesCalledWith[0].name).toBe('phobos.jpg');
expect(filesCalledWith[1].name).toBe('deimos.png');
});
it('should not filter out anything if acceptedFilesType is wildcard', () => {
component.acceptedFilesType = '*';
component.uploadFiles(files);
const filesCalledWith = addToQueueSpy.calls.mostRecent().args;
expect(filesCalledWith.length).toBe(3, 'Files should contain all elements');
expect(filesCalledWith[0].name).toBe('phobos.jpg');
expect(filesCalledWith[1].name).toBe('deimos.png');
expect(filesCalledWith[2].name).toBe('ganymede.bmp');
});
it('should not add any file to que if everything is filtered out', () => {
component.acceptedFilesType = 'doc';
component.uploadFiles(files);
expect(addToQueueSpy).not.toHaveBeenCalled();
});
});
}); });

View File

@@ -152,12 +152,11 @@ export class UploadButtonComponent implements OnInit, OnChanges {
* @param path * @param path
*/ */
uploadFiles(files: File[]): void { uploadFiles(files: File[]): void {
if (files.length > 0) { const latestFilesAdded: FileModel[] = files
const latestFilesAdded = files.map(file => new FileModel(file, { .map<FileModel>(this.createFileModel.bind(this))
newVersion: this.versioning, .filter(this.isFileAcceptable.bind(this));
parentId: this.rootFolderId,
path: (file.webkitRelativePath || '').replace(/\/[^\/]*$/, '') if (latestFilesAdded.length > 0) {
}));
this.uploadService.addToQueue(...latestFilesAdded); this.uploadService.addToQueue(...latestFilesAdded);
this.uploadService.uploadFilesInTheQueue(this.onSuccess); this.uploadService.uploadFilesInTheQueue(this.onSuccess);
if (this.showNotificationBar) { if (this.showNotificationBar) {
@@ -166,6 +165,40 @@ export class UploadButtonComponent implements OnInit, OnChanges {
} }
} }
/**
* Creates FileModel from File
*
* @param file
*/
private createFileModel(file: File): FileModel {
return new FileModel(file, {
newVersion: this.versioning,
parentId: this.rootFolderId,
path: (file.webkitRelativePath || '').replace(/\/[^\/]*$/, '')
});
}
/**
* Checks if the given file is allowed by the extension filters
*
* @param file FileModel
*/
private isFileAcceptable(file: FileModel): boolean {
if (this.acceptedFilesType === '*') {
return true;
}
const allowedExtensions = this.acceptedFilesType
.split(',')
.map(ext => ext.replace(/^\./, ''));
if (allowedExtensions.indexOf(file.extension) !== -1) {
return true;
}
return false;
}
/** /**
* Show undo notification bar. * Show undo notification bar.
* *