Я пытаюсь дать разрешение различным пользователям в зависимости от их ролей.Разрешения: выборка, добавление, удаление, редактирование и т. Д. .Когда я даю только определенное разрешение пользователю, как, например, если я даю только добавить и удалить для пользователя1, то при создании следующего пользователя и затем при предоставлении разрешения только добавить и удалить доступны, другие разрешения не доступны.Как мне решить это?Я хочу новый идентификатор группы для каждого разрешения роли.Я попытался написать код ниже, но, похоже, он не работает.
service.ts
add_permission(data){
var headers = new HttpHeaders().set('Authorization', 'Token ' +
localStorage.getItem('usertoken'));
var options = {
headers: headers
};
return this.httpClient.post('/api/auth/permission_list/',data,
options)
}
component.ts
id :number;
dropdown_data:any = [];
checkedList = [];
permissionList:any = [];
perms:any = [];
permission_data:any = [];
onChange(email:string, checked: boolean) {
if(checked) {
this.perms.push(this.permission_data.permission_list)
}
}
ngOnInit(): void{
//get permission
this.Authentication.get_permissions().subscribe(res =>{
this.permissionList = res;
console.log(res);
for(let val of this.permissionList){
this.dropdown_data = val.permission_list
this.id = val.group_id
}
})
}
//getting values of selected check box
onCheckboxChange(val, event) {
if(event.target.checked) {
this.checkedList.push(val);
console.log(this.checkedList);
} else {
for(var i=0 ; i < this.dropdown_data.length; i++) {
if(this.checkedList[i] == val){
this.checkedList.splice(i,1);
}
}
}
}
// add permission
addPermission(){
let permissions = {};
permissions['group_id'] = this.id
permissions['permission_list']= this.checkedList;
console.log(permissions)
this.Authentication.add_permission(permissions).subscribe(res => {
console.log('added')
},
err =>{
console.log('error');
})
}
component.html
<div class="modal-body">
<table class="table">
<thead>
<tr>
<th scope="col">Permissions</th>
<th scope="col">Select/Unselect</th>
</tr>
</thead>
<tbody *ngFor="let val of dropdown_data" >
<tr>
<td>{{val}}</td>
<td><label class="container-1">
<input type="checkbox" value="{{val}}" (change)="onCheckboxChange(val,$event)" >
<span class="checkmark"></span>
</label></td>
</tr>
</tbody>
</table>
<button type="button" class="btn btn-primary pull-right" (click)="addPermission()">Submit</button>
</div>