mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
[ADF-2671] added permission check on permissions (#3521)
* [ADF-2671] start adding permission check for changing permissions * [ADF-2671] added permission check for inherit button and permission dialog * [ADF-2671] added permission check for inherit button and permission dialog * [ADF-2671] start fixing and adding test for new permission check * ] [ADF-2671] improved check for node-permission directive * [ADF-2671] fixed and added more test for permission on permissions * [ADF-2671] reverting change on node-permission directive * [ADF-2671] fixing test for permission check
This commit is contained in:
@@ -283,7 +283,8 @@
|
|||||||
"EVERYONE" : "EVERYONE"
|
"EVERYONE" : "EVERYONE"
|
||||||
},
|
},
|
||||||
"ERROR": {
|
"ERROR": {
|
||||||
"DUPLICATE-PERMISSION": "One or more of the permissions you have set is already present : {{list}}"
|
"DUPLICATE-PERMISSION": "One or more of the permissions you have set is already present : {{list}}",
|
||||||
|
"NOT-ALLOWED": "You are not allowed to change permissions"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
<button mat-button
|
<button mat-button
|
||||||
id="adf-add-permission-action-button"
|
id="adf-add-permission-action-button"
|
||||||
class="adf-permission-action"
|
class="adf-permission-action"
|
||||||
[disabled]="selectedItems?.length === 0"
|
[disabled]="!isAddEnabled()"
|
||||||
(click)="applySelection()">
|
(click)="applySelection()">
|
||||||
{{'PERMISSION_MANAGER.ADD-PERMISSION.ADD-ACTION' | translate}}
|
{{'PERMISSION_MANAGER.ADD-PERMISSION.ADD-ACTION' | translate}}
|
||||||
</button>
|
</button>
|
||||||
|
@@ -19,7 +19,7 @@ import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
|||||||
import { AddPermissionComponent } from './add-permission.component';
|
import { AddPermissionComponent } from './add-permission.component';
|
||||||
import { AddPermissionPanelComponent } from './add-permission-panel.component';
|
import { AddPermissionPanelComponent } from './add-permission-panel.component';
|
||||||
import { By } from '@angular/platform-browser';
|
import { By } from '@angular/platform-browser';
|
||||||
import { setupTestBed } from '@alfresco/adf-core';
|
import { setupTestBed, NodesApiService } from '@alfresco/adf-core';
|
||||||
import { Observable } from 'rxjs/Observable';
|
import { Observable } from 'rxjs/Observable';
|
||||||
import { fakeAuthorityResults } from '../../../mock/add-permission.component.mock';
|
import { fakeAuthorityResults } from '../../../mock/add-permission.component.mock';
|
||||||
import { ContentTestingModule } from '../../../testing/content.testing.module';
|
import { ContentTestingModule } from '../../../testing/content.testing.module';
|
||||||
@@ -30,6 +30,7 @@ describe('AddPermissionComponent', () => {
|
|||||||
let fixture: ComponentFixture<AddPermissionComponent>;
|
let fixture: ComponentFixture<AddPermissionComponent>;
|
||||||
let element: HTMLElement;
|
let element: HTMLElement;
|
||||||
let nodePermissionService: NodePermissionService;
|
let nodePermissionService: NodePermissionService;
|
||||||
|
let nodeApiService: NodesApiService;
|
||||||
|
|
||||||
setupTestBed({
|
setupTestBed({
|
||||||
imports: [
|
imports: [
|
||||||
@@ -38,6 +39,8 @@ describe('AddPermissionComponent', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
|
nodeApiService = TestBed.get(NodesApiService);
|
||||||
|
spyOn(nodeApiService, 'getNode').and.returnValue(Observable.of({ id: 'fake-node', allowableOperations: ['updatePermissions']}));
|
||||||
fixture = TestBed.createComponent(AddPermissionComponent);
|
fixture = TestBed.createComponent(AddPermissionComponent);
|
||||||
element = fixture.nativeElement;
|
element = fixture.nativeElement;
|
||||||
nodePermissionService = TestBed.get(NodePermissionService);
|
nodePermissionService = TestBed.get(NodePermissionService);
|
||||||
@@ -67,12 +70,24 @@ describe('AddPermissionComponent', () => {
|
|||||||
});
|
});
|
||||||
}));
|
}));
|
||||||
|
|
||||||
it('should emit a success event when the node is updated', async(() => {
|
it('should NOT enable the ADD button when a selection is sent but the user does not have the permissions', async(() => {
|
||||||
|
const addPermissionPanelComponent: AddPermissionPanelComponent = fixture.debugElement.query(By.directive(AddPermissionPanelComponent)).componentInstance;
|
||||||
|
addPermissionPanelComponent.select.emit(fakeAuthorityResults);
|
||||||
|
fixture.componentInstance.currentNode = {id: 'fake-node-id'};
|
||||||
|
fixture.whenStable().then(() => {
|
||||||
|
fixture.detectChanges();
|
||||||
|
const addButton: HTMLButtonElement = <HTMLButtonElement> element.querySelector('#adf-add-permission-action-button');
|
||||||
|
expect(addButton.disabled).toBeTruthy();
|
||||||
|
});
|
||||||
|
}));
|
||||||
|
|
||||||
|
it('should emit a success event when the node is updated', (done) => {
|
||||||
fixture.componentInstance.selectedItems = fakeAuthorityResults;
|
fixture.componentInstance.selectedItems = fakeAuthorityResults;
|
||||||
spyOn(nodePermissionService, 'updateNodePermissions').and.returnValue(Observable.of({ id: 'fake-node-id'}));
|
spyOn(nodePermissionService, 'updateNodePermissions').and.returnValue(Observable.of({ id: 'fake-node-id'}));
|
||||||
|
|
||||||
fixture.componentInstance.success.subscribe((node) => {
|
fixture.componentInstance.success.subscribe((node) => {
|
||||||
expect(node.id).toBe('fake-node-id');
|
expect(node.id).toBe('fake-node-id');
|
||||||
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
@@ -81,14 +96,25 @@ describe('AddPermissionComponent', () => {
|
|||||||
const addButton: HTMLButtonElement = <HTMLButtonElement> element.querySelector('#adf-add-permission-action-button');
|
const addButton: HTMLButtonElement = <HTMLButtonElement> element.querySelector('#adf-add-permission-action-button');
|
||||||
addButton.click();
|
addButton.click();
|
||||||
});
|
});
|
||||||
}));
|
});
|
||||||
|
|
||||||
it('should emit an error event when the node update fail', async(() => {
|
it('should NOT emit a success event when the user does not have permission to update the node', () => {
|
||||||
|
fixture.componentInstance.selectedItems = fakeAuthorityResults;
|
||||||
|
fixture.componentInstance.currentNode = { id: 'fake-node-id' };
|
||||||
|
spyOn(nodePermissionService, 'updateNodePermissions').and.returnValue(Observable.of({ id: 'fake-node-id' }));
|
||||||
|
|
||||||
|
let spySuccess = spyOn(fixture.componentInstance, 'success');
|
||||||
|
fixture.componentInstance.applySelection();
|
||||||
|
expect(spySuccess).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should emit an error event when the node update fail', (done) => {
|
||||||
fixture.componentInstance.selectedItems = fakeAuthorityResults;
|
fixture.componentInstance.selectedItems = fakeAuthorityResults;
|
||||||
spyOn(nodePermissionService, 'updateNodePermissions').and.returnValue(Observable.throw({ error: 'errored'}));
|
spyOn(nodePermissionService, 'updateNodePermissions').and.returnValue(Observable.throw({ error: 'errored'}));
|
||||||
|
|
||||||
fixture.componentInstance.error.subscribe((error) => {
|
fixture.componentInstance.error.subscribe((error) => {
|
||||||
expect(error.error).toBe('errored');
|
expect(error.error).toBe('errored');
|
||||||
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
@@ -97,6 +123,6 @@ describe('AddPermissionComponent', () => {
|
|||||||
const addButton: HTMLButtonElement = <HTMLButtonElement> element.querySelector('#adf-add-permission-action-button');
|
const addButton: HTMLButtonElement = <HTMLButtonElement> element.querySelector('#adf-add-permission-action-button');
|
||||||
addButton.click();
|
addButton.click();
|
||||||
});
|
});
|
||||||
}));
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@@ -18,6 +18,7 @@
|
|||||||
import { Component, ViewEncapsulation, EventEmitter, Input, Output } from '@angular/core';
|
import { Component, ViewEncapsulation, EventEmitter, Input, Output } from '@angular/core';
|
||||||
import { MinimalNodeEntity, MinimalNodeEntryEntity } from 'alfresco-js-api';
|
import { MinimalNodeEntity, MinimalNodeEntryEntity } from 'alfresco-js-api';
|
||||||
import { NodePermissionService } from '../../services/node-permission.service';
|
import { NodePermissionService } from '../../services/node-permission.service';
|
||||||
|
import { NodesApiService, ContentService, PermissionsEnum } from '@alfresco/adf-core';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'adf-add-permission',
|
selector: 'adf-add-permission',
|
||||||
@@ -43,22 +44,32 @@ export class AddPermissionComponent {
|
|||||||
currentNode: MinimalNodeEntryEntity;
|
currentNode: MinimalNodeEntryEntity;
|
||||||
currentNodeRoles: string[];
|
currentNodeRoles: string[];
|
||||||
|
|
||||||
constructor(private nodePermissionService: NodePermissionService) {
|
constructor(private nodePermissionService: NodePermissionService,
|
||||||
|
private nodeApiService: NodesApiService,
|
||||||
|
private contentService: ContentService) {
|
||||||
|
this.nodeApiService.getNode(this.nodeId).subscribe((node) => this.currentNode = node);
|
||||||
}
|
}
|
||||||
|
|
||||||
onSelect(selection: MinimalNodeEntity[]) {
|
onSelect(selection: MinimalNodeEntity[]) {
|
||||||
this.selectedItems = selection;
|
this.selectedItems = selection;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
isAddEnabled(): boolean {
|
||||||
|
return this.contentService.hasPermission(this.currentNode, PermissionsEnum.UPDATEPERMISSIONS) &&
|
||||||
|
this.selectedItems.length !== 0;
|
||||||
|
}
|
||||||
|
|
||||||
applySelection() {
|
applySelection() {
|
||||||
this.nodePermissionService.updateNodePermissions(this.nodeId, this.selectedItems)
|
if (this.contentService.hasPermission(this.currentNode, PermissionsEnum.UPDATEPERMISSIONS)) {
|
||||||
.subscribe(
|
this.nodePermissionService.updateNodePermissions(this.nodeId, this.selectedItems)
|
||||||
(node) => {
|
.subscribe(
|
||||||
this.success.emit(node);
|
(node) => {
|
||||||
},
|
this.success.emit(node);
|
||||||
(error) => {
|
},
|
||||||
this.error.emit(error);
|
(error) => {
|
||||||
});
|
this.error.emit(error);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -21,8 +21,9 @@ import { InheritPermissionDirective } from './inherited-button.directive';
|
|||||||
import { NodesApiService, setupTestBed, CoreModule } from '@alfresco/adf-core';
|
import { NodesApiService, setupTestBed, CoreModule } from '@alfresco/adf-core';
|
||||||
import { Observable } from 'rxjs/Observable';
|
import { Observable } from 'rxjs/Observable';
|
||||||
|
|
||||||
const fakeNodeWithInherit: any = { id: 'fake-id', permissions : {isInheritanceEnabled : true}};
|
const fakeNodeWithInherit: any = { id: 'fake-id', permissions : {isInheritanceEnabled : true}, allowableOperations: ['updatePermissions']};
|
||||||
const fakeNodeNoInherit: any = { id: 'fake-id', permissions : {isInheritanceEnabled : false}};
|
const fakeNodeNoInherit: any = { id: 'fake-id', permissions : {isInheritanceEnabled : false}, allowableOperations: ['updatePermissions']};
|
||||||
|
const fakeNodeWithInheritNoPermission: any = { id: 'fake-id', permissions : {isInheritanceEnabled : true}};
|
||||||
|
|
||||||
describe('InheritPermissionDirective', () => {
|
describe('InheritPermissionDirective', () => {
|
||||||
|
|
||||||
@@ -95,4 +96,19 @@ describe('InheritPermissionDirective', () => {
|
|||||||
});
|
});
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
it('should not update the node when node has no permission', async(() => {
|
||||||
|
spyOn(nodeService, 'getNode').and.returnValue(Observable.of(fakeNodeWithInheritNoPermission));
|
||||||
|
let spyUpdateNode = spyOn(nodeService, 'updateNode');
|
||||||
|
component.updatedNode = true;
|
||||||
|
fixture.detectChanges();
|
||||||
|
const buttonPermission: HTMLButtonElement = <HTMLButtonElement> element.querySelector('#sample-button-permission');
|
||||||
|
expect(buttonPermission).not.toBeNull();
|
||||||
|
expect(element.querySelector('#update-notification')).not.toBeNull();
|
||||||
|
buttonPermission.click();
|
||||||
|
fixture.detectChanges();
|
||||||
|
fixture.whenStable().then(() => {
|
||||||
|
expect(spyUpdateNode).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
}));
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
/* tslint:disable:no-input-rename */
|
/* tslint:disable:no-input-rename */
|
||||||
import { Directive, Input, Output, EventEmitter } from '@angular/core';
|
import { Directive, Input, Output, EventEmitter } from '@angular/core';
|
||||||
import { NodesApiService } from '@alfresco/adf-core';
|
import { NodesApiService, ContentService, PermissionsEnum } from '@alfresco/adf-core';
|
||||||
import { MinimalNodeEntryEntity } from 'alfresco-js-api';
|
import { MinimalNodeEntryEntity } from 'alfresco-js-api';
|
||||||
|
|
||||||
@Directive({
|
@Directive({
|
||||||
@@ -38,15 +38,20 @@ export class InheritPermissionDirective {
|
|||||||
@Output()
|
@Output()
|
||||||
error: EventEmitter<any> = new EventEmitter<any>();
|
error: EventEmitter<any> = new EventEmitter<any>();
|
||||||
|
|
||||||
constructor(private nodeService: NodesApiService) {
|
constructor(private nodeService: NodesApiService,
|
||||||
|
private contentService: ContentService) {
|
||||||
}
|
}
|
||||||
|
|
||||||
onInheritPermissionClicked() {
|
onInheritPermissionClicked() {
|
||||||
this.nodeService.getNode(this.nodeId).subscribe((node: MinimalNodeEntryEntity) => {
|
this.nodeService.getNode(this.nodeId).subscribe((node: MinimalNodeEntryEntity) => {
|
||||||
const nodeBody = { permissions: { isInheritanceEnabled: !node.permissions.isInheritanceEnabled } };
|
if (this.contentService.hasPermission(node, PermissionsEnum.UPDATEPERMISSIONS)) {
|
||||||
this.nodeService.updateNode(this.nodeId, nodeBody, { include: ['permissions'] }).subscribe((nodeUpdated: MinimalNodeEntryEntity) => {
|
const nodeBody = { permissions: { isInheritanceEnabled: !node.permissions.isInheritanceEnabled } };
|
||||||
this.updated.emit(nodeUpdated);
|
this.nodeService.updateNode(this.nodeId, nodeBody, { include: ['permissions'] }).subscribe((nodeUpdated: MinimalNodeEntryEntity) => {
|
||||||
}, (error) => this.error.emit(error));
|
this.updated.emit(nodeUpdated);
|
||||||
|
}, (error) => this.error.emit(error));
|
||||||
|
} else {
|
||||||
|
this.error.emit('PERMISSION_MANAGER.ERROR.NOT-ALLOWED');
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -16,13 +16,14 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import { TestBed, async } from '@angular/core/testing';
|
import { TestBed, async } from '@angular/core/testing';
|
||||||
import { AppConfigService, setupTestBed } from '@alfresco/adf-core';
|
import { AppConfigService, setupTestBed, ContentService } from '@alfresco/adf-core';
|
||||||
import { NodePermissionDialogService } from './node-permission-dialog.service';
|
import { NodePermissionDialogService } from './node-permission-dialog.service';
|
||||||
import { MatDialog } from '@angular/material';
|
import { MatDialog } from '@angular/material';
|
||||||
import { Observable } from 'rxjs/Observable';
|
import { Observable } from 'rxjs/Observable';
|
||||||
import { Subject } from 'rxjs/Subject';
|
import { Subject } from 'rxjs/Subject';
|
||||||
import { ContentTestingModule } from '../../testing/content.testing.module';
|
import { ContentTestingModule } from '../../testing/content.testing.module';
|
||||||
import { NodePermissionService } from './node-permission.service';
|
import { NodePermissionService } from './node-permission.service';
|
||||||
|
import { Node } from 'alfresco-js-api';
|
||||||
|
|
||||||
describe('NodePermissionDialogService', () => {
|
describe('NodePermissionDialogService', () => {
|
||||||
|
|
||||||
@@ -31,6 +32,7 @@ describe('NodePermissionDialogService', () => {
|
|||||||
let spyOnDialogOpen: jasmine.Spy;
|
let spyOnDialogOpen: jasmine.Spy;
|
||||||
let afterOpenObservable: Subject<any>;
|
let afterOpenObservable: Subject<any>;
|
||||||
let nodePermissionService: NodePermissionService;
|
let nodePermissionService: NodePermissionService;
|
||||||
|
let contentService: ContentService;
|
||||||
|
|
||||||
setupTestBed({
|
setupTestBed({
|
||||||
imports: [ContentTestingModule],
|
imports: [ContentTestingModule],
|
||||||
@@ -44,6 +46,7 @@ describe('NodePermissionDialogService', () => {
|
|||||||
materialDialog = TestBed.get(MatDialog);
|
materialDialog = TestBed.get(MatDialog);
|
||||||
afterOpenObservable = new Subject<any>();
|
afterOpenObservable = new Subject<any>();
|
||||||
nodePermissionService = TestBed.get(NodePermissionService);
|
nodePermissionService = TestBed.get(NodePermissionService);
|
||||||
|
contentService = TestBed.get(ContentService);
|
||||||
spyOnDialogOpen = spyOn(materialDialog, 'open').and.returnValue({
|
spyOnDialogOpen = spyOn(materialDialog, 'open').and.returnValue({
|
||||||
afterOpen: () => afterOpenObservable,
|
afterOpen: () => afterOpenObservable,
|
||||||
afterClosed: () => Observable.of({}),
|
afterClosed: () => Observable.of({}),
|
||||||
@@ -57,27 +60,65 @@ describe('NodePermissionDialogService', () => {
|
|||||||
expect(service).not.toBeNull();
|
expect(service).not.toBeNull();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should be able to open the dialog showing node permissions', () => {
|
describe('when node has permission to update permissions', () => {
|
||||||
service.openAddPermissionDialog('fake-node-id', 'fake-title');
|
|
||||||
expect(spyOnDialogOpen).toHaveBeenCalled();
|
let fakePermissionNode = {};
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
fakePermissionNode = <Node> { id: 'fake-permission-node', allowableOperations: ['updatePermissions']};
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be able to open the dialog showing node permissions', () => {
|
||||||
|
service.openAddPermissionDialog(fakePermissionNode, 'fake-title');
|
||||||
|
expect(spyOnDialogOpen).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return the updated node', (done) => {
|
||||||
|
spyOn(nodePermissionService, 'updateNodePermissions').and.returnValue(Observable.of({id : 'fake-node-updated'}));
|
||||||
|
spyOn(service, 'openAddPermissionDialog').and.returnValue(Observable.of({}));
|
||||||
|
spyOn(contentService, 'getNode').and.returnValue(Observable.of(fakePermissionNode));
|
||||||
|
service.updateNodePermissionByDialog('fake-node-id', 'fake-title').subscribe((node) => {
|
||||||
|
expect(node.id).toBe('fake-node-updated');
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should throw an error if the update of the node fails', (done) => {
|
||||||
|
spyOn(nodePermissionService, 'updateNodePermissions').and.returnValue(Observable.throw({error : 'error'}));
|
||||||
|
spyOn(service, 'openAddPermissionDialog').and.returnValue(Observable.of({}));
|
||||||
|
spyOn(contentService, 'getNode').and.returnValue(Observable.of(fakePermissionNode));
|
||||||
|
service.updateNodePermissionByDialog('fake-node-id', 'fake-title').subscribe(() => {
|
||||||
|
Observable.throw('This call should fail');
|
||||||
|
}, (error) => {
|
||||||
|
expect(error.error).toBe('error');
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should throw an error if the update of the node fails', async(() => {
|
describe('when node does not have permission to update permissions', () => {
|
||||||
spyOn(nodePermissionService, 'updateNodePermissions').and.returnValue(Observable.throw({error : 'error'}));
|
|
||||||
spyOn(service, 'openAddPermissionDialog').and.returnValue(Observable.of({}));
|
|
||||||
service.updateNodePermissionByDialog('fake-node-id', 'fake-title').subscribe(() => {
|
|
||||||
Observable.throw('This call should fail');
|
|
||||||
}, (error) => {
|
|
||||||
expect(error.error).toBe('error');
|
|
||||||
});
|
|
||||||
}));
|
|
||||||
|
|
||||||
it('should return the updated node', async(() => {
|
let fakeForbiddenNode = {};
|
||||||
spyOn(nodePermissionService, 'updateNodePermissions').and.returnValue(Observable.of({id : 'fake-node'}));
|
|
||||||
spyOn(service, 'openAddPermissionDialog').and.returnValue(Observable.of({}));
|
|
||||||
service.updateNodePermissionByDialog('fake-node-id', 'fake-title').subscribe((node) => {
|
|
||||||
expect(node.id).toBe('fake-node');
|
|
||||||
});
|
|
||||||
}));
|
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
fakeForbiddenNode = <Node> { id: 'fake-permission-node', allowableOperations: ['update']};
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not be able to open the dialog showing node permissions', () => {
|
||||||
|
service.openAddPermissionDialog(fakeForbiddenNode, 'fake-title');
|
||||||
|
expect(spyOnDialogOpen).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return the updated node', (done) => {
|
||||||
|
spyOn(contentService, 'getNode').and.returnValue(Observable.of(fakeForbiddenNode));
|
||||||
|
service.updateNodePermissionByDialog('fake-node-id', 'fake-title').subscribe((node) => {
|
||||||
|
Observable.throw('This call should fail');
|
||||||
|
},
|
||||||
|
(error) => {
|
||||||
|
expect(error.message).toBe('PERMISSION_MANAGER.ERROR.NOT-ALLOWED');
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
@@ -21,14 +21,16 @@ import { Subject } from 'rxjs/Subject';
|
|||||||
import { Observable } from 'rxjs/Observable';
|
import { Observable } from 'rxjs/Observable';
|
||||||
import { AddPermissionDialogComponent } from '../components/add-permission/add-permission-dialog.component';
|
import { AddPermissionDialogComponent } from '../components/add-permission/add-permission-dialog.component';
|
||||||
import { AddPermissionDialogData } from '../components/add-permission/add-permission-dialog-data.interface';
|
import { AddPermissionDialogData } from '../components/add-permission/add-permission-dialog-data.interface';
|
||||||
import { MinimalNodeEntity, MinimalNodeEntryEntity } from 'alfresco-js-api';
|
import { MinimalNodeEntity, MinimalNodeEntryEntity, Node } from 'alfresco-js-api';
|
||||||
import { NodePermissionService } from './node-permission.service';
|
import { NodePermissionService } from './node-permission.service';
|
||||||
|
import { ContentService, PermissionsEnum } from '@alfresco/adf-core';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class NodePermissionDialogService {
|
export class NodePermissionDialogService {
|
||||||
|
|
||||||
constructor(private dialog: MatDialog,
|
constructor(private dialog: MatDialog,
|
||||||
private nodePermissionService: NodePermissionService) {
|
private nodePermissionService: NodePermissionService,
|
||||||
|
private contentService: ContentService) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -37,21 +39,27 @@ export class NodePermissionDialogService {
|
|||||||
* @param title Dialog title
|
* @param title Dialog title
|
||||||
* @returns Node with updated permissions
|
* @returns Node with updated permissions
|
||||||
*/
|
*/
|
||||||
openAddPermissionDialog(nodeId: string, title?: string): Observable<MinimalNodeEntity[]> {
|
openAddPermissionDialog(node: Node, title?: string): Observable<MinimalNodeEntity[]> {
|
||||||
const confirm = new Subject<MinimalNodeEntity[]>();
|
if (this.contentService.hasPermission(node, PermissionsEnum.UPDATEPERMISSIONS)) {
|
||||||
|
const confirm = new Subject<MinimalNodeEntity[]>();
|
||||||
|
|
||||||
confirm.subscribe({
|
confirm.subscribe({
|
||||||
complete: this.close.bind(this)
|
complete: this.close.bind(this)
|
||||||
});
|
});
|
||||||
|
|
||||||
const data: AddPermissionDialogData = {
|
const data: AddPermissionDialogData = {
|
||||||
nodeId: nodeId,
|
nodeId: node.id,
|
||||||
title: title,
|
title: title,
|
||||||
confirm : confirm
|
confirm: confirm
|
||||||
};
|
};
|
||||||
|
|
||||||
this.openDialog(data, 'adf-add-permission-dialog', '630px');
|
this.openDialog(data, 'adf-add-permission-dialog', '630px');
|
||||||
return confirm;
|
return confirm;
|
||||||
|
} else {
|
||||||
|
let errors = new Error(JSON.stringify({ error: { statusCode: 403 } }));
|
||||||
|
errors.message = 'PERMISSION_MANAGER.ERROR.NOT-ALLOWED';
|
||||||
|
return Observable.throw(errors);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private openDialog(data: any, currentPanelClass: string, chosenWidth: string) {
|
private openDialog(data: any, currentPanelClass: string, chosenWidth: string) {
|
||||||
@@ -72,8 +80,10 @@ export class NodePermissionDialogService {
|
|||||||
* @returns Node with updated permissions
|
* @returns Node with updated permissions
|
||||||
*/
|
*/
|
||||||
updateNodePermissionByDialog(nodeId?: string, title?: string): Observable<MinimalNodeEntryEntity> {
|
updateNodePermissionByDialog(nodeId?: string, title?: string): Observable<MinimalNodeEntryEntity> {
|
||||||
return this.openAddPermissionDialog(nodeId, title).switchMap((selection) => {
|
return this.contentService.getNode(nodeId, { include: ['allowableOperations'] }).switchMap((node) => {
|
||||||
return this.nodePermissionService.updateNodePermissions(nodeId, selection);
|
return this.openAddPermissionDialog(node.entry, title).switchMap((selection) => {
|
||||||
|
return this.nodePermissionService.updateNodePermissions(nodeId, selection);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user