1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-07-30 02:29:43 +02:00

re-working space permissions -- WIP

This commit is contained in:
Harvey Kandola 2017-09-13 19:22:38 +01:00
parent c51ba65b1d
commit ae05cacf3f
37 changed files with 735 additions and 601 deletions

View file

@ -13,7 +13,6 @@ import Ember from 'ember';
import BaseService from '../services/base';
const {
get,
RSVP,
inject: { service }
} = Ember;
@ -30,7 +29,7 @@ export default BaseService.extend({
// Add a new folder.
add(payload) {
return this.get('ajax').post(`folders`, {
return this.get('ajax').post(`space`, {
contentType: 'json',
data: JSON.stringify(payload)
}).then((folder) => {
@ -41,7 +40,7 @@ export default BaseService.extend({
// Returns folder model for specified folder id.
getFolder(id) {
return this.get('ajax').request(`folders/${id}`, {
return this.get('ajax').request(`space/${id}`, {
method: 'GET'
}).then((folder) => {
let data = this.get('store').normalize('folder', folder);
@ -54,7 +53,7 @@ export default BaseService.extend({
// Returns all folders that user can see.
getAll() {
let folders = this.get('folders');
let folders = this.get('space');
if (folders != null) {
return new RSVP.resolve(folders);
@ -67,7 +66,7 @@ export default BaseService.extend({
save(folder) {
let id = folder.get('id');
return this.get('ajax').request(`folders/${id}`, {
return this.get('ajax').request(`space/${id}`, {
method: 'PUT',
contentType: 'json',
data: JSON.stringify(folder)
@ -75,7 +74,7 @@ export default BaseService.extend({
},
remove(folderId, moveToId) {
let url = `folders/${folderId}/move/${moveToId}`;
let url = `space/${folderId}/move/${moveToId}`;
return this.get('ajax').request(url, {
method: 'DELETE'
@ -83,7 +82,7 @@ export default BaseService.extend({
},
delete(folderId) {
return this.get('ajax').request(`folders/${folderId}`, {
return this.get('ajax').request(`space/${folderId}`, {
method: 'DELETE'
});
},
@ -99,7 +98,7 @@ export default BaseService.extend({
// getProtectedFolderInfo returns non-private folders and who has access to them.
getProtectedFolderInfo() {
return this.get('ajax').request(`folders?filter=viewers`, {
return this.get('ajax').request(`space?filter=viewers`, {
method: "GET"
}).then((response) => {
let data = [];
@ -116,7 +115,7 @@ export default BaseService.extend({
// reloads and caches folders.
reload() {
return this.get('ajax').request(`folders`, {
return this.get('ajax').request(`space`, {
method: "GET"
}).then((response) => {
let data = [];
@ -132,14 +131,13 @@ export default BaseService.extend({
// so who can see/edit this folder?
getPermissions(folderId) {
return this.get('ajax').request(`folders/${folderId}/permissions`, {
return this.get('ajax').request(`space/${folderId}/permissions`, {
method: "GET"
}).then((response) => {
let data = [];
data = response.map((obj) => {
let data = this.get('store').normalize('folder-permission', obj);
let data = this.get('store').normalize('user-permission', obj);
return this.get('store').push(data);
});
@ -149,7 +147,7 @@ export default BaseService.extend({
// persist folder permissions
savePermissions(folderId, payload) {
return this.get('ajax').request(`folders/${folderId}/permissions`, {
return this.get('ajax').request(`space/${folderId}/permissions`, {
method: 'PUT',
contentType: 'json',
data: JSON.stringify(payload)
@ -158,7 +156,6 @@ export default BaseService.extend({
// share this folder with new users!
share(folderId, invitation) {
return this.get('ajax').post(`folders/${folderId}/invitation`, {
contentType: 'json',
data: JSON.stringify(invitation)
@ -171,8 +168,9 @@ export default BaseService.extend({
return;
}
let folderId = folder.get('id');
this.set('currentFolder', folder);
this.get('localStorage').storeSessionItem("folder", get(folder, 'id'));
this.get('localStorage').storeSessionItem("folder", folderId);
this.set('canEditCurrentFolder', false);
let userId = this.get('sessionService.user.id');
@ -180,7 +178,7 @@ export default BaseService.extend({
userId = "0";
}
let url = `users/${userId}/permissions`;
let url = `space/${folderId}/permissions/user`;
return this.get('ajax').request(url).then((folderPermissions) => {
// safety check
@ -191,7 +189,6 @@ export default BaseService.extend({
}
let result = [];
let folderId = folder.get('id');
folderPermissions.forEach((item) => {
if (item.folderId === folderId) {