aboutsummaryrefslogtreecommitdiffstats
path: root/start
diff options
context:
space:
mode:
authorLibravatar MCMXC <16797721+mcmxcdev@users.noreply.github.com>2024-02-10 18:19:14 -0700
committerLibravatar Vijay A <vraravam@users.noreply.github.com>2024-02-13 06:59:44 +0530
commit7584d2d7a7110aef0331ebfa178b2295842c59fa (patch)
tree900cd71237e6231b57936fcce77ff229cd459041 /start
parentupgrade recipes submodule (diff)
downloadferdium-server-7584d2d7a7110aef0331ebfa178b2295842c59fa.tar.gz
ferdium-server-7584d2d7a7110aef0331ebfa178b2295842c59fa.tar.zst
ferdium-server-7584d2d7a7110aef0331ebfa178b2295842c59fa.zip
refactor: project maintenance
- work in progress
Diffstat (limited to 'start')
-rw-r--r--start/env.ts24
-rw-r--r--start/events.ts20
-rw-r--r--start/kernel.ts10
-rw-r--r--start/routes.ts4
-rw-r--r--start/routes/api.ts82
-rw-r--r--start/routes/web.ts104
6 files changed, 136 insertions, 108 deletions
diff --git a/start/env.ts b/start/env.ts
new file mode 100644
index 0000000..3e1702e
--- /dev/null
+++ b/start/env.ts
@@ -0,0 +1,24 @@
1/*
2|--------------------------------------------------------------------------
3| Validating Environment Variables
4|--------------------------------------------------------------------------
5|
6| In this file we define the rules for validating environment variables.
7| By performing validation we ensure that your application is running in
8| a stable environment with correct configuration values.
9|
10| This file is read automatically by the framework during the boot lifecycle
11| and hence do not rename or move this file to a different location.
12|
13*/
14import { Env } from '@adonisjs/core/env'
15
16export default await Env.create(new URL('../', import.meta.url), {
17 HOST: Env.schema.string({ format: 'host' }),
18 PORT: Env.schema.number(),
19
20 APP_KEY: Env.schema.string(),
21 APP_NAME: Env.schema.string(),
22
23 NODE_ENV: Env.schema.enum(['development', 'production', 'test'] as const),
24})
diff --git a/start/events.ts b/start/events.ts
index 11e63e5..faedc29 100644
--- a/start/events.ts
+++ b/start/events.ts
@@ -1,6 +1,6 @@
1import Config from '@ioc:Adonis/Core/Config'; 1import { Config } from '@adonisjs/core/config'
2import Event from '@ioc:Adonis/Core/Event'; 2import emitter from '@adonisjs/core/services/emitter'
3import Mail from '@ioc:Adonis/Addons/Mail'; 3import mail from '@adonisjs/mail/services/main'
4 4
5/* 5/*
6|-------------------------------------------------------------------------- 6|--------------------------------------------------------------------------
@@ -11,11 +11,11 @@ import Mail from '@ioc:Adonis/Addons/Mail';
11| boot. 11| boot.
12| 12|
13*/ 13*/
14Event.on('forgot::password', async ({ user, token }) => { 14emitter.on('forgot::password', async ({ user, token }) => {
15 try { 15 try {
16 // eslint-disable-next-line no-console 16 // eslint-disable-next-line no-console
17 console.log('Sending message'); 17 console.log('Sending message')
18 await Mail.send(message => { 18 await mail.send((message) => {
19 message 19 message
20 .subject('[Ferdium] Forgot Password') 20 .subject('[Ferdium] Forgot Password')
21 .to(user.email) 21 .to(user.email)
@@ -24,10 +24,10 @@ Event.on('forgot::password', async ({ user, token }) => {
24 appUrl: Config.get('app.url'), 24 appUrl: Config.get('app.url'),
25 username: user.username, 25 username: user.username,
26 token, 26 token,
27 }); 27 })
28 }); 28 })
29 } catch (error) { 29 } catch (error) {
30 // eslint-disable-next-line no-console 30 // eslint-disable-next-line no-console
31 console.log(`Couldn't send mail: ${error}`); 31 console.log(`Couldn't send mail: ${error}`)
32 } 32 }
33}); 33})
diff --git a/start/kernel.ts b/start/kernel.ts
index 1c5c92b..99a0820 100644
--- a/start/kernel.ts
+++ b/start/kernel.ts
@@ -9,7 +9,7 @@
9| 9|
10*/ 10*/
11 11
12import Server from '@ioc:Adonis/Core/Server'; 12import { server } from '@adonisjs/core/services/server'
13 13
14/* 14/*
15|-------------------------------------------------------------------------- 15|--------------------------------------------------------------------------
@@ -20,10 +20,10 @@ import Server from '@ioc:Adonis/Core/Server';
20| are defined for every HTTP requests. 20| are defined for every HTTP requests.
21| 21|
22*/ 22*/
23Server.middleware.register([ 23server.middleware.register([
24 () => import('@ioc:Adonis/Core/BodyParser'), 24 () => import('@ioc:Adonis/Core/BodyParser'),
25 () => import('@ioc:Adonis/Addons/Shield'), 25 () => import('@ioc:Adonis/Addons/Shield'),
26]); 26])
27 27
28/* 28/*
29|-------------------------------------------------------------------------- 29|--------------------------------------------------------------------------
@@ -41,9 +41,9 @@ Server.middleware.register([
41| Route.get('dashboard', 'UserController.dashboard').middleware('auth') 41| Route.get('dashboard', 'UserController.dashboard').middleware('auth')
42| 42|
43*/ 43*/
44Server.middleware.registerNamed({ 44server.middleware.registerNamed({
45 auth: () => import('App/Middleware/Auth'), 45 auth: () => import('App/Middleware/Auth'),
46 dashboard: () => import('App/Middleware/Dashboard'), 46 dashboard: () => import('App/Middleware/Dashboard'),
47 guest: () => import('App/Middleware/AllowGuestOnly'), 47 guest: () => import('App/Middleware/AllowGuestOnly'),
48 shield: () => import('@ioc:Adonis/Addons/Shield'), 48 shield: () => import('@ioc:Adonis/Addons/Shield'),
49}); 49})
diff --git a/start/routes.ts b/start/routes.ts
index 75cef72..7c62909 100644
--- a/start/routes.ts
+++ b/start/routes.ts
@@ -18,5 +18,5 @@
18| 18|
19*/ 19*/
20 20
21import './routes/api'; 21import './routes/api.js'
22import './routes/web'; 22import './routes/web.js'
diff --git a/start/routes/api.ts b/start/routes/api.ts
index 78282f0..8992154 100644
--- a/start/routes/api.ts
+++ b/start/routes/api.ts
@@ -1,51 +1,47 @@
1// As this is currently a rebuild of the initial API we it is grouped in /v2/ 1// As this is currently a rebuild of the initial API we it is grouped in /v2/
2 2
3import Route from '@ioc:Adonis/Core/Route'; 3import router from '@adonisjs/core/services/router'
4const UserController = () => import('#controllers/Http/UserController')
5const ServiceController = () => import('#controllers/Http/ServiceController')
6const RecipeController = () => import('#controllers/Http/RecipeController')
4 7
5Route.group(() => { 8router
6 // User authentification 9 .group(() => {
7 Route.post('auth/signup', 'UserController.signup').middleware('guest'); 10 // User authentification
8 Route.post('auth/login', 'UserController.login').middleware('guest'); 11 router.post('auth/signup', [UserController, 'signup']).middleware('guest')
12 router.post('auth/login', [UserController, 'login']).middleware('guest')
9 13
10 // User info 14 // User info
11 Route.get('me', 'UserController.me').middleware('auth:jwt'); 15 router.get('me', [UserController, 'me']).middleware('auth:jwt')
12 Route.put('me', 'UserController.updateMe').middleware('auth:jwt'); 16 router.put('me', [UserController, 'updateMe']).middleware('auth:jwt')
13 Route.get('me/newtoken', 'UserController.newToken').middleware('auth:jwt'); 17 router.get('me/newtoken', [UserController, 'newToken']).middleware('auth:jwt')
14 18
15 // // Service info 19 // // Service info
16 Route.post('service', 'ServiceController.create').middleware('auth:jwt'); 20 router.post('service', [ServiceController, 'create']).middleware('auth:jwt')
17 Route.put('service/reorder', 'ServiceController.reorder').middleware( 21 router.put('service/reorder', [ServiceController, 'reorder']).middleware('auth:jwt')
18 'auth:jwt', 22 router.put('service/:id', [ServiceController, 'edit']).middleware('auth:jwt')
19 ); 23 router.delete('service/:id', [ServiceController, 'delete']).middleware('auth:jwt')
20 Route.put('service/:id', 'ServiceController.edit').middleware('auth:jwt'); 24 router.get('me/services', [ServiceController, 'list']).middleware('auth:jwt')
21 Route.delete('service/:id', 'ServiceController.delete').middleware( 25 router.get('recipe', [ServiceController, 'list']).middleware('auth:jwt')
22 'auth:jwt', 26 router.get('icon/:id', [ServiceController, 'icon'])
23 );
24 Route.get('me/services', 'ServiceController.list').middleware('auth:jwt');
25 Route.get('recipe', 'ServiceController.list').middleware('auth:jwt');
26 Route.get('icon/:id', 'ServiceController.icon');
27 27
28 // Recipe store 28 // Recipe store
29 Route.get('recipes', 'RecipeController.list'); 29 router.get('recipes', [RecipeController, 'list'])
30 Route.get('recipes/search', 'RecipeController.search'); 30 router.get('recipes/search', [RecipeController, 'search'])
31 Route.get('recipes/popular', 'RecipeController.popularRecipes'); 31 router.get('recipes/popular', [RecipeController, 'popularRecipes'])
32 Route.get('recipes/download/:recipe', 'RecipeController.download'); 32 router.get('recipes/download/:recipe', [RecipeController, 'download'])
33 Route.post('recipes/update', 'RecipeController.update'); 33 router.post('recipes/update', [RecipeController, 'update'])
34 34
35 // // Workspaces 35 // // Workspaces
36 Route.put('workspace/:id', 'WorkspaceController.edit').middleware('auth:jwt'); 36 router.put('workspace/:id', 'WorkspaceController.edit').middleware('auth:jwt')
37 Route.delete('workspace/:id', 'WorkspaceController.delete').middleware( 37 router.delete('workspace/:id', 'WorkspaceController.delete').middleware('auth:jwt')
38 'auth:jwt', 38 router.post('workspace', 'WorkspaceController.create').middleware('auth:jwt')
39 ); 39 router.get('workspace', 'WorkspaceController.list').middleware('auth:jwt')
40 Route.post('workspace', 'WorkspaceController.create').middleware('auth:jwt');
41 Route.get('workspace', 'WorkspaceController.list').middleware('auth:jwt');
42 40
43 // Static responses 41 // Static responses
44 Route.get('features/:mode?', 'Api/Static/FeaturesController.show'); 42 router.get('features/:mode?', 'Api/Static/FeaturesController.show')
45 Route.get('services', 'Api/Static/EmptyController.show'); 43 router.get('services', 'Api/Static/EmptyController.show')
46 Route.get('news', 'Api/Static/EmptyController.show'); 44 router.get('news', 'Api/Static/EmptyController.show')
47 Route.get( 45 router.get('announcements/:version', 'Api/Static/AnnouncementsController.show')
48 'announcements/:version', 46 })
49 'Api/Static/AnnouncementsController.show', 47 .prefix('/v1')
50 );
51}).prefix('/v1');
diff --git a/start/routes/web.ts b/start/routes/web.ts
index 308abec..fd12bf2 100644
--- a/start/routes/web.ts
+++ b/start/routes/web.ts
@@ -1,54 +1,62 @@
1import Route from '@ioc:Adonis/Core/Route'; 1import router from '@adonisjs/core/services/router'
2 2
3// Health check 3// Health check
4Route.get('health', 'HealthController.index'); 4router.get('health', 'HealthController.index')
5 5
6// Legal documents 6// Legal documents
7Route.get('terms', ({ response }) => response.redirect('/terms.html')); 7router.get('terms', ({ response }) => response.redirect('/terms.html'))
8Route.get('privacy', ({ response }) => response.redirect('/privacy.html')); 8router.get('privacy', ({ response }) => response.redirect('/privacy.html'))
9 9
10// Index 10// Index
11Route.get('/', ({ view }) => view.render('others/index')); 11router.get('/', ({ view }) => view.render('others/index'))
12 12
13Route.group(() => { 13router
14 Route.group(() => { 14 .group(() => {
15 // Guest troutes 15 router
16 Route.group(() => { 16 .group(() => {
17 Route.get('login', 'Dashboard/LoginController.show'); 17 // Guest troutes
18 Route.post('login', 'Dashboard/LoginController.login').as('login'); 18 router
19 19 .group(() => {
20 // Reset password 20 router.get('login', 'Dashboard/LoginController.show')
21 Route.get('forgot', 'Dashboard/ForgotPasswordController.show'); 21 router.post('login', 'Dashboard/LoginController.login').as('login')
22 Route.post('forgot', 'Dashboard/ForgotPasswordController.forgotPassword'); 22
23 23 // Reset password
24 Route.get('reset', 'Dashboard/ResetPasswordController.show'); 24 router.get('forgot', 'Dashboard/ForgotPasswordController.show')
25 Route.post('reset', 'Dashboard/ResetPasswordController.resetPassword'); 25 router.post('forgot', 'Dashboard/ForgotPasswordController.forgotPassword')
26 }).middleware(['dashboard', 'guest']); 26
27 27 router.get('reset', 'Dashboard/ResetPasswordController.show')
28 // Authenticated routes 28 router.post('reset', 'Dashboard/ResetPasswordController.resetPassword')
29 Route.group(() => { 29 })
30 Route.get('account', 'Dashboard/AccountController.show'); 30 .middleware(['dashboard', 'guest'])
31 Route.post('account', 'Dashboard/AccountController.store'); 31
32 32 // Authenticated routes
33 Route.get('data', 'Dashboard/DataController.show'); 33 router
34 Route.get('export', 'Dashboard/ExportController.show'); 34 .group(() => {
35 35 router.get('account', 'Dashboard/AccountController.show')
36 Route.get('transfer', 'Dashboard/TransferController.show'); 36 router.post('account', 'Dashboard/AccountController.store')
37 Route.post('transfer', 'Dashboard/TransferController.import'); 37
38 38 router.get('data', 'Dashboard/DataController.show')
39 Route.get('delete', 'Dashboard/DeleteController.show'); 39 router.get('export', 'Dashboard/ExportController.show')
40 Route.post('delete', 'Dashboard/DeleteController.delete'); 40
41 41 router.get('transfer', 'Dashboard/TransferController.show')
42 Route.get('logout', 'Dashboard/LogOutController.logout'); 42 router.post('transfer', 'Dashboard/TransferController.import')
43 43
44 Route.get('*', ({ response }) => response.redirect('/user/account')); 44 router.get('delete', 'Dashboard/DeleteController.show')
45 }).middleware(['dashboard', 'auth:web']); 45 router.post('delete', 'Dashboard/DeleteController.delete')
46 }).prefix('user'); 46
47 47 router.get('logout', 'Dashboard/LogOutController.logout')
48 // Franz/Ferdi account import 48
49 Route.get('import', ({ view }) => view.render('others/import')); 49 router.get('*', ({ response }) => response.redirect('/user/account'))
50 Route.post('import', 'UserController.import'); 50 })
51 51 .middleware(['dashboard', 'auth:web'])
52 // 404 handler 52 })
53 Route.get('/*', ({ response }) => response.redirect('/')); 53 .prefix('user')
54}).middleware(['dashboard']); 54
55 // Franz/Ferdi account import
56 router.get('import', ({ view }) => view.render('others/import'))
57 router.post('import', 'UserController.import')
58
59 // 404 handler
60 router.get('/*', ({ response }) => response.redirect('/'))
61 })
62 .middleware(['dashboard'])