aboutsummaryrefslogtreecommitdiffstats
path: root/types
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 /types
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 'types')
-rw-r--r--types/auth.ts103
-rw-r--r--types/drive.ts13
-rw-r--r--types/events.ts33
-rw-r--r--types/tests.ts19
4 files changed, 168 insertions, 0 deletions
diff --git a/types/auth.ts b/types/auth.ts
new file mode 100644
index 0000000..9761ea5
--- /dev/null
+++ b/types/auth.ts
@@ -0,0 +1,103 @@
1/**
2 * Contract source: https://git.io/JOdz5
3 *
4 * Feel free to let us know via PR, if you find something broken in this
5 * file.
6 */
7
8import User from '#app/Models/User'
9import { JWTGuardConfig, JWTGuardContract } from '@ioc:Adonis/Addons/Jwt'
10
11declare module '@ioc:Adonis/Addons/Auth' {
12 /*
13 |--------------------------------------------------------------------------
14 | Providers
15 |--------------------------------------------------------------------------
16 |
17 | The providers are used to fetch users. The Auth module comes pre-bundled
18 | with two providers that are `Lucid` and `Database`. Both uses database
19 | to fetch user details.
20 |
21 | You can also create and register your own custom providers.
22 |
23 */
24 interface ProvidersList {
25 /*
26 |--------------------------------------------------------------------------
27 | User Provider
28 |--------------------------------------------------------------------------
29 |
30 | The following provider uses Lucid models as a driver for fetching user
31 | details from the database for authentication.
32 |
33 | You can create multiple providers using the same underlying driver with
34 | different Lucid models.
35 |
36 */
37 user: {
38 implementation: LucidProviderContract<typeof User>
39 config: LucidProviderConfig<typeof User>
40 }
41 }
42
43 /*
44 |--------------------------------------------------------------------------
45 | Guards
46 |--------------------------------------------------------------------------
47 |
48 | The guards are used for authenticating users using different drivers.
49 | The auth module comes with 3 different guards.
50 |
51 | - SessionGuardContract
52 | - BasicAuthGuardContract
53 | - OATGuardContract ( Opaque access token )
54 |
55 | Every guard needs a provider for looking up users from the database.
56 |
57 */
58 interface GuardsList {
59 /*
60 |--------------------------------------------------------------------------
61 | Web Guard
62 |--------------------------------------------------------------------------
63 |
64 | The web guard uses sessions for maintaining user login state. It uses
65 | the `user` provider for fetching user details.
66 |
67 */
68 web: {
69 implementation: SessionGuardContract<'user', 'web'>
70 config: SessionGuardConfig<'user'>
71 }
72 /*
73 |--------------------------------------------------------------------------
74 | OAT Guard
75 |--------------------------------------------------------------------------
76 |
77 | OAT, stands for (Opaque access tokens) guard uses database backed tokens
78 | to authenticate requests.
79 |
80 */
81 api: {
82 implementation: OATGuardContract<'user', 'api'>
83 config: OATGuardConfig<'user'>
84 }
85 /*
86 |--------------------------------------------------------------------------
87 | Basic Auth Guard
88 |--------------------------------------------------------------------------
89 |
90 | The basic guard uses basic auth for maintaining user login state. It uses
91 | the `user` provider for fetching user details.
92 |
93 */
94 basic: {
95 implementation: BasicAuthGuardContract<'user', 'basic'>
96 config: BasicAuthGuardConfig<'user'>
97 }
98 jwt: {
99 implementation: JWTGuardContract<'user', 'api'>
100 config: JWTGuardConfig<'user'>
101 }
102 }
103}
diff --git a/types/drive.ts b/types/drive.ts
new file mode 100644
index 0000000..0ad668e
--- /dev/null
+++ b/types/drive.ts
@@ -0,0 +1,13 @@
1/**
2 * Contract source: https://git.io/JBt3I
3 *
4 * Feel free to let us know via PR, if you find something broken in this contract
5 * file.
6 */
7
8import { InferDisksFromConfig } from '@adonisjs/core/build/config'
9import driveConfig from '../config/drive.js'
10
11declare module '@ioc:Adonis/Core/Drive' {
12 interface DisksList extends InferDisksFromConfig<typeof driveConfig> {}
13}
diff --git a/types/events.ts b/types/events.ts
new file mode 100644
index 0000000..91be5b4
--- /dev/null
+++ b/types/events.ts
@@ -0,0 +1,33 @@
1/**
2 * Contract source: https://git.io/JfefG
3 *
4 * Feel free to let us know via PR, if you find something broken in this contract
5 * file.
6 */
7
8import User from '#app/Models/User'
9
10declare module '@ioc:Adonis/Core/Event' {
11 /*
12 |--------------------------------------------------------------------------
13 | Define typed events
14 |--------------------------------------------------------------------------
15 |
16 | You can define types for events inside the following interface and
17 | AdonisJS will make sure that all listeners and emit calls adheres
18 | to the defined types.
19 |
20 | For example:
21 |
22 | interface EventsList {
23 | 'new:user': UserModel
24 | }
25 |
26 | Now calling `Event.emit('new:user')` will statically ensure that passed value is
27 | an instance of the the UserModel only.
28 |
29 */
30 interface EventsList {
31 'forgot:password': { user: User; token: string }
32 }
33}
diff --git a/types/tests.ts b/types/tests.ts
new file mode 100644
index 0000000..9be30fc
--- /dev/null
+++ b/types/tests.ts
@@ -0,0 +1,19 @@
1/**
2 * Contract source: https://bit.ly/3DP1ypf
3 *
4 * Feel free to let us know via PR, if you find something broken in this contract
5 * file.
6 */
7
8import '@japa/runner'
9
10declare module '@japa/runner' {
11 interface TestContext {
12 // Extend context
13 }
14
15 // eslint-disable-next-line @typescript-eslint/no-unused-vars
16 interface Test<TestData> {
17 // Extend test
18 }
19}