Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature to delete workspace #378

Open
wants to merge 46 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 33 commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
fadd6e2
resolver added
robonetphy Oct 26, 2021
685d067
mutation added in defination
robonetphy Oct 26, 2021
4930cb9
api added
robonetphy Oct 26, 2021
e748e47
Merge branch 'master' into feature/delete/workspace
robonetphy Oct 26, 2021
b4ea989
Bump version up to 1.0.6
github-actions[bot] Oct 26, 2021
391dc51
Merge branch 'master' into feature/delete/workspace
robonetphy Oct 31, 2021
c724783
Bump version up to 1.0.7
github-actions[bot] Oct 31, 2021
a62bab1
delete workspace added
robonetphy Oct 31, 2021
62bce74
Merge branch 'feature/delete/workspace' of https://github.com/codex-t…
robonetphy Oct 31, 2021
3df315c
the is removed added
robonetphy Nov 3, 2021
305189b
lint removed
robonetphy Nov 3, 2021
c35832c
workspace and project removal undo
robonetphy Nov 4, 2021
d28e394
lint removed
robonetphy Nov 4, 2021
25cdd04
the logic modified
robonetphy Nov 4, 2021
30557c6
the schema modified
robonetphy Nov 4, 2021
d610da5
linting added
robonetphy Nov 4, 2021
c5e77f8
delete project collection in added
robonetphy Nov 4, 2021
f4b9d17
lint removed
robonetphy Nov 4, 2021
560fd03
remove workspace using isRemoved flag
robonetphy Nov 14, 2021
8361c89
remove project using isRemoved flag
robonetphy Nov 14, 2021
65722da
remove deletion of projectToWorkspace Relation
robonetphy Nov 14, 2021
5115652
remove workspace from user using isRemoved flag
robonetphy Nov 14, 2021
1b9b7c3
integration with the delete workspace
robonetphy Nov 14, 2021
e9b802c
lint removed
robonetphy Nov 14, 2021
6af6203
rename the functions
robonetphy Nov 19, 2021
e2f0af3
lint removed
robonetphy Nov 19, 2021
ac47016
$ne=>$exists
robonetphy Dec 7, 2021
f7f0c50
remove teamcollection dropping
robonetphy Dec 7, 2021
4e4fa39
not delete the event factories
robonetphy Dec 7, 2021
0a69fa6
removed lint and event factory
robonetphy Dec 7, 2021
df25814
Merge branch 'master' into feature/delete/workspace
robonetphy Dec 20, 2021
628a86e
Bump version up to 1.0.8
github-actions[bot] Dec 20, 2021
f116fc2
forbidden error remove and replace with return flag
robonetphy Jan 19, 2022
430e4f6
Merge branch 'master' of https://github.com/codex-team/hawk.api.nodej…
neSpecc Jan 21, 2022
bc244c2
remove isAdmin from deleteworkspace
robonetphy Jan 28, 2022
f192ccc
update data loader with not to get isRemoved filed
robonetphy Feb 1, 2022
20c75ce
join by link and invitation link function updated
robonetphy Feb 1, 2022
ee773b8
jsdocs warning resolved
robonetphy Feb 1, 2022
56cb42b
Merge branch 'master' into feature/delete/workspace
robonetphy Feb 1, 2022
b37dfc8
Bump version up to 1.0.9
github-actions[bot] Feb 1, 2022
8d645a1
Merge branch 'master' into feature/delete/workspace
robonetphy Feb 15, 2022
52c2658
Bump version up to 1.0.10
github-actions[bot] Feb 15, 2022
2e99fbd
Merge branch 'master' into feature/delete/workspace
robonetphy Feb 16, 2022
bf1c901
lint removed
robonetphy Feb 16, 2022
cfd7499
Merge branch 'master' into feature/delete/workspace
robonetphy Dec 25, 2022
375d4da
Bump version up to 1.0.23
github-actions[bot] Dec 25, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "hawk.api",
"version": "1.0.7",
"version": "1.0.8",
"main": "index.ts",
"license": "UNLICENSED",
"scripts": {
Expand Down
20 changes: 20 additions & 0 deletions src/models/project.ts
Original file line number Diff line number Diff line change
Expand Up @@ -383,4 +383,24 @@ export default class ProjectModel extends AbstractModel<ProjectDBScheme> impleme
console.log(error);
}
}

/**
* Mark project as removed.
*/
public async markProjectAsRemoved(): Promise<void> {
await this.collection.updateOne({ _id: this._id }, {
$set: { isRemoved: true },
});

try {
/**
* Remove users in project collection
*/
await this.dbConnection.collection('users-in-project:' + this._id)
.drop();
} catch (error) {
console.log(`Can't remove collection "users-in-project:${this._id}" because it doesn't exist.`);
console.log(error);
}
}
}
26 changes: 24 additions & 2 deletions src/models/user.ts
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ export interface UserNotificationsDBScheme {
/**
* Types of notifications to receive
*/
whatToReceive: {[key in UserNotificationType]: boolean};
whatToReceive: { [key in UserNotificationType]: boolean };
}

/**
Expand Down Expand Up @@ -317,7 +317,7 @@ export default class UserModel extends AbstractModel<UserDBScheme> implements Us
* Remove workspace from membership collection
* @param workspaceId - id of workspace to remove
*/
public async removeWorkspace(workspaceId: string): Promise<{workspaceId: string}> {
public async removeWorkspace(workspaceId: string): Promise<{ workspaceId: string }> {
await this.membershipCollection.deleteOne({
workspaceId: new ObjectId(workspaceId),
});
Expand All @@ -327,6 +327,22 @@ export default class UserModel extends AbstractModel<UserDBScheme> implements Us
};
}

/**
* Mark workspace as removed.
* @param workspaceId - id of workspace to remove
*/
public async markWorkspaceAsRemoved(workspaceId: string): Promise<{ workspaceId: string }> {
await this.membershipCollection.updateOne({
workspaceId: new ObjectId(workspaceId),
}, {
$set: { isRemoved: true },
});

return {
workspaceId,
};
}

/**
* Confirm membership of workspace by id
* @param workspaceId - workspace id to confirm
Expand All @@ -351,10 +367,16 @@ export default class UserModel extends AbstractModel<UserDBScheme> implements Us
workspaceId: {
$in: idsAsObjectId,
},
isRemoved: {
$ne: true,
},
isPending: {
$ne: true,
},
} : {
isRemoved: {
$ne: true,
},
isPending: {
$ne: true,
},
Expand Down
14 changes: 14 additions & 0 deletions src/models/workspace.ts
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,20 @@ export default class WorkspaceModel extends AbstractModel<WorkspaceDBScheme> imp
}
}

/**
* Mark workspace as removed.
*/
public async markWorkspaceAsRemoved(): Promise<void> {
/**
* Delete the workspace data.
*/
await this.collection.updateOne({
_id: new ObjectId(this._id),
}, {
$set: { isRemoved: true },
});
}

/**
* Update invite hash of workspace
* @param inviteHash - new invite hash
Expand Down
58 changes: 55 additions & 3 deletions src/resolvers/workspace.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import ProjectToWorkspace from '../models/projectToWorkspace';
import Validator from '../utils/validator';
import { dateFromObjectId } from '../utils/dates';

const { ApolloError, UserInputError, ForbiddenError } = require('apollo-server-express');
const { ApolloError, UserInputError } = require('apollo-server-express');
const crypto = require('crypto');

/**
Expand Down Expand Up @@ -301,7 +301,7 @@ module.exports = {
* @param {string} workspaceId - id of the workspace where the user should be removed
* @param {UserInContext} user - current authorized user {@see ../index.js}
* @param {ContextFactories} factories - factories for working with models
* @return {Promise<boolean>} - true if operation is successful
* @return {Promise<boolean>} - true if operation is successful, false if there is no other admin left.
*/
async leaveWorkspace(_obj, { workspaceId }, { user, factories }) {
const userModel = await factories.usersFactory.findById(user.id);
Expand All @@ -320,14 +320,66 @@ module.exports = {
);

if (!isThereOtherAdmins) {
throw new ForbiddenError('You can\'t leave this workspace because you are the last admin');
return false;
}
}
await workspaceModel.removeMember(userModel);

return true;
},

/**
* Mutation in order to leave workspace
* @param {ResolverObj} _obj - object that contains the result returned from the resolver on the parent field
* @param {string} workspaceId - id of the workspace where the user should be removed
* @param {UserInContext} user - current authorized user {@see ../index.js}
* @param {ContextFactories} factories - factories for working with models
* @return {Promise<boolean>} - true if operation is successful
*/
async deleteWorkspace(_obj, { workspaceId }, { user, factories }) {
const workspaceModel = await factories.workspacesFactory.findById(workspaceId);

if (!workspaceModel) {
throw new UserInputError('There is no workspace with provided id');
}

const memberInfo = await workspaceModel.getMemberInfo(user.id);

/**
* Return if user is not Admin.
*/
if (!memberInfo.isAdmin) {
robonetphy marked this conversation as resolved.
Show resolved Hide resolved
return false;
}

const membersInfo = (await workspaceModel.getMembers());

for (const member of membersInfo) {
const userModel = await factories.usersFactory.findById(member.userId.toString());
robonetphy marked this conversation as resolved.
Show resolved Hide resolved

await userModel.markWorkspaceAsRemoved(workspaceId.toString());
}

const projectToWorkspace = new ProjectToWorkspace(workspaceId.toString());

const projectsInfo = await projectToWorkspace.getProjects();

if (projectsInfo.length) {
for (const project of projectsInfo) {
/**
* Remove project
*/
const projectModel = await factories.projectsFactory.findById(project.id.toString());

await projectModel.markProjectAsRemoved();
robonetphy marked this conversation as resolved.
Show resolved Hide resolved
}
}

await workspaceModel.markWorkspaceAsRemoved();

return true;
},

/**
* Change workspace plan for default plan mutation implementation
*
Expand Down
12 changes: 12 additions & 0 deletions src/typeDefs/workspace.ts
Original file line number Diff line number Diff line change
Expand Up @@ -268,12 +268,24 @@ export default gql`
"""
Mutation in order to leave workspace
Returns true if operation is successful
Returns false if there is no other admin lefts
"""
leaveWorkspace(
"""
Workspace ID
"""
workspaceId: ID!
): Boolean! @requireAuth

"""
Mutation in order to delete workspace
Returns true if operation is successful
"""
deleteWorkspace(
"""
Workspace ID
"""
workspaceId: ID!
): Boolean! @requireAdmin
}
`;