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

Retranscription du PAI dans le backend #3350

Closed
wants to merge 22 commits into from
Closed
Show file tree
Hide file tree
Changes from 21 commits
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
718d234
Backend - Ajoute la connexion à l'API directus
amandinejacquelin Sep 12, 2024
bf729dc
Backend - Ajoute la connexion à l'API brevo
amandinejacquelin Sep 12, 2024
ffa3ded
Backend - Ajoute les tags
amandinejacquelin Sep 12, 2024
7e59134
Backend - Ajoute les thématiques
amandinejacquelin Sep 12, 2024
174817e
Backend - Ajoute les fiches
amandinejacquelin Sep 12, 2024
37fd178
Backend - Ajoute les axes
amandinejacquelin Sep 12, 2024
a09e482
Backend - Ajoute les documents
amandinejacquelin Sep 12, 2024
e179931
Backend - Ajoute les actions des référentiels
amandinejacquelin Sep 12, 2024
ced69e9
Backend - Ajoute la récupération des définitions des indicateurs
amandinejacquelin Sep 12, 2024
16a8809
Backend - Ajoute les effets attendus
amandinejacquelin Sep 12, 2024
e0762a8
Backend - Ajoute les partenaires du panier
amandinejacquelin Sep 12, 2024
be56868
Backend - Ajoute les actions à impact
amandinejacquelin Sep 12, 2024
ec5bc92
Backend - Ajoute les paniers
amandinejacquelin Sep 12, 2024
71a8635
Front - Panier - WIP - Change le realtime de supabase par websocket
amandinejacquelin Sep 12, 2024
9418d9d
Backend - Ajoute les catégories FNV
amandinejacquelin Sep 18, 2024
39917d3
Backend- Sépare les tables liées aux collectivités dans des fichiers …
amandinejacquelin Sep 20, 2024
ec76f94
Backend - Adapte les fichiers de trajectoires aux nouvelles conventio…
amandinejacquelin Sep 20, 2024
f635d71
Backend - Ajoute les utilisateurs et les droits supports et vérifiés
amandinejacquelin Sep 20, 2024
19efad0
Backend - Ajoute les compétences banatics
amandinejacquelin Sep 25, 2024
21c722b
Revert "Front - Panier - WIP - Change le realtime de supabase par web…
amandinejacquelin Oct 10, 2024
1fa92f5
Ajoute les dépendances pour websocket
amandinejacquelin Oct 22, 2024
e81f1cc
Met à jour le code avec le .editconfig
amandinejacquelin Oct 23, 2024
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: 2 additions & 0 deletions backend/src/auth/auth.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { JwtModule } from '@nestjs/jwt';
import { CommonModule } from '../common/common.module';
import { AuthGuard } from './guards/auth.guard';
import { AuthService } from './services/auth.service';
import { CollectivitesModule } from '../collectivites/collectivites.module';
import { ConfigurationModule } from '../config/configuration.module';

@Module({
Expand All @@ -14,6 +15,7 @@ import { ConfigurationModule } from '../config/configuration.module';
}),
ConfigurationModule,
CommonModule,
CollectivitesModule,
],
providers: [
{
Expand Down
2 changes: 1 addition & 1 deletion backend/src/auth/guards/auth.guard.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import { Request } from 'express';
import BackendConfigurationService from '../../config/configuration.service';
import { getErrorMessage } from '../../common/services/errors.helper';
import { PublicEndpoint } from '../decorators/public-endpoint.decorator';
import { SupabaseJwtPayload } from '../models/auth.models';
import { SupabaseJwtPayload } from '../models/supabase-jwt.models';

@Injectable()
export class AuthGuard implements CanActivate {
Expand Down
52 changes: 52 additions & 0 deletions backend/src/auth/models/auth-users.table.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
import { pgSchema } from 'drizzle-orm/pg-core';
import { timestamp, uuid, varchar } from 'drizzle-orm/pg-core';

export const authSchemaDB = pgSchema('auth');

export const authUsersTable = authSchemaDB.table('users', {
id: uuid('user_id').primaryKey().notNull(),
email: varchar('email', { length: 255 }),
createdAt: timestamp('created_at', { withTimezone: true, mode: 'string' }),
lastSignInAt: timestamp('last_sign_in_at', {
withTimezone: true,
mode: 'string',
}),

/*
TODO
instance_id uuid,
aud varchar(255),
role varchar(255),
encrypted_password varchar(255),
email_confirmed_at timestamp with time zone,
invited_at timestamp with time zone,
confirmation_token varchar(255),
confirmation_sent_at timestamp with time zone,
recovery_token varchar(255),
recovery_sent_at timestamp with time zone,
email_change_token_new varchar(255),
email_change varchar(255),
email_change_sent_at timestamp with time zone,
raw_app_meta_data jsonb,
raw_user_meta_data jsonb,
is_super_admin boolean,
updated_at timestamp with time zone,
phone text default NULL::character varying
unique,
phone_confirmed_at timestamp with time zone,
phone_change text default ''::character varying,
phone_change_token varchar(255) default ''::character varying,
phone_change_sent_at timestamp with time zone,
confirmed_at timestamp with time zone generated always as (LEAST(email_confirmed_at, phone_confirmed_at)) stored,
email_change_token_current varchar(255) default ''::character varying,
email_change_confirm_status smallint default 0
constraint users_email_change_confirm_status_check
check ((email_change_confirm_status >= 0) AND (email_change_confirm_status <= 2)),
banned_until timestamp with time zone,
reauthentication_token varchar(255) default ''::character varying,
reauthentication_sent_at timestamp with time zone,
is_sso_user boolean default false not null,
deleted_at timestamp with time zone,
is_anonymous boolean default false not null
*/
});
22 changes: 22 additions & 0 deletions backend/src/auth/models/dcp.table.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import { boolean, pgTable, uuid, varchar } from 'drizzle-orm/pg-core';
import { text, timestamp } from 'drizzle-orm/pg-core';

export const dcpTable = pgTable('dcp', {
userId: uuid('user_id').primaryKey().notNull(), // TODO .references(() => users.id),
nom: text('nom').notNull(),
prenom: text('prenom').notNull(),
email: text('email').notNull(),
limited: boolean('limited').default(false).notNull(),
deleted: boolean('deleted').default(false).notNull(),
createdAt: timestamp('created_at', { withTimezone: true, mode: 'string' })
.defaultNow()
.notNull(),
modifiedAt: timestamp('modified_at', { withTimezone: true, mode: 'string' })
.defaultNow()
.notNull(),
telephone: varchar('telephone', { length: 30 }),
cguAccepteesLe: timestamp('cgu_acceptees_le', {
withTimezone: true,
mode: 'string',
}),
});
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@ import {
timestamp,
uuid,
} from 'drizzle-orm/pg-core';
import { collectiviteTable } from '../../collectivites/models/collectivite.table';
import { default as jwt } from 'jsonwebtoken';
import { collectiviteTable } from '../../collectivites/models/collectivite.models';

export enum NiveauAcces {
LECTURE = 'lecture',
Expand All @@ -26,43 +26,25 @@ export const niveauAccessEnum = pgEnum('niveau_acces', niveauAccessOrdonne);

export const utilisateurDroitTable = pgTable('private_utilisateur_droit', {
id: serial('id').primaryKey(),
user_id: uuid('user_id').notNull(), // TODO: reference user table
collectivite_id: integer('collectivite_id')
userId: uuid('user_id').notNull(), // TODO: reference user table
collectiviteId: integer('collectivite_id')
.notNull()
.references(() => collectiviteTable.id),
created_at: timestamp('created_at', { withTimezone: true })
createdAt: timestamp('created_at', { withTimezone: true })
.default(sql.raw(`CURRENT_TIMESTAMP`))
.notNull(),
modified_at: timestamp('modified_at', { withTimezone: true }).default(
sql.raw(`CURRENT_TIMESTAMP`)
modifiedAt: timestamp('modified_at', { withTimezone: true }).default(
sql.raw(`CURRENT_TIMESTAMP`),
),
active: boolean('active').notNull(),
niveau_acces: niveauAccessEnum('niveau_acces')
niveauAcces: niveauAccessEnum('niveau_acces')
.notNull()
.default(NiveauAcces.LECTURE),
invitation_id: uuid('invitation_id'), // TODO: reference invitation table
invitationId: uuid('invitation_id'), // TODO: reference invitation table
});
export type UtilisateurDroitType = InferSelectModel<
typeof utilisateurDroitTable
>;
export type CreateUtilisateurDroitType = InferInsertModel<
typeof utilisateurDroitTable
>;

export enum SupabaseRole {
AUTHENTICATED = 'authenticated',
SERVICE_ROLE = 'service_role',
ANON = 'anon', // Anonymous
}

export interface SupabaseJwtPayload extends jwt.JwtPayload {
email?: string;
phone?: string;
app_metadata?: {
provider: string;
providers: string[];
};
session_id: string;
role: SupabaseRole;
is_anonymous: boolean;
}
18 changes: 18 additions & 0 deletions backend/src/auth/models/supabase-jwt.models.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import * as jwt from 'jsonwebtoken';

export enum SupabaseRole {
AUTHENTICATED = 'authenticated',
SERVICE_ROLE = 'service_role',
ANON = 'anon', // Anonymous
}
export interface SupabaseJwtPayload extends jwt.JwtPayload {
email?: string;
phone?: string;
app_metadata?: {
provider: string;
providers: string[];
};
session_id: string;
role: SupabaseRole;
is_anonymous: boolean;
}
8 changes: 8 additions & 0 deletions backend/src/auth/models/user-crm.dto.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
export type userCrm = {
prenom: string;
nom: string;
email: string;
telephone: string | null;
creation: string | null;
derniereConnexion: string | null;
};
10 changes: 10 additions & 0 deletions backend/src/auth/models/utilisateur-support.table.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import { boolean, pgTable, uuid } from 'drizzle-orm/pg-core';
import { dcpTable } from './dcp.table';

export const utilisateurSupportTable = pgTable('utilisateur_support', {
userId: uuid('user_id')
.primaryKey()
.notNull()
.references(() => dcpTable.userId, { onDelete: 'cascade' }),
support: boolean('support').default(false).notNull(),
});
10 changes: 10 additions & 0 deletions backend/src/auth/models/utilisateur-verifie.table.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import { boolean, pgTable, uuid } from 'drizzle-orm/pg-core';
import { dcpTable } from './dcp.table';

export const utilisateurVerifieTable = pgTable('utilisateur_verifie', {
userId: uuid('user_id')
.primaryKey()
.notNull()
.references(() => dcpTable.userId, { onDelete: 'cascade' }),
verifie: boolean('verifie').default(false).notNull(),
});
91 changes: 46 additions & 45 deletions backend/src/auth/services/auth.service.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,11 @@ import { Test } from '@nestjs/testing';
import DatabaseService from '../../common/services/database.service';
import {
NiveauAcces,
SupabaseRole,
UtilisateurDroitType,
} from '../models/auth.models';
} from '../models/private-utilisateur-droit.table';
import { AuthService } from './auth.service';
import { SupabaseRole } from '../models/supabase-jwt.models';
import CollectivitesService from '../../collectivites/services/collectivites.service';

describe('AuthService', () => {
let authService: AuthService;
Expand All @@ -15,7 +16,7 @@ describe('AuthService', () => {
controllers: [AuthService],
})
.useMocker((token) => {
if (token === DatabaseService) {
if (token === DatabaseService || token === CollectivitesService) {
return {};
}
})
Expand Down Expand Up @@ -62,23 +63,23 @@ describe('AuthService', () => {
const droits: UtilisateurDroitType[] = [
{
id: 1,
user_id: '1',
collectivite_id: 1,
niveau_acces: NiveauAcces.EDITION,
userId: '1',
collectiviteId: 1,
niveauAcces: NiveauAcces.EDITION,
active: true,
created_at: new Date(),
modified_at: null,
invitation_id: null,
createdAt: new Date(),
modifiedAt: null,
invitationId: null,
},
{
id: 1,
user_id: '1',
collectivite_id: 2,
niveau_acces: NiveauAcces.ADMIN,
userId: '1',
collectiviteId: 2,
niveauAcces: NiveauAcces.ADMIN,
active: true,
created_at: new Date(),
modified_at: null,
invitation_id: null,
createdAt: new Date(),
modifiedAt: null,
invitationId: null,
},
];

Expand All @@ -96,23 +97,23 @@ describe('AuthService', () => {
const droits: UtilisateurDroitType[] = [
{
id: 1,
user_id: '1',
collectivite_id: 1,
niveau_acces: NiveauAcces.EDITION,
userId: '1',
collectiviteId: 1,
niveauAcces: NiveauAcces.EDITION,
active: true,
created_at: new Date(),
modified_at: null,
invitation_id: null,
createdAt: new Date(),
modifiedAt: null,
invitationId: null,
},
{
id: 1,
user_id: '1',
collectivite_id: 2,
niveau_acces: NiveauAcces.ADMIN,
userId: '1',
collectiviteId: 2,
niveauAcces: NiveauAcces.ADMIN,
active: false,
created_at: new Date(),
modified_at: null,
invitation_id: null,
createdAt: new Date(),
modifiedAt: null,
invitationId: null,
},
];

Expand All @@ -130,23 +131,23 @@ describe('AuthService', () => {
const droits: UtilisateurDroitType[] = [
{
id: 1,
user_id: '1',
collectivite_id: 1,
niveau_acces: NiveauAcces.LECTURE,
userId: '1',
collectiviteId: 1,
niveauAcces: NiveauAcces.LECTURE,
active: true,
created_at: new Date(),
modified_at: null,
invitation_id: null,
createdAt: new Date(),
modifiedAt: null,
invitationId: null,
},
{
id: 1,
user_id: '1',
collectivite_id: 2,
niveau_acces: NiveauAcces.ADMIN,
userId: '1',
collectiviteId: 2,
niveauAcces: NiveauAcces.ADMIN,
active: true,
created_at: new Date(),
modified_at: null,
invitation_id: null,
createdAt: new Date(),
modifiedAt: null,
invitationId: null,
},
];

Expand All @@ -164,13 +165,13 @@ describe('AuthService', () => {
const droits: UtilisateurDroitType[] = [
{
id: 1,
user_id: '1',
collectivite_id: 2,
niveau_acces: NiveauAcces.EDITION,
userId: '1',
collectiviteId: 2,
niveauAcces: NiveauAcces.EDITION,
active: true,
created_at: new Date(),
modified_at: null,
invitation_id: null,
createdAt: new Date(),
modifiedAt: null,
invitationId: null,
},
];

Expand Down
Loading
Loading