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:
parent
c51ba65b1d
commit
ae05cacf3f
37 changed files with 735 additions and 601 deletions
|
@ -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) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue