diff --git a/.env.example b/.env.example index 61c55439e..f89657dc1 100644 --- a/.env.example +++ b/.env.example @@ -23,7 +23,13 @@ REDIS_PASS=A3vniod98Zbuvn9u5 # ================================================ +# Tip: use mailtrap.io for local development +EMAIL_SENDING_ADDRESS=hello@panora.dev +SMTP_HOST= +SMTP_PORT= +SMTP_USER= +SMTP_PASSWORD= # ================================================ # Database # ================================================ diff --git a/docker-compose.dev.yml b/docker-compose.dev.yml index 830a61fb0..fc870aff7 100644 --- a/docker-compose.dev.yml +++ b/docker-compose.dev.yml @@ -161,6 +161,11 @@ services: HELPSCOUT_TICKETING_CLOUD_CLIENT_SECRET: ${HELPSCOUT_TICKETING_CLOUD_CLIENT_SECRET} IRONCLAD_TICKETING_CLOUD_CLIENT_ID: ${IRONCLAD_TICKETING_CLOUD_CLIENT_ID} IRONCLAD_TICKETING_CLOUD_CLIENT_SECRET: ${IRONCLAD_TICKETING_CLOUD_CLIENT_SECRET} + EMAIL_SENDING_ADDRESS: ${EMAIL_SENDING_ADDRESS} + SMTP_HOST: ${SMTP_HOST} + SMTP_PORT: ${SMTP_PORT} + SMTP_USER: ${SMTP_USER} + SMTP_PASSWORD: ${SMTP_PASSWORD} restart: unless-stopped ports: @@ -195,47 +200,47 @@ services: retries: 5 start_period: 10s - webapp-nextjs: - build: - dockerfile: ./apps/webapp/Dockerfile.dev - context: ./ - args: - VITE_BACKEND_DOMAIN: ${NEXT_PUBLIC_BACKEND_DOMAIN} - environment: - NEXT_PUBLIC_DISTRIBUTION: ${DISTRIBUTION} - NEXT_PUBLIC_BACKEND_DOMAIN: ${NEXT_PUBLIC_BACKEND_DOMAIN} - NEXT_PUBLIC_MAGIC_LINK_DOMAIN: ${NEXT_PUBLIC_MAGIC_LINK_DOMAIN} - NEXT_PUBLIC_WEBAPP_DOMAIN: ${NEXT_PUBLIC_WEBAPP_DOMAIN} - NEXT_PUBLIC_REDIRECT_WEBHOOK_INGRESS: ${REDIRECT_TUNNEL_INGRESS} - restart: unless-stopped - ports: - - 80:8090 - depends_on: - api: - condition: service_healthy - volumes: - - .:/app - networks: - - backend - - frontend + # webapp-nextjs: + # build: + # dockerfile: ./apps/webapp/Dockerfile.dev + # context: ./ + # args: + # VITE_BACKEND_DOMAIN: ${NEXT_PUBLIC_BACKEND_DOMAIN} + # environment: + # NEXT_PUBLIC_DISTRIBUTION: ${DISTRIBUTION} + # NEXT_PUBLIC_BACKEND_DOMAIN: ${NEXT_PUBLIC_BACKEND_DOMAIN} + # NEXT_PUBLIC_MAGIC_LINK_DOMAIN: ${NEXT_PUBLIC_MAGIC_LINK_DOMAIN} + # NEXT_PUBLIC_WEBAPP_DOMAIN: ${NEXT_PUBLIC_WEBAPP_DOMAIN} + # NEXT_PUBLIC_REDIRECT_WEBHOOK_INGRESS: ${REDIRECT_TUNNEL_INGRESS} + # restart: unless-stopped + # ports: + # - 80:8090 + # depends_on: + # api: + # condition: service_healthy + # volumes: + # - .:/app + # networks: + # - backend + # - frontend - magic-link-frontend: - build: - dockerfile: ./apps/magic-link/Dockerfile.dev - context: ./ - args: - VITE_BACKEND_DOMAIN: ${NEXT_PUBLIC_BACKEND_DOMAIN} - restart: always - ports: - - 81:5173 - depends_on: - api: - condition: service_healthy - networks: - - backend - - frontend - volumes: - - .:/app + # magic-link-frontend: + # build: + # dockerfile: ./apps/magic-link/Dockerfile.dev + # context: ./ + # args: + # VITE_BACKEND_DOMAIN: ${NEXT_PUBLIC_BACKEND_DOMAIN} + # restart: always + # ports: + # - 81:5173 + # depends_on: + # api: + # condition: service_healthy + # networks: + # - backend + # - frontend + # volumes: + # - .:/app # pgadmin: # image: dpage/pgadmin4 @@ -271,14 +276,14 @@ services: # condition: service_healthy # network_mode: "host" - docs: - build: - dockerfile: ./Dockerfile.dev - context: ./docs/ - ports: - - 911:3000 - volumes: - - ./docs/:/app + # docs: + # build: + # dockerfile: ./Dockerfile.dev + # context: ./docs/ + # ports: + # - 911:3000 + # volumes: + # - ./docs/:/app volumes: local_pgdata: diff --git a/docker-compose.source.yml b/docker-compose.source.yml index 0d830a2ae..da0ba4a5a 100644 --- a/docker-compose.source.yml +++ b/docker-compose.source.yml @@ -161,6 +161,11 @@ services: HELPSCOUT_TICKETING_CLOUD_CLIENT_SECRET: ${HELPSCOUT_TICKETING_CLOUD_CLIENT_SECRET} IRONCLAD_TICKETING_CLOUD_CLIENT_ID: ${IRONCLAD_TICKETING_CLOUD_CLIENT_ID} IRONCLAD_TICKETING_CLOUD_CLIENT_SECRET: ${IRONCLAD_TICKETING_CLOUD_CLIENT_SECRET} + EMAIL_SENDING_ADDRESS: ${EMAIL_SENDING_ADDRESS} + SMTP_HOST: ${SMTP_HOST} + SMTP_PORT: ${SMTP_PORT} + SMTP_USER: ${SMTP_USER} + SMTP_PASSWORD: ${SMTP_PASSWORD} restart: unless-stopped ports: - 3000:3000 diff --git a/docker-compose.yml b/docker-compose.yml index fafe6b1d4..f82c70f68 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -155,6 +155,11 @@ services: HELPSCOUT_TICKETING_CLOUD_CLIENT_SECRET: ${HELPSCOUT_TICKETING_CLOUD_CLIENT_SECRET} IRONCLAD_TICKETING_CLOUD_CLIENT_ID: ${IRONCLAD_TICKETING_CLOUD_CLIENT_ID} IRONCLAD_TICKETING_CLOUD_CLIENT_SECRET: ${IRONCLAD_TICKETING_CLOUD_CLIENT_SECRET} + EMAIL_SENDING_ADDRESS: ${EMAIL_SENDING_ADDRESS} + SMTP_HOST: ${SMTP_HOST} + SMTP_PORT: ${SMTP_PORT} + SMTP_USER: ${SMTP_USER} + SMTP_PASSWORD: ${SMTP_PASSWORD} restart: unless-stopped ports: - 3000:3000 diff --git a/packages/api/package.json b/packages/api/package.json index 18d076a19..5d893e17d 100644 --- a/packages/api/package.json +++ b/packages/api/package.json @@ -58,6 +58,7 @@ "js-yaml": "^4.1.0", "jwt-decode": "^4.0.0", "nestjs-pino": "^3.5.0", + "nodemailer": "^6.9.14", "openai": "^4.38.5", "passport": "^0.6.0", "passport-headerapikey": "^1.2.2", diff --git a/packages/api/prisma/schema.prisma b/packages/api/prisma/schema.prisma index b600e19e2..7e2bcb50e 100644 --- a/packages/api/prisma/schema.prisma +++ b/packages/api/prisma/schema.prisma @@ -11,13 +11,15 @@ datasource db { model users { id_user String @id(map: "pk_users") @db.Uuid identification_strategy String - email String? + email String? @unique(map: "unique_email") password_hash String? first_name String last_name String id_stytch String? @unique(map: "force_stytch_id_unique") created_at DateTime @default(now()) @db.Timestamp(6) modified_at DateTime @default(now()) @db.Timestamp(6) + reset_token String? + reset_token_expires_at DateTime? @db.Timestamptz(6) api_keys api_keys[] projects projects[] } @@ -1637,37 +1639,44 @@ model acc_vendor_credits { } /// This model or at least one of its fields has comments in the database, and requires an additional setup for migrations: Read more: https://pris.ly/d/database-comments -model ecom_customer_addresses { - id_ecom_customer_address String @id(map: "pk_ecom_customer_addresses") @db.Uuid - address_type String? - line_1 String? - line_2 String? - street_1 String? - street_2 String? - city String? - state String? - postal_code String? - country String? - id_ecom_customer String @db.Uuid - modified_at DateTime @db.Timestamptz(6) - created_at DateTime @db.Timestamptz(6) - ecom_customers ecom_customers @relation(fields: [id_ecom_customer], references: [id_ecom_customer], onDelete: NoAction, onUpdate: NoAction, map: "fk_ecom_customer_customeraddress") +model ecom_addresses { + id_ecom_address String @id(map: "pk_ecom_customer_addresses") @db.Uuid + address_type String? + street_1 String? + street_2 String? + city String? + state String? + postal_code String? + country String? + id_ecom_customer String @db.Uuid + modified_at DateTime @db.Timestamptz(6) + created_at DateTime @db.Timestamptz(6) + remote_deleted Boolean + id_ecom_order String @db.Uuid + ecom_customers ecom_customers @relation(fields: [id_ecom_customer], references: [id_ecom_customer], onDelete: NoAction, onUpdate: NoAction, map: "fk_ecom_customer_customeraddress") + ecom_orders ecom_orders @relation(fields: [id_ecom_order], references: [id_ecom_order], onDelete: NoAction, onUpdate: NoAction, map: "fk_ecom_order_address") @@index([id_ecom_customer], map: "fk_index_ecom_customer_customeraddress") + @@index([id_ecom_order], map: "fk_index_fk_ecom_order_address") } model ecom_customers { - id_ecom_customer String @id(map: "pk_ecom_customers") @db.Uuid - remote_id String? - email String? - first_name String? - last_name String? - phone_number String? - modifed_at DateTime @db.Timestamptz(6) - created_at DateTime @db.Timestamptz(6) - id_connection String @db.Uuid - ecom_customer_addresses ecom_customer_addresses[] - ecom_orders ecom_orders[] + id_ecom_customer String @id(map: "pk_ecom_customers") @db.Uuid + remote_id String? + email String? + first_name String? + last_name String? + phone_number String? + modified_at DateTime @db.Timestamptz(6) + created_at DateTime @db.Timestamptz(6) + id_connection String @db.Uuid + remote_deleted Boolean + ecom_addresses ecom_addresses[] + ecom_orders ecom_orders[] +} + +model ecom_fulfilment_orders { + id_ecom_fulfilment_order String @id(map: "pk_ecom_fulfilment_order") @db.Uuid } /// This model or at least one of its fields has comments in the database, and requires an additional setup for migrations: Read more: https://pris.ly/d/database-comments @@ -1680,13 +1689,18 @@ model ecom_fulfilments { remote_id String? id_ecom_order String? @db.Uuid id_connection String @db.Uuid - modifed_at DateTime @db.Timestamptz(6) + modified_at DateTime @db.Timestamptz(6) created_at DateTime @db.Timestamptz(6) + remote_deleted Boolean ecom_orders ecom_orders? @relation(fields: [id_ecom_order], references: [id_ecom_order], onDelete: NoAction, onUpdate: NoAction, map: "fk_ecom_order_fulfilment") @@index([id_ecom_order], map: "fk_index_ecom_order_fulfilment") } +model ecom_order_line_items { + id_ecom_order_line_item String @id(map: "pk_106") @db.Uuid +} + model ecom_orders { id_ecom_order String @id(map: "pk_ecom_orders") @db.Uuid order_status String? @@ -1701,8 +1715,10 @@ model ecom_orders { remote_id String? id_ecom_customer String? @db.Uuid id_connection String @db.Uuid - modifed_at DateTime @db.Timestamptz(6) + modified_at DateTime @db.Timestamptz(6) created_at DateTime @db.Timestamptz(6) + remote_deleted Boolean + ecom_addresses ecom_addresses[] ecom_fulfilments ecom_fulfilments[] ecom_customers ecom_customers? @relation(fields: [id_ecom_customer], references: [id_ecom_customer], onDelete: NoAction, onUpdate: NoAction, map: "fk_ecom_customer_orders") @@ -1721,8 +1737,9 @@ model ecom_product_variants { weight BigInt? inventory_quantity BigInt? id_ecom_product String? @db.Uuid - modifed_at DateTime @db.Timestamptz(6) + modified_at DateTime @db.Timestamptz(6) created_at DateTime @db.Timestamptz(6) + remote_deleted Boolean ecom_products ecom_products? @relation(fields: [id_ecom_product], references: [id_ecom_product], onDelete: NoAction, onUpdate: NoAction, map: "fk_ecom_products_variants") @@index([id_ecom_product], map: "fk_index_ecom_products_variants") @@ -1738,8 +1755,9 @@ model ecom_products { description String? vendor String? tags String[] - modifed_at DateTime @db.Timestamptz(6) + modified_at DateTime @db.Timestamptz(6) created_at DateTime @db.Timestamptz(6) id_connection String @db.Uuid + remote_deleted Boolean ecom_product_variants ecom_product_variants[] } diff --git a/packages/api/scripts/init.sql b/packages/api/scripts/init.sql index d9a630743..f6d1d46bd 100644 --- a/packages/api/scripts/init.sql +++ b/packages/api/scripts/init.sql @@ -2,9 +2,7 @@ -- *********** Generated by SqlDBM: Panora_DB by rf@panora.dev ********** - -- ************************************** webhooks_reponses - CREATE TABLE webhooks_reponses ( id_webhooks_reponse uuid NOT NULL, @@ -12,17 +10,9 @@ CREATE TABLE webhooks_reponses http_status_code text NOT NULL, CONSTRAINT PK_webhooks_reponse PRIMARY KEY ( id_webhooks_reponse ) ); - - - COMMENT ON COLUMN webhooks_reponses.http_status_code IS 'anything that is not 2xx is failed, and leads to retry'; - - - - -- ************************************** webhooks_payloads - CREATE TABLE webhooks_payloads ( id_webhooks_payload uuid NOT NULL, @@ -30,15 +20,7 @@ CREATE TABLE webhooks_payloads CONSTRAINT PK_webhooks_payload PRIMARY KEY ( id_webhooks_payload ) ); - - - - - - - -- ************************************** webhook_endpoints - CREATE TABLE webhook_endpoints ( id_webhook_endpoint uuid NOT NULL, @@ -52,20 +34,12 @@ CREATE TABLE webhook_endpoints last_update timestamp NULL, CONSTRAINT PK_webhook_endpoint PRIMARY KEY ( id_webhook_endpoint ) ); - - - COMMENT ON COLUMN webhook_endpoints.endpoint_description IS 'An optional description of what the webhook is used for'; COMMENT ON COLUMN webhook_endpoints.secret IS 'a shared secret for secure communication'; COMMENT ON COLUMN webhook_endpoints.active IS 'a flag indicating whether the webhook is active or not'; COMMENT ON COLUMN webhook_endpoints."scope" IS 'stringified array with events,'; - - - - -- ************************************** users - CREATE TABLE users ( id_user uuid NOT NULL, @@ -77,27 +51,20 @@ CREATE TABLE users id_stytch text NULL, created_at timestamp NOT NULL DEFAULT NOW(), modified_at timestamp NOT NULL DEFAULT NOW(), + reset_token text NULL, + reset_token_expires_at timestamp with time zone NULL, CONSTRAINT PK_users PRIMARY KEY ( id_user ), - CONSTRAINT force_stytch_id_unique UNIQUE ( id_stytch ) + CONSTRAINT force_stytch_id_unique UNIQUE ( id_stytch ), + CONSTRAINT unique_email UNIQUE ( email ) ); - - - COMMENT ON COLUMN users.identification_strategy IS 'can be: - PANORA_SELF_HOSTED STYTCH_B2B STYTCH_B2C'; COMMENT ON COLUMN users.created_at IS 'DEFAULT NOW() to automatically insert a value if nothing supplied'; - COMMENT ON CONSTRAINT force_stytch_id_unique ON users IS 'force unique on stytch id'; - - - - -- ************************************** tcg_users - CREATE TABLE tcg_users ( id_tcg_user uuid NOT NULL, @@ -106,23 +73,16 @@ CREATE TABLE tcg_users remote_id text NULL, remote_platform text NULL, teams text[] NULL, - created_at timestamp NULL, - modified_at timestamp NULL, id_linked_user uuid NULL, id_connection uuid NOT NULL, + created_at timestamp NULL, + modified_at timestamp NULL, CONSTRAINT PK_tcg_users PRIMARY KEY ( id_tcg_user ) ); - COMMENT ON TABLE tcg_users IS 'The User object is used to represent an employee within a company.'; - COMMENT ON COLUMN tcg_users.teams IS 'array of id_tcg_team. Teams the support agent belongs to.'; - - - - -- ************************************** tcg_teams - CREATE TABLE tcg_teams ( id_tcg_team uuid NOT NULL, @@ -137,15 +97,7 @@ CREATE TABLE tcg_teams CONSTRAINT PK_tcg_teams PRIMARY KEY ( id_tcg_team ) ); - - - - - - - -- ************************************** tcg_collections - CREATE TABLE tcg_collections ( id_tcg_collection uuid NOT NULL, @@ -155,6 +107,7 @@ CREATE TABLE tcg_collections remote_platform text NULL, collection_type text NULL, parent_collection uuid NULL, + id_tcg_ticket uuid NULL, created_at timestamp NOT NULL, modified_at timestamp NOT NULL, id_linked_user uuid NOT NULL, @@ -162,15 +115,7 @@ CREATE TABLE tcg_collections CONSTRAINT PK_tcg_collections PRIMARY KEY ( id_tcg_collection ) ); - - - - - - - -- ************************************** tcg_accounts - CREATE TABLE tcg_accounts ( id_tcg_account uuid NOT NULL, @@ -184,17 +129,9 @@ CREATE TABLE tcg_accounts id_connection uuid NOT NULL, CONSTRAINT PK_tcg_account PRIMARY KEY ( id_tcg_account ) ); - - - COMMENT ON COLUMN tcg_accounts.name IS 'company or customer name'; - - - - -- ************************************** remote_data - CREATE TABLE remote_data ( id_remote_data uuid NOT NULL, @@ -205,18 +142,10 @@ CREATE TABLE remote_data CONSTRAINT PK_remote_data PRIMARY KEY ( id_remote_data ), CONSTRAINT Force_Unique_ressourceOwnerId UNIQUE ( ressource_owner_id ) ); - - - COMMENT ON COLUMN remote_data.ressource_owner_id IS 'uuid of the unified object that owns this remote data. UUID of the contact, or deal , etc...'; COMMENT ON COLUMN remote_data."format" IS 'can be json, xml'; - - - - -- ************************************** managed_webhooks - CREATE TABLE managed_webhooks ( id_managed_webhook uuid NOT NULL, @@ -230,18 +159,10 @@ CREATE TABLE managed_webhooks created_at timestamp NOT NULL, CONSTRAINT PK_managed_webhooks PRIMARY KEY ( id_managed_webhook ) ); - - - COMMENT ON COLUMN managed_webhooks.endpoint IS 'UUID that will be used in the final URL to help identify where to route data ex: api.panora.dev/mw/{managed_webhooks.endpoint}'; - - - - -- ************************************** fs_users - CREATE TABLE fs_users ( id_fs_user uuid NOT NULL, @@ -255,15 +176,7 @@ CREATE TABLE fs_users CONSTRAINT PK_fs_users PRIMARY KEY ( id_fs_user ) ); - - - - - - - -- ************************************** fs_shared_links - CREATE TABLE fs_shared_links ( id_fs_shared_link uuid NOT NULL, @@ -281,18 +194,10 @@ CREATE TABLE fs_shared_links remote_id text NULL, CONSTRAINT PK_fs_shared_links PRIMARY KEY ( id_fs_shared_link ) ); - - - COMMENT ON COLUMN fs_shared_links."scope" IS 'can be public, or company depending on the link'; COMMENT ON COLUMN fs_shared_links.password IS 'encrypted password'; - - - - -- ************************************** fs_permissions - CREATE TABLE fs_permissions ( id_fs_permission uuid NOT NULL, @@ -306,17 +211,9 @@ CREATE TABLE fs_permissions id_connection uuid NOT NULL, CONSTRAINT PK_fs_permissions PRIMARY KEY ( id_fs_permission ) ); - - - COMMENT ON COLUMN fs_permissions.roles IS 'read, write, owner'; - - - - -- ************************************** fs_groups - CREATE TABLE fs_groups ( id_fs_group uuid NOT NULL, @@ -329,17 +226,9 @@ CREATE TABLE fs_groups id_connection uuid NOT NULL, CONSTRAINT PK_fs_groups PRIMARY KEY ( id_fs_group ) ); - - - COMMENT ON COLUMN fs_groups.remote_was_deleted IS 'set to true'; - - - - -- ************************************** fs_drives - CREATE TABLE fs_drives ( id_fs_drive uuid NOT NULL, @@ -353,15 +242,7 @@ CREATE TABLE fs_drives CONSTRAINT PK_fs_drives PRIMARY KEY ( id_fs_drive ) ); - - - - - - - -- ************************************** entity - CREATE TABLE entity ( id_entity uuid NOT NULL, @@ -370,17 +251,58 @@ CREATE TABLE entity modified_at timestamp with time zone NOT NULL, CONSTRAINT PK_entity PRIMARY KEY ( id_entity ) ); - - - COMMENT ON COLUMN entity.ressource_owner_id IS 'uuid of the ressource owner - can be a a crm_contact, a crm_deal, etc...'; +-- ************************************** ecom_products +CREATE TABLE ecom_products +( + id_ecom_product uuid NOT NULL, + remote_id text NULL, + product_url text NULL, + product_type text NULL, + product_status text NULL, + images_urls text[] NULL, + description text NULL, + vendor text NULL, + tags text[] NULL, + modified_at timestamp with time zone NOT NULL, + created_at timestamp with time zone NOT NULL, + id_connection uuid NOT NULL, + remote_deleted boolean NOT NULL, + CONSTRAINT PK_ecom_products PRIMARY KEY ( id_ecom_product ) +); +-- ************************************** ecom_order_line_items +CREATE TABLE ecom_order_line_items +( + id_ecom_order_line_item uuid NOT NULL, + CONSTRAINT PK_106 PRIMARY KEY ( id_ecom_order_line_item ) +); +-- ************************************** ecom_fulfilment_orders +CREATE TABLE ecom_fulfilment_orders +( + id_ecom_fulfilment_order uuid NOT NULL, + CONSTRAINT PK_ecom_fulfilment_order PRIMARY KEY ( id_ecom_fulfilment_order ) +); +-- ************************************** ecom_customers +CREATE TABLE ecom_customers +( + id_ecom_customer uuid NOT NULL, + remote_id text NULL, + email text NULL, + first_name text NULL, + last_name text NULL, + phone_number text NULL, + modified_at timestamp with time zone NOT NULL, + created_at timestamp with time zone NOT NULL, + id_connection uuid NOT NULL, + remote_deleted boolean NOT NULL, + CONSTRAINT PK_ecom_customers PRIMARY KEY ( id_ecom_customer ) +); -- ************************************** cs_values - CREATE TABLE cs_values ( id_cs_value uuid NOT NULL, @@ -389,15 +311,7 @@ CREATE TABLE cs_values CONSTRAINT PK_ct_values PRIMARY KEY ( id_cs_value ) ); - - - - - - - -- ************************************** cs_entities - CREATE TABLE cs_entities ( id_cs_entity uuid NOT NULL, @@ -405,15 +319,7 @@ CREATE TABLE cs_entities CONSTRAINT PK_ct_entities PRIMARY KEY ( id_cs_entity ) ); - - - - - - - -- ************************************** cs_attributes - CREATE TABLE cs_attributes ( id_cs_attribute uuid NOT NULL, @@ -423,15 +329,7 @@ CREATE TABLE cs_attributes CONSTRAINT PK_ct_attributes PRIMARY KEY ( id_cs_attribute ) ); - - - - - - - -- ************************************** crm_users - CREATE TABLE crm_users ( id_crm_user uuid NOT NULL, @@ -446,15 +344,7 @@ CREATE TABLE crm_users CONSTRAINT PK_crm_users PRIMARY KEY ( id_crm_user ) ); - - - - - - - -- ************************************** crm_deals_stages - CREATE TABLE crm_deals_stages ( id_crm_deals_stage uuid NOT NULL, @@ -468,15 +358,7 @@ CREATE TABLE crm_deals_stages CONSTRAINT PK_crm_deal_stages PRIMARY KEY ( id_crm_deals_stage ) ); - - - - - - - -- ************************************** connector_sets - CREATE TABLE connector_sets ( id_connector_set uuid NOT NULL, @@ -495,15 +377,7 @@ CREATE TABLE connector_sets CONSTRAINT PK_project_connector PRIMARY KEY ( id_connector_set ) ); - - - - - - - -- ************************************** connection_strategies - CREATE TABLE connection_strategies ( id_connection_strategy uuid NOT NULL, @@ -512,19 +386,11 @@ CREATE TABLE connection_strategies id_project uuid NULL, CONSTRAINT PK_connection_strategies PRIMARY KEY ( id_connection_strategy ) ); - - - COMMENT ON COLUMN connection_strategies.id_connection_strategy IS 'Connection strategies are meant to overwrite default env variables for oauth strategies'; COMMENT ON COLUMN connection_strategies.status IS 'if the connection strategy should overwrite default strategy (from env)'; COMMENT ON COLUMN connection_strategies.type IS 'OAUTH2, API_KEY, PIPEDRIVE_CLOUD_OAUTH, PIPEDRIVE_CLOUD_API, HUBSPOT_CLOUD'; - - - - -- ************************************** ats_users - CREATE TABLE ats_users ( id_ats_user uuid NOT NULL, @@ -541,17 +407,9 @@ CREATE TABLE ats_users id_connection uuid NOT NULL, CONSTRAINT PK_ats_users PRIMARY KEY ( id_ats_user ) ); - - - COMMENT ON COLUMN ats_users.access_role IS 'The user''s role. Possible values include: SUPER_ADMIN, ADMIN, TEAM_MEMBER, LIMITED_TEAM_MEMBER, INTERVIEWER. In cases where there is no clear mapping, the original value passed through will be returned.'; - - - - -- ************************************** ats_reject_reasons - CREATE TABLE ats_reject_reasons ( id_ats_reject_reason uuid NOT NULL, @@ -563,15 +421,7 @@ CREATE TABLE ats_reject_reasons CONSTRAINT PK_ats_reject_reasons PRIMARY KEY ( id_ats_reject_reason ) ); - - - - - - - -- ************************************** ats_offices - CREATE TABLE ats_offices ( id_ats_office uuid NOT NULL, @@ -583,16 +433,9 @@ CREATE TABLE ats_offices id_connection uuid NOT NULL, CONSTRAINT PK_ats_offices PRIMARY KEY ( id_ats_office ) ); - COMMENT ON TABLE ats_offices IS 'The Office object is used to represent an office within a company. A given Job has the Office ID in its offices field.'; - - - - - -- ************************************** ats_jobs - CREATE TABLE ats_jobs ( id_ats_job uuid NOT NULL, @@ -614,9 +457,7 @@ CREATE TABLE ats_jobs id_connection uuid NOT NULL, CONSTRAINT PK_ats_jobs PRIMARY KEY ( id_ats_job ) ); - COMMENT ON TABLE ats_jobs IS 'The Job object can be used to track any jobs that are currently or will be open/closed for applications.'; - COMMENT ON COLUMN ats_jobs.description IS 'the jobs description'; COMMENT ON COLUMN ats_jobs.status IS 'The job''s status. Possible values include: OPEN, CLOSED, DRAFT, ARCHIVED, PENDING. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN ats_jobs.type IS 'The job''s type. Possible values include: POSTING, REQUISITION, PROFILE. In cases where there is no clear mapping, the original value passed through will be returned.'; @@ -625,12 +466,7 @@ COMMENT ON COLUMN ats_jobs.ats_offices IS 'IDs of Office objects for this Job.'; COMMENT ON COLUMN ats_jobs.managers IS 'IDs of RemoteUser objects that serve as hiring managers for this Job.'; COMMENT ON COLUMN ats_jobs.recruiters IS 'IDs of RemoteUser objects that serve as recruiters for this Job.'; - - - - -- ************************************** ats_departments - CREATE TABLE ats_departments ( id_ats_department uuid NOT NULL, @@ -642,15 +478,7 @@ CREATE TABLE ats_departments CONSTRAINT PK_ats_departments PRIMARY KEY ( id_ats_department ) ); - - - - - - - -- ************************************** ats_candidates - CREATE TABLE ats_candidates ( id_ats_candidate uuid NOT NULL, @@ -671,9 +499,6 @@ CREATE TABLE ats_candidates id_connection uuid NOT NULL, CONSTRAINT PK_ats_candidates PRIMARY KEY ( id_ats_candidate ) ); - - - COMMENT ON COLUMN ats_candidates.first_name IS 'candidate''s first name.'; COMMENT ON COLUMN ats_candidates.last_name IS 'candidate''s last name.'; COMMENT ON COLUMN ats_candidates.company IS 'The candidate''s current company'; @@ -681,12 +506,7 @@ COMMENT ON COLUMN ats_candidates.title IS 'The candidate''s current title'; COMMENT ON COLUMN ats_candidates.email_reachable IS 'can the candidate be emailed'; COMMENT ON COLUMN ats_candidates.tags IS 'array of id_ats_candidate_tag'; - - - - -- ************************************** ats_candidate_tags - CREATE TABLE ats_candidate_tags ( id_ats_candidate_tag uuid NOT NULL, @@ -698,15 +518,7 @@ CREATE TABLE ats_candidate_tags CONSTRAINT PK_ats_candidate_tags PRIMARY KEY ( id_ats_candidate_tag ) ); - - - - - - - -- ************************************** acc_vendor_credits - CREATE TABLE acc_vendor_credits ( id_acc_vendor_credit uuid NOT NULL, @@ -725,17 +537,9 @@ CREATE TABLE acc_vendor_credits accounting_period uuid NULL, CONSTRAINT PK_acc_vendor_credits PRIMARY KEY ( id_acc_vendor_credit ) ); - - - COMMENT ON COLUMN acc_vendor_credits.company IS 'The company the vendor credit belongs to.'; - - - - -- ************************************** acc_vendor_credit_lines - CREATE TABLE acc_vendor_credit_lines ( id_acc_vendor_credit_line uuid NOT NULL, @@ -753,15 +557,7 @@ CREATE TABLE acc_vendor_credit_lines CONSTRAINT PK_acc_vendor_credit_lines PRIMARY KEY ( id_acc_vendor_credit_line ) ); - - - - - - - -- ************************************** acc_transactions - CREATE TABLE acc_transactions ( id_acc_transaction uuid NOT NULL, @@ -782,10 +578,8 @@ CREATE TABLE acc_transactions id_connection uuid NOT NULL, CONSTRAINT PK_acc_transactions PRIMARY KEY ( id_acc_transaction ) ); - COMMENT ON TABLE acc_transactions IS 'Transactions The Transaction common model includes records of all types of transactions that do not appear in other common models. The type of transaction can be identified through the type field. More specifically, it will contain all types of transactions outside of: - Credit Notes Expenses Invoices @@ -793,15 +587,9 @@ Journal Entries Payments Purchase Orders Vendor Credits'; - COMMENT ON COLUMN acc_transactions.total_amount IS 'The total amount being paid after taxes.'; - - - - -- ************************************** acc_tracking_categories - CREATE TABLE acc_tracking_categories ( id_acc_tracking_category uuid NOT NULL, @@ -815,19 +603,11 @@ CREATE TABLE acc_tracking_categories id_connection uuid NOT NULL, CONSTRAINT PK_acc_tracking_categories PRIMARY KEY ( id_acc_tracking_category ) ); - - - COMMENT ON COLUMN acc_tracking_categories.status IS 'The tracking category''s status. Possible values include: ACTIVE, ARCHIVED. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN acc_tracking_categories.category_type IS 'The tracking category’s type. Possible values include: CLASS, DEPARTMENT. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN acc_tracking_categories.parent_category IS 'ID of the parent tracking category.'; - - - - -- ************************************** acc_tax_rates - CREATE TABLE acc_tax_rates ( id_acc_tax_rate uuid NOT NULL, @@ -841,18 +621,10 @@ CREATE TABLE acc_tax_rates modified_at timestamp with time zone NOT NULL, CONSTRAINT PK_acc_tax_rates PRIMARY KEY ( id_acc_tax_rate ) ); - - - COMMENT ON COLUMN acc_tax_rates.total_tax_ratge IS 'The tax’s total tax rate - sum of the tax components (not compounded).'; COMMENT ON COLUMN acc_tax_rates.company IS 'The subsidiary that the tax rate belongs to (in the case of multi-entity systems).'; - - - - -- ************************************** acc_report_items - CREATE TABLE acc_report_items ( id_acc_report_item uuid NOT NULL, @@ -866,15 +638,7 @@ CREATE TABLE acc_report_items CONSTRAINT PK_acc_report_items PRIMARY KEY ( id_acc_report_item ) ); - - - - - - - -- ************************************** acc_income_statements - CREATE TABLE acc_income_statements ( id_acc_income_statement uuid NOT NULL, @@ -892,15 +656,7 @@ CREATE TABLE acc_income_statements CONSTRAINT PK_acc_income_statements PRIMARY KEY ( id_acc_income_statement ) ); - - - - - - - -- ************************************** acc_credit_notes - CREATE TABLE acc_credit_notes ( id_acc_credit_note uuid NOT NULL, @@ -925,19 +681,11 @@ CREATE TABLE acc_credit_notes id_connection uuid NOT NULL, CONSTRAINT PK_acc_credit_notes PRIMARY KEY ( id_acc_credit_note ) ); - - - COMMENT ON COLUMN acc_credit_notes.status IS 'The credit note''s status. Possible values include: SUBMITTED, AUTHORIZED, PAID. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN acc_credit_notes."number" IS 'The credit note''s number.'; COMMENT ON COLUMN acc_credit_notes.payments IS 'array of id_acc_payment'; - - - - -- ************************************** acc_company_infos - CREATE TABLE acc_company_infos ( id_acc_company_info uuid NOT NULL, @@ -957,15 +705,7 @@ CREATE TABLE acc_company_infos CONSTRAINT PK_acc_company_infos PRIMARY KEY ( id_acc_company_info ) ); - - - - - - - -- ************************************** acc_cash_flow_statements - CREATE TABLE acc_cash_flow_statements ( id_acc_cash_flow_statement uuid NOT NULL, @@ -984,15 +724,7 @@ CREATE TABLE acc_cash_flow_statements CONSTRAINT PK_acc_cash_flow_statements PRIMARY KEY ( id_acc_cash_flow_statement ) ); - - - - - - - -- ************************************** acc_balance_sheets_report_items - CREATE TABLE acc_balance_sheets_report_items ( id_acc_balance_sheets_report_item uuid NOT NULL, @@ -1005,17 +737,9 @@ CREATE TABLE acc_balance_sheets_report_items id_acc_company_info uuid NULL, CONSTRAINT PK_acc_balance_sheets_report_items PRIMARY KEY ( id_acc_balance_sheets_report_item ) ); - - - COMMENT ON COLUMN acc_balance_sheets_report_items.parent_item IS 'uuid of another id_acc_balance_sheets_report_item'; - - - - -- ************************************** acc_accounting_periods - CREATE TABLE acc_accounting_periods ( id_acc_accounting_period uuid NOT NULL, @@ -1029,17 +753,9 @@ CREATE TABLE acc_accounting_periods id_connection uuid NOT NULL, CONSTRAINT PK_acc_accounting_periods PRIMARY KEY ( id_acc_accounting_period ) ); - - - COMMENT ON COLUMN acc_accounting_periods.status IS 'Possible values include: ACTIVE, INACTIVE. In cases where there is no clear mapping, the original value passed through will be returned.'; - - - - -- ************************************** tcg_tickets - CREATE TABLE tcg_tickets ( id_tcg_ticket uuid NOT NULL, @@ -1053,39 +769,29 @@ CREATE TABLE tcg_tickets collections text[] NULL, completed_at timestamp NULL, priority text NULL, - created_at timestamp NOT NULL, - modified_at timestamp NOT NULL, assigned_to text[] NULL, remote_id text NULL, remote_platform text NULL, creator_type text NULL, id_tcg_user uuid NULL, - id_linked_user uuid NOT NULL, + id_linked_user uuid NULL, + created_at timestamp NOT NULL, + modified_at timestamp NOT NULL, id_connection uuid NOT NULL, CONSTRAINT PK_tcg_tickets PRIMARY KEY ( id_tcg_ticket ) ); - CREATE INDEX FK_tcg_ticket_tcg_user ON tcg_tickets ( id_tcg_user ); - - - COMMENT ON COLUMN tcg_tickets.name IS 'Name of the ticket. Usually very short.'; COMMENT ON COLUMN tcg_tickets.status IS 'OPEN, CLOSED, IN_PROGRESS, ON_HOLD'; COMMENT ON COLUMN tcg_tickets.tags IS 'array of tags uuid'; COMMENT ON COLUMN tcg_tickets.assigned_to IS 'Employees assigned to this ticket. - It is a stringified array containing tcg_users'; COMMENT ON COLUMN tcg_tickets.id_tcg_user IS 'id of the user who created the ticket'; - - - - -- ************************************** tcg_contacts - CREATE TABLE tcg_contacts ( id_tcg_contact uuid NOT NULL, @@ -1103,21 +809,12 @@ CREATE TABLE tcg_contacts CONSTRAINT PK_tcg_contact PRIMARY KEY ( id_tcg_contact ), CONSTRAINT FK_49 FOREIGN KEY ( id_tcg_account ) REFERENCES tcg_accounts ( id_tcg_account ) ); - CREATE INDEX FK_tcg_contact_tcg_account_id ON tcg_contacts ( id_tcg_account ); - - - - - - - -- ************************************** projects - CREATE TABLE projects ( id_project uuid NOT NULL, @@ -1131,25 +828,15 @@ CREATE TABLE projects CONSTRAINT FK_project_connectorsetid FOREIGN KEY ( id_connector_set ) REFERENCES connector_sets ( id_connector_set ), CONSTRAINT FK_46_1 FOREIGN KEY ( id_user ) REFERENCES users ( id_user ) ); - CREATE INDEX FK_connectors_sets ON projects ( id_connector_set ); - - - COMMENT ON COLUMN projects.sync_mode IS 'Can be realtime or periodic_pull'; COMMENT ON COLUMN projects.pull_frequency IS 'Frequency in seconds for pulls - ex 3600 for one hour'; - - - - -- ************************************** fs_folders - CREATE TABLE fs_folders ( id_fs_folder uuid NOT NULL, @@ -1166,26 +853,68 @@ CREATE TABLE fs_folders id_fs_permission uuid NULL, CONSTRAINT PK_fs_folders PRIMARY KEY ( id_fs_folder ) ); - CREATE INDEX FK_fs_folder_driveID ON fs_folders ( id_fs_drive ); - CREATE INDEX FK_fs_folder_permissionID ON fs_folders ( id_fs_permission ); +-- ************************************** ecom_product_variants +CREATE TABLE ecom_product_variants +( + id_ecom_product_variant uuid NOT NULL, + id_connection uuid NOT NULL, + remote_id text NULL, + title text NULL, + price bigint NULL, + sku text NULL, + options jsonb NULL, + weight bigint NULL, + inventory_quantity bigint NULL, + id_ecom_product uuid NULL, + modified_at timestamp with time zone NOT NULL, + created_at timestamp with time zone NOT NULL, + remote_deleted boolean NOT NULL, + CONSTRAINT PK_ecom_product_variants PRIMARY KEY ( id_ecom_product_variant ), + CONSTRAINT FK_ecom_products_variants FOREIGN KEY ( id_ecom_product ) REFERENCES ecom_products ( id_ecom_product ) +); +CREATE INDEX FK_index_ecom_products_variants ON ecom_product_variants +( + id_ecom_product +); +COMMENT ON COLUMN ecom_product_variants.options IS 'an array of product options. ex [{color: blue}, {size: medium}] ...'; - - - - - +-- ************************************** ecom_orders +CREATE TABLE ecom_orders +( + id_ecom_order uuid NOT NULL, + order_status text NULL, + order_number text NULL, + payment_status text NULL, + currency text NULL, + total_price bigint NULL, + total_discount bigint NULL, + total_shipping bigint NULL, + total_tax bigint NULL, + fulfillment_status text NULL, + remote_id text NULL, + id_ecom_customer uuid NULL, + id_connection uuid NOT NULL, + modified_at timestamp with time zone NOT NULL, + created_at timestamp with time zone NOT NULL, + remote_deleted boolean NOT NULL, + CONSTRAINT PK_ecom_orders PRIMARY KEY ( id_ecom_order ), + CONSTRAINT FK_ecom_customer_orders FOREIGN KEY ( id_ecom_customer ) REFERENCES ecom_customers ( id_ecom_customer ) +); +CREATE INDEX FK_index_ecom_customer_orders ON ecom_orders +( + id_ecom_customer +); -- ************************************** crm_contacts - CREATE TABLE crm_contacts ( id_crm_contact uuid NOT NULL, @@ -1201,22 +930,13 @@ CREATE TABLE crm_contacts CONSTRAINT PK_crm_contacts PRIMARY KEY ( id_crm_contact ), CONSTRAINT FK_23 FOREIGN KEY ( id_crm_user ) REFERENCES crm_users ( id_crm_user ) ); - CREATE INDEX FK_crm_contact_userID ON crm_contacts ( id_crm_user ); - - - COMMENT ON COLUMN crm_contacts.remote_platform IS 'can be hubspot, zendesk, zoho...'; - - - - -- ************************************** crm_companies - CREATE TABLE crm_companies ( id_crm_company uuid NOT NULL, @@ -1231,23 +951,14 @@ CREATE TABLE crm_companies id_linked_user uuid NULL, id_connection uuid NOT NULL, CONSTRAINT PK_crm_companies PRIMARY KEY ( id_crm_company ), - CONSTRAINT FK_24 FOREIGN KEY ( id_crm_user ) REFERENCES crm_users ( id_crm_user ) -); - -CREATE INDEX FK_crm_company_crm_userID ON crm_companies -( - id_crm_user -); - - - - - - - + CONSTRAINT FK_24 FOREIGN KEY ( id_crm_user ) REFERENCES crm_users ( id_crm_user ) +); +CREATE INDEX FK_crm_company_crm_userID ON crm_companies +( + id_crm_user +); -- ************************************** attribute - CREATE TABLE attribute ( id_attribute uuid NOT NULL, @@ -1267,36 +978,24 @@ CREATE TABLE attribute CONSTRAINT PK_attribute PRIMARY KEY ( id_attribute ), CONSTRAINT FK_32 FOREIGN KEY ( id_entity ) REFERENCES entity ( id_entity ) ); - CREATE INDEX FK_attribute_entityID ON attribute ( id_entity ); - - - COMMENT ON COLUMN attribute.status IS 'NEED_REMOTE_ID LINKED'; COMMENT ON COLUMN attribute.ressource_owner_type IS 'ressource_owner type: - crm_deal, crm_contact'; COMMENT ON COLUMN attribute.slug IS 'Custom field name,ex : SIZE, AGE, MIDDLE_NAME, HAS_A_CAR ...'; COMMENT ON COLUMN attribute.description IS 'description of this custom field'; COMMENT ON COLUMN attribute.data_type IS 'INTEGER, STRING, BOOLEAN...'; COMMENT ON COLUMN attribute."source" IS 'can be hubspot, zendesk, etc'; COMMENT ON COLUMN attribute."scope" IS 'defines at which scope the ressource will be available - can be "ORGANIZATION", or "LINKED_USER"'; COMMENT ON COLUMN attribute.id_consumer IS 'Can be an organization iD , or linked user ID - id_linked_user'; - - - - -- ************************************** ats_job_interview_stages - CREATE TABLE ats_job_interview_stages ( id_ats_job_interview_stage uuid NOT NULL, @@ -1309,22 +1008,14 @@ CREATE TABLE ats_job_interview_stages id_connection uuid NOT NULL, CONSTRAINT PK_ats_job_interview_stages PRIMARY KEY ( id_ats_job_interview_stage ) ); - CREATE INDEX FK_ATS_Jobs_ATS_JobInterview_ID ON ats_job_interview_stages ( id_ats_job ); - COMMENT ON TABLE ats_job_interview_stages IS 'The JobInterviewStage object is used to represent a particular recruiting stage for an Application. A given Application typically has the JobInterviewStage object represented in the current_stage field.'; - COMMENT ON COLUMN ats_job_interview_stages.id_ats_job IS 'This field is populated only if the stage is specific to a particular job. If the stage is generic, this field will not be populated.'; - - - - -- ************************************** ats_eeocs - CREATE TABLE ats_eeocs ( id_ats_eeoc uuid NOT NULL, @@ -1340,25 +1031,17 @@ CREATE TABLE ats_eeocs id_connection uuid NOT NULL, CONSTRAINT PK_ats_eeocs PRIMARY KEY ( id_ats_eeoc ) ); - CREATE INDEX FK_candidate_eeocsid ON ats_eeocs ( id_ats_candidate ); - COMMENT ON TABLE ats_eeocs IS 'The EEOC object is used to represent the Equal Employment Opportunity Commission information for a candidate (race, gender, veteran status, disability status).'; - COMMENT ON COLUMN ats_eeocs.race IS 'The candidate''s race. Possible values include: AMERICAN_INDIAN_OR_ALASKAN_NATIVE, ASIAN, BLACK_OR_AFRICAN_AMERICAN, HISPANIC_OR_LATINO, WHITE, NATIVE_HAWAIIAN_OR_OTHER_PACIFIC_ISLANDER, TWO_OR_MORE_RACES, DECLINE_TO_SELF_IDENTIFY. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN ats_eeocs.gender IS 'The candidate''s gender. Possible values include: MALE, FEMALE, NON-BINARY, OTHER, DECLINE_TO_SELF_IDENTIFY. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN ats_eeocs.veteran_status IS 'The candidate''s veteran status. Possible values include: I_AM_NOT_A_PROTECTED_VETERAN, I_IDENTIFY_AS_ONE_OR_MORE_OF_THE_CLASSIFICATIONS_OF_A_PROTECTED_VETERAN, I_DONT_WISH_TO_ANSWER. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN ats_eeocs.disability_status IS 'The candidate''s disability status. Possible values include: YES_I_HAVE_A_DISABILITY_OR_PREVIOUSLY_HAD_A_DISABILITY, NO_I_DONT_HAVE_A_DISABILITY, I_DONT_WISH_TO_ANSWER. In cases where there is no clear mapping, the original value passed through will be returned.'; - - - - -- ************************************** ats_candidate_urls - CREATE TABLE ats_candidate_urls ( id_ats_candidate_url uuid NOT NULL, @@ -1369,21 +1052,12 @@ CREATE TABLE ats_candidate_urls id_ats_candidate uuid NOT NULL, CONSTRAINT PK_ats_candidate_urls PRIMARY KEY ( id_ats_candidate_url ) ); - CREATE INDEX FK_candidate_url_ID ON ats_candidate_urls ( id_ats_candidate ); - - - - - - - -- ************************************** ats_candidate_phone_numbers - CREATE TABLE ats_candidate_phone_numbers ( id_ats_candidate_phone_number uuid NOT NULL, @@ -1394,22 +1068,13 @@ CREATE TABLE ats_candidate_phone_numbers id_ats_candidate uuid NOT NULL, CONSTRAINT PK_ats_candidate_phone_numbers PRIMARY KEY ( id_ats_candidate_phone_number ) ); - CREATE INDEX FK_candidate_phone_id ON ats_candidate_phone_numbers ( id_ats_candidate ); - - - COMMENT ON COLUMN ats_candidate_phone_numbers.type IS 'can be PERSONAL, PRO...'; - - - - -- ************************************** ats_candidate_email_addresses - CREATE TABLE ats_candidate_email_addresses ( id_ats_candidate_email_address uuid NOT NULL, @@ -1420,21 +1085,12 @@ CREATE TABLE ats_candidate_email_addresses id_ats_candidate uuid NOT NULL, CONSTRAINT PK_ats_candidate_email_addresses PRIMARY KEY ( id_ats_candidate_email_address ) ); - CREATE INDEX FK_candidate_email_ID ON ats_candidate_email_addresses ( id_ats_candidate ); - - - - - - - -- ************************************** ats_candidate_attachments - CREATE TABLE ats_candidate_attachments ( id_ats_candidate_attachment uuid NOT NULL, @@ -1450,22 +1106,13 @@ CREATE TABLE ats_candidate_attachments id_connection uuid NOT NULL, CONSTRAINT PK_ats_candidate_attachments PRIMARY KEY ( id_ats_candidate_attachment ) ); - CREATE INDEX FK_ats_candidate_attachment_candidateID_Index ON ats_candidate_attachments ( id_ats_candidate ); - - - COMMENT ON COLUMN ats_candidate_attachments.file_type IS 'Can be RESUME, COVER_LETTER, OFFER_LETTER, OTHER'; - - - - -- ************************************** ats_applications - CREATE TABLE ats_applications ( id_ats_application uuid NOT NULL, @@ -1484,29 +1131,19 @@ CREATE TABLE ats_applications id_connection uuid NOT NULL, CONSTRAINT PK_ats_applications PRIMARY KEY ( id_ats_application ) ); - CREATE INDEX FK_ats_application_ATS_JOB_ID ON ats_applications ( id_ats_job ); - CREATE INDEX FK_ats_application_atsCandidateId ON ats_applications ( id_ats_candidate ); - - - COMMENT ON COLUMN ats_applications."source" IS 'the applications source'; COMMENT ON COLUMN ats_applications.credited_to IS 'The user credited for this application.'; COMMENT ON COLUMN ats_applications.current_stage IS 'this is an id_ats_job_interview_stage'; - - - - -- ************************************** ats_activities - CREATE TABLE ats_activities ( id_ats_activity uuid NOT NULL, @@ -1522,26 +1159,17 @@ CREATE TABLE ats_activities id_connection uuid NOT NULL, CONSTRAINT PK_ats_activities PRIMARY KEY ( id_ats_activity ) ); - CREATE INDEX FK_activity_candidate ON ats_activities ( id_ats_candidate ); - - - COMMENT ON COLUMN ats_activities.activity_type IS 'The activity''s type. Possible values include: NOTE, EMAIL, OTHER. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN ats_activities.subject IS 'The activity''s subject.'; COMMENT ON COLUMN ats_activities.body IS 'The activity''s body.'; COMMENT ON COLUMN ats_activities.visibility IS 'The activity''s visibility. Possible values include: ADMIN_ONLY, PUBLIC, PRIVATE. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN ats_activities.id_ats_candidate IS 'The activity’s candidate.'; - - - - -- ************************************** acc_transactions_lines_items - CREATE TABLE acc_transactions_lines_items ( id_acc_transactions_lines_item uuid NOT NULL, @@ -1562,22 +1190,13 @@ CREATE TABLE acc_transactions_lines_items id_acc_transaction uuid NULL, CONSTRAINT PK_acc_transactions_lines_items PRIMARY KEY ( id_acc_transactions_lines_item ) ); - CREATE INDEX FK_acc_transactions_lineItems ON acc_transactions_lines_items ( id_acc_transaction ); - - - COMMENT ON COLUMN acc_transactions_lines_items.id_acc_company_info IS 'The company the line belongs to.'; - - - - -- ************************************** acc_purchase_orders - CREATE TABLE acc_purchase_orders ( id_acc_purchase_order uuid NOT NULL, @@ -1603,14 +1222,10 @@ CREATE TABLE acc_purchase_orders id_acc_accounting_period uuid NULL, CONSTRAINT PK_acc_purchase_orders PRIMARY KEY ( id_acc_purchase_order ) ); - CREATE INDEX FK_purchaseOrder_accountingPeriod ON acc_purchase_orders ( id_acc_accounting_period ); - - - COMMENT ON COLUMN acc_purchase_orders.status IS 'The purchase order''s status. Possible values include: DRAFT, SUBMITTED, AUTHORIZED, BILLED, DELETED. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN acc_purchase_orders.delivery_address IS 'contains a id_acc_address'; COMMENT ON COLUMN acc_purchase_orders.customer IS 'The contact making the purchase order. @@ -1618,12 +1233,7 @@ Contains a id_acc_contact'; COMMENT ON COLUMN acc_purchase_orders.vendor IS 'contains a id_acc_contact'; COMMENT ON COLUMN acc_purchase_orders.id_acc_accounting_period IS 'The accounting period that the PurchaseOrder was generated in.'; - - - - -- ************************************** acc_journal_entries - CREATE TABLE acc_journal_entries ( id_acc_journal_entry uuid NOT NULL, @@ -1646,26 +1256,16 @@ CREATE TABLE acc_journal_entries modified_at timestamp with time zone NOT NULL, CONSTRAINT PK_acc_journal_entries PRIMARY KEY ( id_acc_journal_entry ) ); - CREATE INDEX FK_journal_entry_accounting_period ON acc_journal_entries ( id_acc_accounting_period ); - CREATE INDEX FK_journal_entry_companyInfo ON acc_journal_entries ( id_acc_company_info ); - - - - - - - -- ************************************** acc_contacts - CREATE TABLE acc_contacts ( id_acc_contact uuid NOT NULL, @@ -1684,22 +1284,13 @@ CREATE TABLE acc_contacts modified_at timestamp with time zone NOT NULL, CONSTRAINT PK_acc_contacts PRIMARY KEY ( id_acc_contact ) ); - CREATE INDEX FK_acc_contact_company ON acc_contacts ( id_acc_company_info ); - - - COMMENT ON COLUMN acc_contacts.status IS 'The contact''s status Possible values include: ACTIVE, ARCHIVED. In cases where there is no clear mapping, the original value passed through will be returned.'; - - - - -- ************************************** acc_cash_flow_statement_report_items - CREATE TABLE acc_cash_flow_statement_report_items ( id_acc_cash_flow_statement_report_item uuid NOT NULL, @@ -1714,22 +1305,13 @@ CREATE TABLE acc_cash_flow_statement_report_items id_acc_cash_flow_statement uuid NULL, CONSTRAINT PK_acc_cash_flow_statement_report_items PRIMARY KEY ( id_acc_cash_flow_statement_report_item ) ); - CREATE INDEX FK_cashflow_statement_acc_cash_flow_statement_report_item ON acc_cash_flow_statement_report_items ( id_acc_cash_flow_statement ); - - - COMMENT ON COLUMN acc_cash_flow_statement_report_items.type IS 'can be operating, investing, financing'; - - - - -- ************************************** acc_balance_sheets - CREATE TABLE acc_balance_sheets ( id_acc_balance_sheet uuid NOT NULL, @@ -1748,25 +1330,16 @@ CREATE TABLE acc_balance_sheets id_connection uuid NOT NULL, CONSTRAINT PK_acc_balance_sheets PRIMARY KEY ( id_acc_balance_sheet ) ); - CREATE INDEX FK_balanceSheetCompanyInfoID ON acc_balance_sheets ( id_acc_company_info ); - - - COMMENT ON COLUMN acc_balance_sheets.net_assets IS 'The balance sheet''s net assets.'; COMMENT ON COLUMN acc_balance_sheets.assets IS 'array of id_acc_balance_sheets_report_item objects'; COMMENT ON COLUMN acc_balance_sheets.liabilities IS 'array of id_acc_balance_sheets_report_item objects'; COMMENT ON COLUMN acc_balance_sheets.equity IS 'array of id_acc_balance_sheets_report_item objects'; - - - - -- ************************************** acc_accounts - CREATE TABLE acc_accounts ( id_acc_account uuid NOT NULL, @@ -1786,26 +1359,17 @@ CREATE TABLE acc_accounts id_connection uuid NOT NULL, CONSTRAINT PK_acc_accounts PRIMARY KEY ( id_acc_account ) ); - CREATE INDEX FK_accounts_companyinfo_ID ON acc_accounts ( id_acc_company_info ); - - - COMMENT ON COLUMN acc_accounts.classification IS 'The account''s broadest grouping. Possible values include: ASSET, EQUITY, EXPENSE, LIABILITY, REVENUE. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN acc_accounts.type IS 'The account''s type is a narrower and more specific grouping within the account''s classification.'; COMMENT ON COLUMN acc_accounts.status IS 'The account''s status. Possible values include: ACTIVE, PENDING, INACTIVE. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN acc_accounts.current_balance IS 'Use cents. 100 USD would be 10000'; COMMENT ON COLUMN acc_accounts.currency IS 'Possible values include: XUA, AFN, AFA, ALL, ALK, DZD, ADP, AOA, AOK, AON, AOR, ARA, ARS, ARM, ARP, ARL, AMD, AWG, AUD, ATS, AZN, AZM, BSD, BHD, BDT, BBD, BYN, BYB, BYR, BEF, BEC, BEL, BZD, BMD, BTN, BOB, BOL, BOV, BOP, BAM, BAD, BAN, BWP, BRC, BRZ, BRE, BRR, BRN, BRB, BRL, GBP, BND, BGL, BGN, BGO, BGM, BUK, BIF, XPF, KHR, CAD, CVE, KYD, XAF, CLE, CLP, CLF, CNX, CNY, CNH, COP, COU, KMF, CDF, CRC, HRD, HRK, CUC, CUP, CYP, CZK, CSK, DKK, DJF, DOP, NLG, XCD, DDM, ECS, ECV, EGP, GQE, ERN, EEK, ETB, EUR, XBA, XEU, XBB, XBC, XBD, FKP, FJD, FIM, FRF, XFO, XFU, GMD, GEK, GEL, DEM, GHS, GHC, GIP, XAU, GRD, GTQ, GWP, GNF, GNS, GYD, HTG, HNL, HKD, HUF, IMP, ISK, ISJ, INR, IDR, IRR, IQD, IEP, ILS, ILP, ILR, ITL, JMD, JPY, JOD, KZT, KES, KWD, KGS, LAK, LVL, LVR, LBP, LSL, LRD, LYD, LTL, LTT, LUL, LUC, LUF, MOP, MKD, MKN, MGA, MGF, MWK, MYR, MVR, MVP, MLF, MTL, MTP, MRU, MRO, MUR, MXV, MXN, MXP, MDC, MDL, MCF, MNT, MAD, MAF, MZE, MZN, MZM, MMK, NAD, NPR, ANG, TWD, NZD, NIO, NIC, NGN, KPW, NOK, OMR, PKR, XPD, PAB, PGK, PYG, PEI, PEN, PES, PHP, XPT, PLN, PLZ, PTE, GWE, QAR, XRE, RHD, RON, ROL, RUB, RUR, RWF, SVC, WST, SAR, RSD, CSD, SCR, SLL, XAG, SGD, SKK, SIT, SBD, SOS, ZAR, ZAL, KRH, KRW, KRO, SSP, SUR, ESP, ESA, ESB, XDR, LKR, SHP, XSU, SDD, SDG, SDP, SRD, SRG, SZL, SEK, CHF, SYP, STN, STD, TVD, TJR, TJS, TZS, XTS, THB, XXX, TPE, TOP, TTD, TND, TRY, TRL, TMT, TMM, USD, USN, USS, UGX, UGS, UAH, UAK, AED, UYW, UYU, UYP, UYI, UZS, VUV, VES, VEB, VEF, VND, VNN, CHE, CHW, XOF, YDD, YER, YUN, YUD, YUM, YUR, ZWN, ZRN, ZRZ, ZMW, ZMK, ZWD, ZWR, ZWL. In cases where there is no clear mapping, the original value passed through will be returned.'; - - - - -- ************************************** value - CREATE TABLE value ( id_value uuid NOT NULL, @@ -1818,27 +1382,17 @@ CREATE TABLE value CONSTRAINT FK_33 FOREIGN KEY ( id_attribute ) REFERENCES attribute ( id_attribute ), CONSTRAINT FK_34 FOREIGN KEY ( id_entity ) REFERENCES entity ( id_entity ) ); - CREATE INDEX FK_value_attributeID ON value ( id_attribute ); - CREATE INDEX FK_value_entityID ON value ( id_entity ); - - - COMMENT ON COLUMN value.data IS 'can be: true, false, 0, 1 , 2 3 , 4 , hello, world ...'; - - - - -- ************************************** tcg_tags - CREATE TABLE tcg_tags ( id_tcg_tag uuid NOT NULL, @@ -1853,21 +1407,12 @@ CREATE TABLE tcg_tags CONSTRAINT PK_tcg_tags PRIMARY KEY ( id_tcg_tag ), CONSTRAINT FK_48 FOREIGN KEY ( id_tcg_ticket ) REFERENCES tcg_tickets ( id_tcg_ticket ) ); - CREATE INDEX FK_tcg_tag_tcg_ticketID ON tcg_tags ( id_tcg_ticket ); - - - - - - - -- ************************************** tcg_comments - CREATE TABLE tcg_comments ( id_tcg_comment uuid NOT NULL, @@ -1876,46 +1421,36 @@ CREATE TABLE tcg_comments is_private boolean NULL, remote_id text NULL, remote_platform text NULL, - created_at timestamp NULL, - modified_at timestamp NULL, creator_type text NULL, id_tcg_attachment text[] NULL, id_tcg_ticket uuid NULL, id_tcg_contact uuid NULL, id_tcg_user uuid NULL, id_linked_user uuid NULL, + created_at timestamp NULL, + modified_at timestamp NULL, id_connection uuid NOT NULL, CONSTRAINT PK_tcg_comments PRIMARY KEY ( id_tcg_comment ), CONSTRAINT FK_41 FOREIGN KEY ( id_tcg_contact ) REFERENCES tcg_contacts ( id_tcg_contact ), CONSTRAINT FK_40_1 FOREIGN KEY ( id_tcg_ticket ) REFERENCES tcg_tickets ( id_tcg_ticket ), CONSTRAINT FK_42 FOREIGN KEY ( id_tcg_user ) REFERENCES tcg_users ( id_tcg_user ) ); - CREATE INDEX FK_tcg_comment_tcg_contact ON tcg_comments ( id_tcg_contact ); - CREATE INDEX FK_tcg_comment_tcg_ticket ON tcg_comments ( id_tcg_ticket ); - CREATE INDEX FK_tcg_comment_tcg_userID ON tcg_comments ( id_tcg_user ); - COMMENT ON TABLE tcg_comments IS 'The tcg_comment object represents a comment on a ticket.'; - COMMENT ON COLUMN tcg_comments.creator_type IS 'Who created the comment. Can be a a id_tcg_contact or a id_tcg_user'; - - - - -- ************************************** linked_users - CREATE TABLE linked_users ( id_linked_user uuid NOT NULL, @@ -1925,23 +1460,14 @@ CREATE TABLE linked_users CONSTRAINT key_id_linked_users PRIMARY KEY ( id_linked_user ), CONSTRAINT FK_10 FOREIGN KEY ( id_project ) REFERENCES projects ( id_project ) ); - CREATE INDEX FK_proectID_linked_users ON linked_users ( id_project ); - - - COMMENT ON COLUMN linked_users.linked_user_origin_id IS 'id of the customer, in our customers own systems'; COMMENT ON COLUMN linked_users.alias IS 'human-readable alias, for UI (ex ACME company)'; - - - - -- ************************************** fs_files - CREATE TABLE fs_files ( id_fs_file uuid NOT NULL, @@ -1957,26 +1483,69 @@ CREATE TABLE fs_files id_connection uuid NOT NULL, CONSTRAINT PK_fs_files PRIMARY KEY ( id_fs_file ) ); - CREATE INDEX FK_fs_file_FolderID ON fs_files ( id_fs_folder ); - CREATE INDEX FK_fs_file_permissionID ON fs_files ( id_fs_permission ); +-- ************************************** ecom_fulfilments +CREATE TABLE ecom_fulfilments +( + id_ecom_fulfilment uuid NOT NULL, + carrier text NULL, + tracking_urls text[] NULL, + tracking_numbers text[] NULL, + items jsonb NULL, + remote_id text NULL, + id_ecom_order uuid NULL, + id_connection uuid NOT NULL, + modified_at timestamp with time zone NOT NULL, + created_at timestamp with time zone NOT NULL, + remote_deleted boolean NOT NULL, + CONSTRAINT PK_ecom_fulfilments PRIMARY KEY ( id_ecom_fulfilment ), + CONSTRAINT FK_ecom_order_fulfilment FOREIGN KEY ( id_ecom_order ) REFERENCES ecom_orders ( id_ecom_order ) +); +CREATE INDEX FK_index_ecom_order_fulfilment ON ecom_fulfilments +( + id_ecom_order +); +COMMENT ON COLUMN ecom_fulfilments.items IS 'array of ecom_products info'; - - - - - +-- ************************************** ecom_addresses +CREATE TABLE ecom_addresses +( + id_ecom_address uuid NOT NULL, + address_type text NULL, + street_1 text NULL, + street_2 text NULL, + city text NULL, + "state" text NULL, + postal_code text NULL, + country text NULL, + id_ecom_customer uuid NOT NULL, + modified_at timestamp with time zone NOT NULL, + created_at timestamp with time zone NOT NULL, + remote_deleted boolean NOT NULL, + id_ecom_order uuid NOT NULL, + CONSTRAINT PK_ecom_customer_addresses PRIMARY KEY ( id_ecom_address ), + CONSTRAINT FK_ecom_customer_customeraddress FOREIGN KEY ( id_ecom_customer ) REFERENCES ecom_customers ( id_ecom_customer ), + CONSTRAINT FK_ecom_order_address FOREIGN KEY ( id_ecom_order ) REFERENCES ecom_orders ( id_ecom_order ) +); +CREATE INDEX FK_index_ecom_customer_customeraddress ON ecom_addresses +( + id_ecom_customer +); +CREATE INDEX FK_index_FK_ecom_order_address ON ecom_addresses +( + id_ecom_order +); +COMMENT ON COLUMN ecom_addresses.address_type IS 'billing, shipping, other'; -- ************************************** crm_phone_numbers - CREATE TABLE crm_phone_numbers ( id_crm_phone_number uuid NOT NULL, @@ -1992,27 +1561,17 @@ CREATE TABLE crm_phone_numbers CONSTRAINT FK_phonenumber_crm_contactID FOREIGN KEY ( id_crm_contact ) REFERENCES crm_contacts ( id_crm_contact ), CONSTRAINT FK_17 FOREIGN KEY ( id_crm_company ) REFERENCES crm_companies ( id_crm_company ) ); - CREATE INDEX crm_contactID_crm_contact_phone_number ON crm_phone_numbers ( id_crm_contact ); - CREATE INDEX FK_phone_number_companyID ON crm_phone_numbers ( id_crm_company ); - - - COMMENT ON COLUMN crm_phone_numbers.owner_type IS 'can be ''COMPANY'' or ''CONTACT'' - helps locate who to link the phone number to.'; - - - - -- ************************************** crm_engagements - CREATE TABLE crm_engagements ( id_crm_engagement uuid NOT NULL, @@ -2035,30 +1594,19 @@ CREATE TABLE crm_engagements CONSTRAINT FK_crm_engagement_crm_user FOREIGN KEY ( id_crm_user ) REFERENCES crm_users ( id_crm_user ), CONSTRAINT FK_29 FOREIGN KEY ( id_crm_company ) REFERENCES crm_companies ( id_crm_company ) ); - CREATE INDEX FK_crm_engagement_crm_user_ID ON crm_engagements ( id_crm_user ); - CREATE INDEX FK_crm_engagement_crmCompanyID ON crm_engagements ( id_crm_company ); - - - COMMENT ON COLUMN crm_engagements.type IS 'can be (but not restricted to) - MEETING, CALL, EMAIL'; COMMENT ON COLUMN crm_engagements.contacts IS 'array of id_crm_contact (uuids)'; - - - - -- ************************************** crm_email_addresses - CREATE TABLE crm_email_addresses ( id_crm_email uuid NOT NULL, @@ -2074,32 +1622,22 @@ CREATE TABLE crm_email_addresses CONSTRAINT FK_3 FOREIGN KEY ( id_crm_contact ) REFERENCES crm_contacts ( id_crm_contact ), CONSTRAINT FK_16 FOREIGN KEY ( id_crm_company ) REFERENCES crm_companies ( id_crm_company ) ); - CREATE INDEX crm_contactID_crm_contact_email_address ON crm_email_addresses ( id_crm_contact ); - CREATE INDEX FK_contact_email_adress_companyID ON crm_email_addresses ( id_crm_company ); - - - COMMENT ON COLUMN crm_email_addresses.owner_type IS 'can be ''COMPANY'' or ''CONTACT'' - helps locate who to link the email belongs to.'; - - - - -- ************************************** crm_deals - CREATE TABLE crm_deals ( id_crm_deal uuid NOT NULL, name text NOT NULL, - description text NOT NULL, + description text NULL, amount bigint NOT NULL, created_at timestamp NOT NULL, modified_at timestamp NOT NULL, @@ -2115,32 +1653,21 @@ CREATE TABLE crm_deals CONSTRAINT FK_21 FOREIGN KEY ( id_crm_deals_stage ) REFERENCES crm_deals_stages ( id_crm_deals_stage ), CONSTRAINT FK_47_1 FOREIGN KEY ( id_crm_company ) REFERENCES crm_companies ( id_crm_company ) ); - CREATE INDEX crm_deal_crm_userID ON crm_deals ( id_crm_user ); - CREATE INDEX crm_deal_deal_stageID ON crm_deals ( id_crm_deals_stage ); - CREATE INDEX FK_crm_deal_crmCompanyID ON crm_deals ( id_crm_company ); - - - COMMENT ON COLUMN crm_deals.amount IS 'AMOUNT IN CENTS'; - - - - -- ************************************** crm_addresses - CREATE TABLE crm_addresses ( id_crm_address uuid NOT NULL, @@ -2161,30 +1688,19 @@ CREATE TABLE crm_addresses CONSTRAINT FK_14 FOREIGN KEY ( id_crm_contact ) REFERENCES crm_contacts ( id_crm_contact ), CONSTRAINT FK_15 FOREIGN KEY ( id_crm_company ) REFERENCES crm_companies ( id_crm_company ) ); - CREATE INDEX FK_crm_addresses_to_crm_contacts ON crm_addresses ( id_crm_contact ); - CREATE INDEX FK_crm_adresses_to_crm_companies ON crm_addresses ( id_crm_company ); - - - COMMENT ON COLUMN crm_addresses.owner_type IS 'Can be a company or a contact''s address - ''company'' ''contact'''; - - - - -- ************************************** ats_offers - CREATE TABLE ats_offers ( id_ats_offer uuid NOT NULL, @@ -2201,23 +1717,14 @@ CREATE TABLE ats_offers id_connection uuid NOT NULL, CONSTRAINT PK_ats_offers PRIMARY KEY ( id_ats_offer ) ); - CREATE INDEX FK_ats_offers_applicationID ON ats_offers ( id_ats_application ); - - - COMMENT ON COLUMN ats_offers.created_by IS 'the ats_user who created this ID'; COMMENT ON COLUMN ats_offers.status IS 'The offer''s status. Possible values include: DRAFT, APPROVAL-SENT, APPROVED, SENT, SENT-MANUALLY, OPENED, DENIED, SIGNED, DEPRECATED. In cases where there is no clear mapping, the original value passed through will be returned.'; - - - - -- ************************************** ats_interviews - CREATE TABLE ats_interviews ( id_ats_interview uuid NOT NULL, @@ -2237,30 +1744,20 @@ CREATE TABLE ats_interviews id_connection uuid NOT NULL, CONSTRAINT PK_ats_interviews PRIMARY KEY ( id_ats_interview ) ); - CREATE INDEX FK_applications_interviews ON ats_interviews ( id_ats_application ); - CREATE INDEX FK_id_ats_job_interview_stageID ON ats_interviews ( id_ats_job_interview_stage ); - - - COMMENT ON COLUMN ats_interviews.status IS 'The interview''s status. Possible values include: SCHEDULED, AWAITING_FEEDBACK, COMPLETE. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN ats_interviews.organized_by IS 'The user organizing the interview. Data is a id_ats_user.'; COMMENT ON COLUMN ats_interviews.interviewers IS 'Array of RemoteUser IDs.'; COMMENT ON COLUMN ats_interviews.id_ats_job_interview_stage IS 'The stage of the interview.'; - - - - -- ************************************** api_keys - CREATE TABLE api_keys ( id_api_key uuid NOT NULL, @@ -2273,26 +1770,16 @@ CREATE TABLE api_keys CONSTRAINT FK_8 FOREIGN KEY ( id_user ) REFERENCES users ( id_user ), CONSTRAINT FK_7 FOREIGN KEY ( id_project ) REFERENCES projects ( id_project ) ); - CREATE INDEX FK_2 ON api_keys ( id_user ); - CREATE INDEX FK_api_keys_projects ON api_keys ( id_project ); - - - - - - - -- ************************************** acc_purchase_orders_line_items - CREATE TABLE acc_purchase_orders_line_items ( id_acc_purchase_orders_line_item uuid NOT NULL, @@ -2312,21 +1799,12 @@ CREATE TABLE acc_purchase_orders_line_items id_acc_company uuid NULL, CONSTRAINT PK_acc_purchase_orders_line_items PRIMARY KEY ( id_acc_purchase_orders_line_item ) ); - CREATE INDEX FK_purchaseorder_purchaseorderLineItems ON acc_purchase_orders_line_items ( id_acc_purchase_order ); - - - - - - - -- ************************************** acc_phone_numbers - CREATE TABLE acc_phone_numbers ( id_acc_phone_number uuid NOT NULL, @@ -2339,28 +1817,18 @@ CREATE TABLE acc_phone_numbers id_connection uuid NOT NULL, CONSTRAINT PK_acc_phone_numbers PRIMARY KEY ( id_acc_phone_number ) ); - CREATE INDEX FK_acc_phone_number_contact ON acc_phone_numbers ( id_acc_contact ); - CREATE INDEX FK_company_infos_phone_number ON acc_phone_numbers ( id_acc_company_info ); - - - COMMENT ON COLUMN acc_phone_numbers.id_acc_company_info IS 'holds a valueif if the phone number belongs to a acc_company_infos objects'; COMMENT ON COLUMN acc_phone_numbers.id_acc_contact IS 'holds a valueif if the phone number belongs to a acc_contact object'; - - - - -- ************************************** acc_journal_entries_lines - CREATE TABLE acc_journal_entries_lines ( id_acc_journal_entries_line uuid NOT NULL, @@ -2377,21 +1845,12 @@ CREATE TABLE acc_journal_entries_lines id_acc_journal_entry uuid NOT NULL, CONSTRAINT PK_acc_journal_entries_lines PRIMARY KEY ( id_acc_journal_entries_line ) ); - CREATE INDEX FK_journal_entries_entries_lines ON acc_journal_entries_lines ( id_acc_journal_entry ); - - - - - - - -- ************************************** acc_items - CREATE TABLE acc_items ( id_acc_item uuid NOT NULL, @@ -2409,32 +1868,21 @@ CREATE TABLE acc_items id_connection uuid NOT NULL, CONSTRAINT PK_acc_items PRIMARY KEY ( id_acc_item ) ); - CREATE INDEX FK_acc_item_acc_account ON acc_items ( purchase_account ); - CREATE INDEX FK_acc_item_acc_company_infos ON acc_items ( id_acc_company_info ); - CREATE INDEX FK_acc_items_sales_account ON acc_items ( sales_account ); - - - COMMENT ON COLUMN acc_items.status IS 'The item''s status. Possible values include: ACTIVE, ARCHIVED. In cases where there is no clear mapping, the original value passed through will be returned.'; - - - - -- ************************************** acc_invoices - CREATE TABLE acc_invoices ( id_acc_invoice uuid NOT NULL, @@ -2462,29 +1910,19 @@ CREATE TABLE acc_invoices tracking_categories text[] NULL, CONSTRAINT PK_acc_invoices PRIMARY KEY ( id_acc_invoice ) ); - CREATE INDEX FK_acc_invoice_accounting_period_index ON acc_invoices ( id_acc_accounting_period ); - CREATE INDEX FK_invoice_contactID ON acc_invoices ( id_acc_contact ); - - - COMMENT ON COLUMN acc_invoices.type IS 'Whether the invoice is an accounts receivable or accounts payable. If type is ACCOUNTS_PAYABLE, the invoice is a bill. If type is ACCOUNTS_RECEIVABLE, it is an invoice. Possible values include: ACCOUNTS_RECEIVABLE, ACCOUNTS_PAYABLE. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN acc_invoices.total_discount IS 'The total discounts applied to the total cost.'; COMMENT ON COLUMN acc_invoices.status IS 'The status of the invoice. Possible values include: PAID, DRAFT, SUBMITTED, PARTIALLY_PAID, OPEN, VOID. In cases where there is no clear mapping, the original value passed through will be returned.'; - - - - -- ************************************** acc_expenses - CREATE TABLE acc_expenses ( id_acc_expense uuid NOT NULL, @@ -2506,34 +1944,23 @@ CREATE TABLE acc_expenses tracking_categories text[] NULL, CONSTRAINT PK_acc_expenses PRIMARY KEY ( id_acc_expense ) ); - CREATE INDEX FK_acc_account_acc_expense_index ON acc_expenses ( id_acc_account ); - CREATE INDEX FK_acc_expense_acc_company_index ON acc_expenses ( id_acc_company_info ); - CREATE INDEX FK_acc_expense_acc_contact_index ON acc_expenses ( id_acc_contact ); - - - COMMENT ON COLUMN acc_expenses.transaction_date IS 'When the transaction occurred.'; COMMENT ON COLUMN acc_expenses.remote_created_at IS 'When the expense was created.'; COMMENT ON COLUMN acc_expenses.tracking_categories IS 'array of id_acc_tracking_category'; - - - - -- ************************************** acc_attachments - CREATE TABLE acc_attachments ( id_acc_attachment uuid NOT NULL, @@ -2546,21 +1973,12 @@ CREATE TABLE acc_attachments id_connection uuid NOT NULL, CONSTRAINT PK_acc_attachments PRIMARY KEY ( id_acc_attachment ) ); - CREATE INDEX FK_acc_attachments_accountID ON acc_attachments ( id_acc_account ); - - - - - - - -- ************************************** acc_addresses - CREATE TABLE acc_addresses ( id_acc_address uuid NOT NULL, @@ -2579,31 +1997,22 @@ CREATE TABLE acc_addresses id_connection uuid NOT NULL, CONSTRAINT PK_acc_addresses PRIMARY KEY ( id_acc_address ) ); - CREATE INDEX FK_acc_company_info_acc_adresses ON acc_addresses ( id_acc_company_info ); - CREATE INDEX FK_acc_contact_acc_addresses ON acc_addresses ( id_acc_contact ); - COMMENT ON TABLE acc_addresses IS 'The Address object is used to represent a contact''s or company''s address.'; - COMMENT ON COLUMN acc_addresses.type IS 'can be SHIPPING, BILLING, OFFICES, PO....'; COMMENT ON COLUMN acc_addresses."state" IS 'can also be a region'; COMMENT ON COLUMN acc_addresses.country_subdivision IS 'Also called a "departement" in some countries (ex: france)'; COMMENT ON COLUMN acc_addresses.id_acc_contact IS 'contains a value if the acc_address belongs to an acc_contact object'; COMMENT ON COLUMN acc_addresses.id_acc_company_info IS 'contains a value if the acc_address belongs to an acc_company_info object'; - - - - -- ************************************** tcg_attachments - CREATE TABLE tcg_attachments ( id_tcg_attachment uuid NOT NULL, @@ -2622,29 +2031,19 @@ CREATE TABLE tcg_attachments CONSTRAINT FK_51 FOREIGN KEY ( id_tcg_comment ) REFERENCES tcg_comments ( id_tcg_comment ), CONSTRAINT FK_50 FOREIGN KEY ( id_tcg_ticket ) REFERENCES tcg_tickets ( id_tcg_ticket ) ); - CREATE INDEX FK_tcg_attachment_tcg_commentID ON tcg_attachments ( id_tcg_comment ); - CREATE INDEX FK_tcg_attachment_tcg_ticketID ON tcg_attachments ( id_tcg_ticket ); - - - COMMENT ON COLUMN tcg_attachments.remote_id IS 'If empty, means the file is stored is panora but not in the destination platform (often because the platform doesn''t support )'; COMMENT ON COLUMN tcg_attachments.uploader IS 'id_tcg_user who uploaded the file'; COMMENT ON COLUMN tcg_attachments.id_tcg_ticket IS 'For cases where the ticketing platform does not specify which comment the attachment belongs to.'; - - - - -- ************************************** invite_links - CREATE TABLE invite_links ( id_invite_link uuid NOT NULL, @@ -2654,21 +2053,12 @@ CREATE TABLE invite_links CONSTRAINT PK_invite_links PRIMARY KEY ( id_invite_link ), CONSTRAINT FK_37 FOREIGN KEY ( id_linked_user ) REFERENCES linked_users ( id_linked_user ) ); - CREATE INDEX FK_invite_link_linkedUserID ON invite_links ( id_linked_user ); - - - - - - - -- ************************************** events - CREATE TABLE events ( id_event uuid NOT NULL, @@ -2683,23 +2073,14 @@ CREATE TABLE events CONSTRAINT PK_jobs PRIMARY KEY ( id_event ), CONSTRAINT FK_12 FOREIGN KEY ( id_linked_user ) REFERENCES linked_users ( id_linked_user ) ); - CREATE INDEX FK_linkeduserID_projectID ON events ( id_linked_user ); - - - COMMENT ON COLUMN events.status IS 'pending,, retry_scheduled, failed, success'; COMMENT ON COLUMN events.type IS 'example crm_contact.created crm_contact.deleted'; - - - - -- ************************************** crm_tasks - CREATE TABLE crm_tasks ( id_crm_task uuid NOT NULL, @@ -2722,31 +2103,20 @@ CREATE TABLE crm_tasks CONSTRAINT FK_25 FOREIGN KEY ( id_crm_user ) REFERENCES crm_users ( id_crm_user ), CONSTRAINT FK_27 FOREIGN KEY ( id_crm_deal ) REFERENCES crm_deals ( id_crm_deal ) ); - CREATE INDEX FK_crm_task_companyID ON crm_tasks ( id_crm_company ); - CREATE INDEX FK_crm_task_userID ON crm_tasks ( id_crm_user ); - CREATE INDEX FK_crmtask_dealID ON crm_tasks ( id_crm_deal ); - - - - - - - -- ************************************** crm_notes - CREATE TABLE crm_notes ( id_crm_note uuid NOT NULL, @@ -2766,36 +2136,24 @@ CREATE TABLE crm_notes CONSTRAINT FK_18 FOREIGN KEY ( id_crm_company ) REFERENCES crm_companies ( id_crm_company ), CONSTRAINT FK_20 FOREIGN KEY ( id_crm_deal ) REFERENCES crm_deals ( id_crm_deal ) ); - CREATE INDEX FK_crm_note_crm_companyID ON crm_notes ( id_crm_contact ); - CREATE INDEX FK_crm_note_crm_contactID ON crm_notes ( id_crm_company ); - CREATE INDEX FK_crm_note_crm_userID ON crm_notes ( id_crm_user ); - CREATE INDEX FK_crm_notes_crm_dealID ON crm_notes ( id_crm_deal ); - - - - - - - -- ************************************** connections - CREATE TABLE connections ( id_connection uuid NOT NULL, @@ -2815,29 +2173,19 @@ CREATE TABLE connections CONSTRAINT FK_9 FOREIGN KEY ( id_project ) REFERENCES projects ( id_project ), CONSTRAINT FK_11 FOREIGN KEY ( id_linked_user ) REFERENCES linked_users ( id_linked_user ) ); - CREATE INDEX FK_1 ON connections ( id_project ); - CREATE INDEX FK_connections_to_LinkedUsersID ON connections ( id_linked_user ); - - - COMMENT ON COLUMN connections.status IS 'ONLY FOR INVITE LINK'; COMMENT ON COLUMN connections.token_type IS 'The type of the token, such as "Bearer," "JWT," or any other supported type.'; COMMENT ON COLUMN connections.connection_token IS 'Connection token users will put in their header to identify which service / linked_User they make request for'; - - - - -- ************************************** ats_scorecards - CREATE TABLE ats_scorecards ( id_ats_scorecard uuid NOT NULL, @@ -2852,29 +2200,19 @@ CREATE TABLE ats_scorecards id_connection uuid NOT NULL, CONSTRAINT PK_ats_scorecards PRIMARY KEY ( id_ats_scorecard ) ); - CREATE INDEX FK_applications_scorecard ON ats_scorecards ( id_ats_application ); - CREATE INDEX FK_interviews_scorecards ON ats_scorecards ( id_ats_interview ); - - - COMMENT ON COLUMN ats_scorecards.overall_recommendation IS 'The inteviewer''s recommendation. Possible values include: DEFINITELY_NO, NO, YES, STRONG_YES, NO_DECISION. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN ats_scorecards.id_ats_application IS 'The application being scored.'; COMMENT ON COLUMN ats_scorecards.id_ats_interview IS 'The interview being scored.'; - - - - -- ************************************** acc_payments - CREATE TABLE acc_payments ( id_acc_payment uuid NOT NULL, @@ -2895,45 +2233,32 @@ CREATE TABLE acc_payments tracking_categories text[] NULL, CONSTRAINT PK_acc_payments PRIMARY KEY ( id_acc_payment ) ); - CREATE INDEX FK_acc_payment_acc_account_index ON acc_payments ( id_acc_account ); - CREATE INDEX FK_acc_payment_acc_company_index ON acc_payments ( id_acc_company_info ); - CREATE INDEX FK_acc_payment_acc_contact ON acc_payments ( id_acc_contact ); - CREATE INDEX FK_acc_payment_accounting_period_index ON acc_payments ( id_acc_accounting_period ); - CREATE INDEX FK_acc_payment_invoiceID ON acc_payments ( id_acc_invoice ); - - - COMMENT ON COLUMN acc_payments.id_acc_contact IS 'The supplier, or customer involved in the payment.'; COMMENT ON COLUMN acc_payments.id_acc_account IS 'The supplier’s or customer’s account in which the payment is made.'; COMMENT ON COLUMN acc_payments.type IS 'The type of the invoice. Possible values include: ACCOUNTS_PAYABLE, ACCOUNTS_RECEIVABLE. In cases where there is no clear mapping, the original value passed through will be returned.'; COMMENT ON COLUMN acc_payments.id_acc_company_info IS 'The company the payment belongs to.'; - - - - -- ************************************** acc_invoices_line_items - CREATE TABLE acc_invoices_line_items ( id_acc_invoices_line_item uuid NOT NULL, @@ -2952,26 +2277,16 @@ CREATE TABLE acc_invoices_line_items acc_tracking_categories text[] NULL, CONSTRAINT PK_acc_invoices_line_items PRIMARY KEY ( id_acc_invoices_line_item ) ); - CREATE INDEX FK_acc_invoice_line_items_index ON acc_invoices_line_items ( id_acc_invoice ); - CREATE INDEX FK_acc_items_lines_invoice_index ON acc_invoices_line_items ( id_acc_item ); - - - - - - - -- ************************************** acc_expense_lines - CREATE TABLE acc_expense_lines ( id_acc_expense_line uuid NOT NULL, @@ -2986,21 +2301,12 @@ CREATE TABLE acc_expense_lines id_connection uuid NOT NULL, CONSTRAINT PK_acc_expense_lines PRIMARY KEY ( id_acc_expense_line ) ); - CREATE INDEX FK_acc_expense_expense_lines_index ON acc_expense_lines ( id_acc_expense ); - - - - - - - -- ************************************** webhook_delivery_attempts - CREATE TABLE webhook_delivery_attempts ( id_webhook_delivery_attempt uuid NOT NULL, @@ -3018,44 +2324,30 @@ CREATE TABLE webhook_delivery_attempts CONSTRAINT FK_39 FOREIGN KEY ( id_event ) REFERENCES events ( id_event ), CONSTRAINT FK_40 FOREIGN KEY ( id_webhooks_reponse ) REFERENCES webhooks_reponses ( id_webhooks_reponse ) ); - CREATE INDEX FK_we_payload_webhookID ON webhook_delivery_attempts ( id_webhooks_payload ); - CREATE INDEX FK_we_webhookEndpointID ON webhook_delivery_attempts ( id_webhook_endpoint ); - CREATE INDEX FK_webhook_delivery_attempt_eventID ON webhook_delivery_attempts ( id_event ); - CREATE INDEX FK_webhook_delivery_attempt_webhook_responseID ON webhook_delivery_attempts ( id_webhooks_reponse ); - - - COMMENT ON COLUMN webhook_delivery_attempts."timestamp" IS 'timestamp of the delivery attempt'; COMMENT ON COLUMN webhook_delivery_attempts.status IS 'status of the delivery attempt - can be success, retry, failure'; COMMENT ON COLUMN webhook_delivery_attempts.next_retry IS 'if null no next retry'; COMMENT ON COLUMN webhook_delivery_attempts.attempt_count IS 'Number of attempt - can be 0 1 2 3 4 5 6'; - - - - -- ************************************** jobs_status_history - CREATE TABLE jobs_status_history ( id_jobs_status_history uuid NOT NULL, @@ -3066,23 +2358,14 @@ CREATE TABLE jobs_status_history CONSTRAINT PK_jobs_status_history PRIMARY KEY ( id_jobs_status_history ), CONSTRAINT FK_4 FOREIGN KEY ( id_event ) REFERENCES events ( id_event ) ); - CREATE INDEX id_job_jobs_status_history ON jobs_status_history ( id_event ); - - - COMMENT ON COLUMN jobs_status_history.previous_status IS 'void when first initialization'; COMMENT ON COLUMN jobs_status_history.new_status IS 'pending, retry_scheduled, failed, success'; - - - - -- ************************************** acc_payments_line_items - CREATE TABLE acc_payments_line_items ( acc_payments_line_item uuid NOT NULL, @@ -3097,16 +2380,9 @@ CREATE TABLE acc_payments_line_items id_connection uuid NOT NULL, CONSTRAINT PK_acc_payments_line_items PRIMARY KEY ( acc_payments_line_item ) ); - CREATE INDEX FK_acc_payment_line_items_index ON acc_payments_line_items ( id_acc_payment ); - - - COMMENT ON COLUMN acc_payments_line_items.related_object_type IS 'can either be a Invoice, CreditNote, or JournalEntry'; - - - diff --git a/packages/api/src/@core/auth/auth.controller.ts b/packages/api/src/@core/auth/auth.controller.ts index b777285bc..182200260 100644 --- a/packages/api/src/@core/auth/auth.controller.ts +++ b/packages/api/src/@core/auth/auth.controller.ts @@ -22,6 +22,9 @@ import { import { ApiKeyDto } from './dto/api-key.dto'; import { LoginDto } from './dto/login.dto'; import { RefreshDto } from './dto/refresh.dto'; +import { ResetPasswordDto } from './dto/reset-password.dto'; +import { RequestPasswordResetDto } from './dto/request-password-reset.dto'; + @ApiTags('auth') @ApiExcludeController() @@ -42,6 +45,11 @@ export class AuthController { return this.authService.register(user); } + @Post('request-password-reset') + async requestPasswordReset(@Body() requestPasswordResetDto: RequestPasswordResetDto) { + return this.authService.requestPasswordReset(requestPasswordResetDto); + } + @ApiOperation({ operationId: 'signIn', summary: 'Log In' }) @ApiBody({ type: LoginDto }) @ApiResponse({ status: 201 }) @@ -58,6 +66,14 @@ export class AuthController { return this.authService.getUsers(); } + @ApiOperation({ operationId: 'resetPassword', summary: 'Reset Password' }) + @ApiBody({ type: ResetPasswordDto }) + @ApiResponse({ status: 200, description: 'Password reset successfully' }) + @Post('reset-password') + async resetPassword(@Body() resetPasswordDto: ResetPasswordDto) { + return this.authService.resetPassword(resetPasswordDto); + } + @ApiResponse({ status: 201 }) @UseGuards(JwtAuthGuard) @Get('profile') diff --git a/packages/api/src/@core/auth/auth.service.ts b/packages/api/src/@core/auth/auth.service.ts index ebd9461b5..e47a17249 100644 --- a/packages/api/src/@core/auth/auth.service.ts +++ b/packages/api/src/@core/auth/auth.service.ts @@ -1,7 +1,7 @@ import { LoggerService } from '@@core/@core-services/logger/logger.service'; import { ProjectsService } from '@@core/projects/projects.service'; import { AuthError } from '@@core/utils/errors'; -import { Injectable } from '@nestjs/common'; +import { Injectable, BadRequestException } from '@nestjs/common'; import { JwtService } from '@nestjs/jwt'; import * as bcrypt from 'bcrypt'; import * as crypto from 'crypto'; @@ -11,6 +11,9 @@ import { CreateUserDto } from './dto/create-user.dto'; import { LoginDto } from './dto/login.dto'; import { VerifyUserDto } from './dto/verify-user.dto'; import { ConflictException } from '@nestjs/common'; +import { ResetPasswordDto } from './dto/reset-password.dto'; +import { RequestPasswordResetDto } from './dto/request-password-reset.dto'; +import * as nodemailer from 'nodemailer'; @Injectable() export class AuthService { @@ -23,6 +26,108 @@ export class AuthService { this.logger.setContext(AuthService.name); } + async resetPassword(resetPasswordDto: ResetPasswordDto) { + const { email, newPassword, resetToken } = resetPasswordDto; + + // verify there is a user with corresponding email and non-expired reset token + const checkResetRequestIsValid = await this.prisma.users.findFirst({ + where: { + email: email, + reset_token_expires_at: { + gt: new Date(), + }, + }, + }); + + if (!checkResetRequestIsValid) { + throw new BadRequestException('Invalid email or expired request'); + } + + // Verify the reset token + const isValidToken = await this.verifyResetToken(checkResetRequestIsValid.reset_token, resetToken); + + if (!isValidToken) { + throw new BadRequestException('Invalid reset token'); + } + + // Hash the new password + const hashedPassword = await bcrypt.hash(newPassword, 10); + + // Update the user's password in the database + const updatedPassword =await this.prisma.users.update({ + where: { email }, + data: { password_hash: hashedPassword }, + }); + console.log(updatedPassword); + return { message: 'Password reset successfully' }; + } + + private async verifyResetToken(database_token: string, request_token: string): Promise { + const isValidToken = await bcrypt.compare(request_token, database_token); + return isValidToken; + } + + + async requestPasswordReset(requestPasswordResetDto: RequestPasswordResetDto) { + const { email } = requestPasswordResetDto; + + if (!email){ + throw new BadRequestException('Incorrect API request'); + } + + const user = await this.prisma.users.findUnique({ + where: { email }, + }); + + if (!user) { + throw new BadRequestException('Email not found'); + } + + const resetToken = uuidv4(); + const hashedResetToken = await bcrypt.hash(resetToken, 10); + const resetTokenExpiresAt = new Date(Date.now() + 3600 * 1000); // 1 hour from now + + await this.prisma.users.update({ + where: { email }, + data: { + reset_token: hashedResetToken, + reset_token_expires_at: resetTokenExpiresAt, + }, + }); + + // Send email with resetToken (implementation depends on your email service) + await this.sendResetEmail(email, resetToken); + return { message: 'Password reset link sent' }; + } + + private async sendResetEmail(email: string, resetToken: string) { + const resetLink = `${process.env.PANORA_BASE_API_URL}/reset-password?token=${resetToken}&email=${email}`; + + // Create a transporter object using the default SMTP transport + const transporter = nodemailer.createTransport({ + host: process.env.SMTP_HOST, + port: Number(process.env.SMTP_PORT), + //secure: false, + auth: { + user: process.env.SMTP_USER, + pass: process.env.SMTP_PASSWORD, + } + }); + + // Send mail with defined transport object + const info = await transporter.sendMail({ + from: `${process.env.EMAIL_SENDING_ADDRESS}`, + to: email, + subject: 'Panora | Password Reset Request', + text: `You requested a password reset. Click the following link within one hour from now to reset your password: ${resetLink}`, + html: `

You requested a password reset. Click the link to reset your password:

${resetLink}

The link will expire after one hour

`, + }); + + this.logger.log(`Send reset email to ${email} with token ${resetToken}`); + } + + + async getUsers() { try { return await this.prisma.users.findMany(); @@ -270,6 +375,8 @@ export class AuthService { } } + + async getProjectIdForApiKey(apiKey: string) { try { // Decode the JWT to verify if it's valid and get the payload diff --git a/packages/api/src/@core/auth/dto/request-password-reset.dto.ts b/packages/api/src/@core/auth/dto/request-password-reset.dto.ts new file mode 100644 index 000000000..b9c3dd3c2 --- /dev/null +++ b/packages/api/src/@core/auth/dto/request-password-reset.dto.ts @@ -0,0 +1,6 @@ +import { IsEmail } from 'class-validator'; + +export class RequestPasswordResetDto { + @IsEmail() + email: string; +} \ No newline at end of file diff --git a/packages/api/src/@core/auth/dto/reset-password.dto.ts b/packages/api/src/@core/auth/dto/reset-password.dto.ts new file mode 100644 index 000000000..1d695356e --- /dev/null +++ b/packages/api/src/@core/auth/dto/reset-password.dto.ts @@ -0,0 +1,18 @@ +import { ApiProperty } from '@nestjs/swagger'; +import { IsEmail, IsNotEmpty, IsString } from 'class-validator'; + +export class ResetPasswordDto { + @ApiProperty() + @IsEmail() + email: string; + + @ApiProperty() + @IsString() + @IsNotEmpty() + newPassword: string; + + @ApiProperty() + @IsString() + @IsNotEmpty() + resetToken: string; +} \ No newline at end of file diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 5180944f7..28ce560e4 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -526,6 +526,9 @@ importers: nestjs-pino: specifier: ^3.5.0 version: 3.5.0(@nestjs/common@10.3.7)(pino-http@8.6.1) + nodemailer: + specifier: ^6.9.14 + version: 6.9.14 openai: specifier: ^4.38.5 version: 4.38.5 @@ -11703,6 +11706,11 @@ packages: /node-releases@2.0.18: resolution: {integrity: sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==} + /nodemailer@6.9.14: + resolution: {integrity: sha512-Dobp/ebDKBvz91sbtRKhcznLThrKxKt97GI2FAlAyy+fk19j73Uz3sBXolVtmcXjaorivqsbbbjDY+Jkt4/bQA==} + engines: {node: '>=6.0.0'} + dev: false + /nopt@5.0.0: resolution: {integrity: sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==} engines: {node: '>=6'}