Skip to content

Commit 4475409

Browse files
refactor: changes in cloud function
1 parent e5f1524 commit 4475409

File tree

5 files changed

+67
-1
lines changed

5 files changed

+67
-1
lines changed

apps/OpenSignServer/cloud/main.js

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -58,6 +58,8 @@ import updateOrganization from './parsefunction/updateOrganization.js';
5858
import getTeams from './parsefunction/getTeams.js';
5959
import addTeam from './parsefunction/addTeam.js';
6060
import updateTeam from './parsefunction/updateTeam.js';
61+
import getOrgAdmins from './parsefunction/getOrgAdmins.js';
62+
import getAllUserTeamByOrg from './parsefunction/getAllUserTeamByOrg.js';
6163

6264
// This afterSave function triggers after an object is added or updated in the specified class, allowing for post-processing logic.
6365
Parse.Cloud.afterSave('contracts_Document', DocumentAftersave);
@@ -125,3 +127,5 @@ Parse.Cloud.define('updateorganization', updateOrganization);
125127
Parse.Cloud.define('getteams', getTeams);
126128
Parse.Cloud.define('addteam', addTeam);
127129
Parse.Cloud.define('updateteam', updateTeam);
130+
Parse.Cloud.define('getorgadmins', getOrgAdmins);
131+
Parse.Cloud.define('getalluserteambyorg', getAllUserTeamByOrg);

apps/OpenSignServer/cloud/parsefunction/addOrganization.js

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -48,6 +48,15 @@ export default async function addOrganization(request) {
4848
objectId: resExt.id,
4949
});
5050
const newResOrg = await newOrg.save(null, { useMasterKey: true });
51+
const teamCls = new Parse.Object('contracts_Teams');
52+
teamCls.set('Name', 'All Users');
53+
teamCls.set('OrganizationId', {
54+
__type: 'Pointer',
55+
className: 'contracts_Organizations',
56+
objectId: newResOrg.id,
57+
});
58+
teamCls.set('IsActive', true);
59+
await teamCls.save(null, { useMasterKey: true });
5160
if (newResOrg) {
5261
return newResOrg;
5362
}
Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
export default async function getAllUserTeamByOrg(request) {
2+
const OrgId = request.params.orgId;
3+
if (!request?.user) {
4+
throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'User is not authenticated.');
5+
}
6+
try {
7+
const teamCls = new Parse.Query('contracts_Teams');
8+
teamCls.equalTo('OrganizationId', {
9+
__type: 'Pointer',
10+
className: 'contracts_Organizations',
11+
objectId: OrgId,
12+
});
13+
teamCls.equalTo('IsActive', true);
14+
const teamRes = await teamCls.first({ useMasterKey: true });
15+
if (teamRes) {
16+
return teamRes;
17+
} else {
18+
throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Team not found.');
19+
}
20+
} catch (err) {
21+
console.log('err in getOrganizations', err);
22+
const code = err?.code || 400;
23+
const msg = err?.message || 'Something went wrong.';
24+
throw new Parse.Error(code, msg);
25+
}
26+
}
Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
export default async function getOrgAdmins(req) {
2+
if (!req?.user) {
3+
throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'User is not authenticated.');
4+
} else {
5+
try {
6+
const extUser = new Parse.Query('contracts_Users');
7+
extUser.equalTo('UserRole', 'contracts_OrgAdmin');
8+
extUser.equalTo('CreatedBy', req?.user);
9+
extUser.notEqualTo('UserId', req?.user);
10+
extUser.include('TeamIds,OrganizationId');
11+
extUser.descending('createdAt');
12+
const userRes = await extUser.find({ useMasterKey: true });
13+
if (userRes.length > 0) {
14+
const _userRes = JSON.parse(JSON.stringify(userRes));
15+
return _userRes;
16+
} else {
17+
return [];
18+
}
19+
} catch (err) {
20+
console.log('err in getOrgAdmins', err);
21+
throw err;
22+
}
23+
}
24+
}

apps/OpenSignServer/cloud/parsefunction/getOrganizations.js

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@ export default async function getOrganizations(request) {
22
const limit = request.params.limit || 200;
33
const skip = request.params.skip || 0;
44
const extUserId = request.params.extUserId;
5+
const activeOrgs = request.params.active;
56
if (!request?.user) {
67
throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'User is not authenticated.');
78
}
@@ -17,7 +18,9 @@ export default async function getOrganizations(request) {
1718
className: 'contracts_Users',
1819
objectId: extUserId,
1920
});
20-
orgQuery.equalTo('IsActive', true);
21+
if (activeOrgs) {
22+
orgQuery.equalTo('IsActive', true);
23+
}
2124
orgQuery.exclude('ExtUserId');
2225
orgQuery.limit(limit);
2326
orgQuery.skip(skip);

0 commit comments

Comments
 (0)