aboutsummaryrefslogtreecommitdiffstats
path: root/app/Controllers/Http/WorkspaceController.js
diff options
context:
space:
mode:
authorLibravatar Ricardo <ricardo@cino.io>2023-10-13 14:12:03 +0200
committerLibravatar GitHub <noreply@github.com>2023-10-13 13:12:03 +0100
commite503468660a13760010a94ecda5f0625c6f47f87 (patch)
treefa532f54fc5f091de08d55405ec6339bd2440a02 /app/Controllers/Http/WorkspaceController.js
parent1.3.16 [skip ci] (diff)
downloadferdium-server-e503468660a13760010a94ecda5f0625c6f47f87.tar.gz
ferdium-server-e503468660a13760010a94ecda5f0625c6f47f87.tar.zst
ferdium-server-e503468660a13760010a94ecda5f0625c6f47f87.zip
Server re-build with latest AdonisJS framework & Typescript (#47)
* chore: setup first basis structure * chore: ensure styling is loaded correctly * chore: comply to new routing syntax by replace . with / in routes/resource locations * chore: add login controller * chore: correctly use views with slash instead of dot * chore: working login + tests * chore: clean up tests * chore: add password-forgot endpoint and matching test * chore: add delete page test * chore: add logout test * chore: add reset-password route and tests * chore: remove obsolete comment * chore: add account-page and tests * chore: add data page & first step of the test * chore: add transfer/import data feature and tests * chore: add export and basic test * chore: add all static api routes with tests * Regenerate 'pnpm-lock.json' and fix bad merge conflict WIP: - Tests have been commented out since they dont work - Server doesn't start * easier dev and test runs * - remove --require-pragma from reformat-files so formatting works properly - run pnpm reformat-files over codebase - remove .json files from .eslintignore - add invalid.json file to .eslintignore - configure prettier properly in eslint config - add type jsdoc to prettier config - run adonis generate:manifest command to regenerate ace-manifest.json - specify volta in package.json - introduce typecheck npm script - remove unused .mjs extension from npm scripts - install missing type definition dependencies - add pnpm.allowedDeprecatedVersions to package.json - fix invalid extends in tsconfig.json causing TS issues throughout codebase - remove @ts-ignore throughout codebase which is not relevant anymore - enable some of the tsconfig options - remove outdated eslint-disable from codebase - change deprecated faker.company.companyName() to faker.company.name() - fix TS issues inside transfer.spec.ts * - update to latest node and pnpm versions - upgrade all non-major dependencies to latest - install missing @types/luxon dependency - add cuid to pnpm.allowedDeprecatedVersions - add esModuleInterop config option to tsconfig - migrate more deprecated faker methods to new ones - add more temporary ts-ignore to code * - update eslint config - remove trailingComma: all since default in prettier v3 - add typecheck command to prepare-code npm script - upgrade various dependencies to latest major version - update tsconfig to include only useful config options - disable some lint issues and fix others * - add test command to prepare-code - disable strictPropertyInitialization flag in tsconfig which creates issues with adonis models - update precommit hook to excute pnpm prepare-code - remove ts-ignore statements from all models * fix node and pnpm dependency update * add cross env (so that we can develop on windows) * add signup endpoint (TODO: JWT auth) * Add login endpoint * Add me and updateMe endpoints * Add service endpoint * refactor: change endpoints to use jwt * add recipes endpoint * add workspaces endpoint * fix web controllors for login and post import * Update node deps * Change auth middleware (for web) and exempt api from CSRF * Add import endpoint (franz import) * Fix export/import logic * Fix service and workspace data in user/data * Fix partial lint * chore: workaround lint issues * fix: migration naming had two . * Sync back node with recipes repo * Temporarily ignore typescript * Fix adonisrc to handle public folder static assets * Fix issue with production database * add Legacy Password Provider * Fix lint errors * Fix issue on login errors frontend * add Legacy Password Provider * Fix issue with customIcons * Fix issue with auth tokens * Update 'node' to '18.18.0' * make docker work * improve docker entrypoint (test api performance) * Add migration database script * NODE_ENV on recipes * prefer @ts-expect-error over @ts-ignore * small fixes * Update 'pnpm' to '8.7.6' * fix error catch * Automatically generate JWT Public and Private keys * Use custom Adonis5-jwt * Update code to use secret (old way, no breaking changes) * Normalize appKey * Trick to make JWT tokens on client work with new version * Fix error with new JWT logic * Change migration and how we store JWT * Fix 500 response code (needs to be 401) * Improve logic and fix bugs * Fix build and entrypoint logic * Catch error if appKey changes * Add newToken logic * Fix lint (ignore any errors) * Add build for PRs * pnpm reformat-files result * Fix some tests * Fix reset password not working (test failing) * Restore csrfTokens (disabled by accident) * Fix pnpm start command with .env * Disable failing tests on the transfer endpoint (TODO) * Add tests to PR build * Fix build * Remove unnecessary assertStatus * Add typecheck * hash password on UserFactory (fix build) * Add JWT_USE_PEM true by default (increase security) * fix name of github action --------- Co-authored-by: Vijay A <vraravam@users.noreply.github.com> Co-authored-by: Balaji Vijayakumar <kuttibalaji.v6@gmail.com> Co-authored-by: MCMXC <16797721+mcmxcdev@users.noreply.github.com> Co-authored-by: André Oliveira <oliveira.andrerodrigues95@gmail.com>
Diffstat (limited to 'app/Controllers/Http/WorkspaceController.js')
-rw-r--r--app/Controllers/Http/WorkspaceController.js172
1 files changed, 0 insertions, 172 deletions
diff --git a/app/Controllers/Http/WorkspaceController.js b/app/Controllers/Http/WorkspaceController.js
deleted file mode 100644
index a9c2872..0000000
--- a/app/Controllers/Http/WorkspaceController.js
+++ /dev/null
@@ -1,172 +0,0 @@
1const Workspace = use('App/Models/Workspace');
2const { validateAll } = use('Validator');
3
4const { v4: uuid } = require('uuid');
5
6class WorkspaceController {
7 // Create a new workspace for user
8 async create({ request, response, auth }) {
9 try {
10 await auth.getUser();
11 } catch (error) {
12 return response.send('Missing or invalid api token');
13 }
14
15 // Validate user input
16 const validation = await validateAll(request.all(), {
17 name: 'required',
18 });
19 if (validation.fails()) {
20 return response.status(401).send({
21 message: 'Invalid POST arguments',
22 messages: validation.messages(),
23 status: 401,
24 });
25 }
26
27 const data = request.all();
28
29 // Get new, unused uuid
30 let workspaceId;
31 do {
32 workspaceId = uuid();
33 } while (
34 (await Workspace.query().where('workspaceId', workspaceId).fetch()).rows
35 .length > 0
36 ); // eslint-disable-line no-await-in-loop
37
38 const order = (await auth.user.workspaces().fetch()).rows.length;
39
40 await Workspace.create({
41 userId: auth.user.id,
42 workspaceId,
43 name: data.name,
44 order,
45 services: JSON.stringify([]),
46 data: JSON.stringify(data),
47 });
48
49 return response.send({
50 userId: auth.user.id,
51 name: data.name,
52 id: workspaceId,
53 order,
54 workspaces: [],
55 });
56 }
57
58 async edit({ request, response, auth, params }) {
59 try {
60 await auth.getUser();
61 } catch (error) {
62 return response.send('Missing or invalid api token');
63 }
64
65 // Validate user input
66 const validation = await validateAll(request.all(), {
67 name: 'required',
68 });
69 if (validation.fails()) {
70 return response.status(401).send({
71 message: 'Invalid POST arguments',
72 messages: validation.messages(),
73 status: 401,
74 });
75 }
76
77 const data = request.all();
78 const { id } = params;
79
80 // Update data in database
81 await Workspace.query()
82 .where('workspaceId', id)
83 .where('userId', auth.user.id)
84 .update({
85 name: data.name,
86 services: JSON.stringify(data.services),
87 });
88
89 // Get updated row
90 const workspace = (
91 await Workspace.query()
92 .where('workspaceId', id)
93 .where('userId', auth.user.id)
94 .fetch()
95 ).rows[0];
96
97 return response.send({
98 id: workspace.workspaceId,
99 name: data.name,
100 order: workspace.order,
101 services: data.services,
102 userId: auth.user.id,
103 });
104 }
105
106 async delete({
107 // eslint-disable-next-line no-unused-vars
108 _request,
109 response,
110 auth,
111 params,
112 }) {
113 try {
114 await auth.getUser();
115 } catch (error) {
116 return response.send('Missing or invalid api token');
117 }
118
119 // Validate user input
120 const validation = await validateAll(params, {
121 id: 'required',
122 });
123 if (validation.fails()) {
124 return response.status(401).send({
125 message: 'Invalid arguments',
126 messages: validation.messages(),
127 status: 401,
128 });
129 }
130
131 const { id } = params;
132
133 // Update data in database
134 await Workspace.query()
135 .where('workspaceId', id)
136 .where('userId', auth.user.id)
137 .delete();
138
139 return response.send({
140 message: 'Successfully deleted workspace',
141 });
142 }
143
144 // List all workspaces a user has created
145 async list({ response, auth }) {
146 try {
147 await auth.getUser();
148 } catch (error) {
149 return response.send('Missing or invalid api token');
150 }
151
152 const workspaces = (await auth.user.workspaces().fetch()).rows;
153 // Convert to array with all data Franz wants
154 let workspacesArray = [];
155 if (workspaces) {
156 workspacesArray = workspaces.map(workspace => ({
157 id: workspace.workspaceId,
158 name: workspace.name,
159 order: workspace.order,
160 services:
161 typeof workspace.services === 'string'
162 ? JSON.parse(workspace.services)
163 : workspace.services,
164 userId: auth.user.id,
165 }));
166 }
167
168 return response.send(workspacesArray);
169 }
170}
171
172module.exports = WorkspaceController;