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

[2/2] Affiliate program Integration v1 #564

Merged
merged 80 commits into from
Nov 14, 2023
Merged
Changes from 1 commit
Commits
Show all changes
80 commits
Select commit Hold shift + click to select a range
48bbbac
auth: Allow for corporate registrations
sashko9807 Oct 9, 2023
e1c0be3
auth: Don't create new corporate profile if company exists
sashko9807 Oct 9, 2023
310e19c
Affiliate Program: Initial changes
sashko9807 Oct 10, 2023
254cca6
Run prisma migrate
sashko9807 Oct 10, 2023
5002426
schema.prisma: Add donation relation to Affiliate model
sashko9807 Oct 12, 2023
a0e658d
schema.prisma: Add guaranteed status for donations
sashko9807 Oct 13, 2023
d00ff81
Add affiliateId to testing and seeding scripts
sashko9807 Oct 16, 2023
f8e7252
validation: Set exposeDefaultValues to true globally
sashko9807 Oct 16, 2023
fc847c3
src/affiliate: Implement endpoints for creating/cancelling donations
sashko9807 Oct 17, 2023
7c7ea94
src/campaign: Include guaranteedAmount in campaign's summary
sashko9807 Oct 17, 2023
8782e23
tasks/bank-import: Handle affiliate donations
sashko9807 Oct 18, 2023
a8337a3
bank-transactions: Add endpoint to simulate IRIS transactions.
sashko9807 Oct 19, 2023
39b7f7a
src/affiliate: Change affiliateCode structure
sashko9807 Oct 19, 2023
ed56cfc
affiliate: Make affiliateCode available only for active affiliates
sashko9807 Oct 19, 2023
3f48f56
jest: Fix test breakage
sashko9807 Oct 19, 2023
764731d
src/donations: Include guaranteed donations in listPublic
sashko9807 Oct 20, 2023
b187047
eslint: Address errors and warnings
sashko9807 Oct 20, 2023
76c8129
src/donations: Include companyName in listPublic endpoint
sashko9807 Oct 20, 2023
1dc7243
corporateUser: Add space between first and last name for legalpersonname
sashko9807 Oct 20, 2023
505a210
src/affiliate: Generate new code whenever affiliate is set to active
sashko9807 Oct 20, 2023
9afc6e9
Run nx format
sashko9807 Oct 21, 2023
fc1907c
src/donations:c Add affiliateId to donation mock
sashko9807 Oct 21, 2023
4ac27a3
src/affiliates: Add tests
sashko9807 Oct 23, 2023
f8a8bce
bank-transaction: Return unprocessed if no guaranteed donations are …
sashko9807 Oct 23, 2023
b51522d
tasks/bank-import: Set transaction to importFailed if no guaranteed d…
sashko9807 Oct 23, 2023
ca85225
tasks/bank-import: Include test for affiliate donations
sashko9807 Oct 23, 2023
b4f0824
src/affiliate: Fix redundant space on ForbiddenException
sashko9807 Oct 23, 2023
df7d3ed
affiliate.controller.spec: Rename test to AffiliateController
sashko9807 Oct 24, 2023
1571039
schema.prisma: Add companyId to person model
sashko9807 Oct 24, 2023
e5f1065
auth.service: Add companyId in createPerson method
sashko9807 Oct 24, 2023
9c5f796
src/register.controller: Use single endpoint for registration
sashko9807 Oct 24, 2023
fa1a0c1
Consider bank transaction as successfull if no guaranteed donations a…
sashko9807 Oct 24, 2023
7cbe6f7
affiliate: Rename endpoints
sashko9807 Oct 24, 2023
80711dd
bank-transaction: Update bankDonationStatus on duplicate record
sashko9807 Oct 24, 2023
4de21df
affiliate: Create endpoint to get donations with pagination
sashko9807 Oct 24, 2023
480524a
schema.prisma:Affiliate: Make companyId not null
sashko9807 Oct 24, 2023
7245c78
affiliateCodeGenerator: Get the first 8 characters
sashko9807 Oct 24, 2023
1c09553
eslint: Address error and warnings
sashko9807 Oct 24, 2023
b7c2716
tasks/bank-import: Change bankstatus only if donation is affiliate
sashko9807 Oct 24, 2023
8d389a5
jest: Fix tests
sashko9807 Oct 24, 2023
4295987
swagger: Provide schema for iris-transaction-test endpoint
sashko9807 Oct 25, 2023
724ac2d
bank-import: Initialize variable with affiliate code prefix
sashko9807 Oct 26, 2023
d79c1dd
donation: Add metadata field to donation Model
sashko9807 Oct 26, 2023
00b31d1
schema.prisma: Map DonationMetadata model
sashko9807 Oct 27, 2023
7055e1d
src/affiliate: Include metadata in affiliateDonationDto in jest
sashko9807 Oct 30, 2023
52d67ee
src/auth: Allow for corporate fields to be either string or undefined
sashko9807 Oct 30, 2023
734963f
src/affiliate: Improve semantics
sashko9807 Oct 30, 2023
4daeba8
src/affiliate: Fix test
sashko9807 Oct 30, 2023
50238df
src/affiliate: Include JWT_SECRET_KEY when generating affiliate code
sashko9807 Oct 30, 2023
7ce8939
src/affiliate: Create new endpoint to refresh affiliate code
sashko9807 Oct 30, 2023
a7d1df3
src/donations: Fix error handling if no vault has been found
sashko9807 Oct 30, 2023
12ceefe
src/affiliate: Check whether campaign accepts more donations before m…
sashko9807 Oct 30, 2023
2aacb5d
src/donations: Bring back count query to listPublic service endpoint
sashko9807 Oct 31, 2023
a5e4e0b
src/donations: Handle corporate donations
sashko9807 Oct 31, 2023
ca25104
src/donations: Don't update updatedAt property on imported donation
sashko9807 Nov 1, 2023
3acf963
src/donation-wish: Extend selector to include companyName and donatio…
sashko9807 Nov 1, 2023
d5754e8
src/affiliate: Include donation wish in query
sashko9807 Nov 1, 2023
87df4e2
updateAffiliateBankPayment: Use value of donation's updatedAt field
sashko9807 Nov 1, 2023
aea9be9
getUserDonationById: Include companyName inside the query
sashko9807 Nov 2, 2023
82eb4a4
userDonationById(): Get first and last name from keycloak token
sashko9807 Nov 2, 2023
c143e6b
src/affiliate: Add new endpoint to get affiliate's data by userid
sashko9807 Nov 4, 2023
4929a4f
src/affiliate: cleanup console.log
sashko9807 Nov 4, 2023
ec25464
schema.prisma: Add profileEnabled to person table
sashko9807 Nov 6, 2023
e112223
src/account: Make endpoint for manual activation/deactivation of profile
sashko9807 Nov 6, 2023
7cd1a24
src/person: Fix ordering by profile type not working
sashko9807 Nov 6, 2023
62cfe03
src/auth: Prevent deactivation of profile if it is in podkrepi-admin …
sashko9807 Nov 6, 2023
f2be94f
src/affiliate: Solve ts errors on controller.spec
sashko9807 Nov 7, 2023
4227d25
src/affiliate: Add new endpoint to list all affiliates
sashko9807 Nov 7, 2023
6fa38f0
src/affiliate: Include person's email in findAll query result
sashko9807 Nov 7, 2023
c42e7b3
src/auth: Fix test breakage
sashko9807 Nov 7, 2023
5a68fc4
schema.prisma: Add createdAt and updatedAt fields to Affiliate model
sashko9807 Nov 7, 2023
26837ce
src/donations: Improve validation of metadata fields if not undefined
sashko9807 Nov 8, 2023
bd4a86a
src/donations: Fix ts errors
sashko9807 Nov 8, 2023
b34c67a
bank-transaction: iris-simulation should be done only by admin
sashko9807 Nov 8, 2023
e113148
dto/donation-metadata: Fix extraData field being empty on valid Objec…
sashko9807 Nov 9, 2023
8079147
src/auth: Change admin roles lookup
sashko9807 Nov 12, 2023
753d220
Merge branch 'master' into affiliate-program2
sashko9807 Nov 13, 2023
92044eb
events/stripe: Resolve errors after merge of master
sashko9807 Nov 13, 2023
421df97
ESLint: Remove unused imports
sashko9807 Nov 13, 2023
94b97bc
auth.service.spec: Bring back issueToken testcase
sashko9807 Nov 13, 2023
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
Prev Previous commit
Next Next commit
Run prisma migrate
sashko9807 committed Oct 19, 2023
commit 254cca64332dd435a0d4a16b08272625c15215e1
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
export class ConnectBankAccountDto {
id: string
}

export class ConnectBankAccountDto {
id: string;
}

Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
import { AccountHolderType } from '@prisma/client'
import { ApiProperty } from '@nestjs/swagger'

import {AccountHolderType} from '@prisma/client'
import {ApiProperty} from '@nestjs/swagger'




export class CreateBankAccountDto {
ibanNumber: string
accountHolderName: string
@ApiProperty({ enum: AccountHolderType })
accountHolderType: AccountHolderType
bankName?: string
bankIdCode?: string
fingerprint?: string
ibanNumber: string;
accountHolderName: string;
@ApiProperty({ enum: AccountHolderType})
accountHolderType: AccountHolderType;
bankName?: string;
bankIdCode?: string;
fingerprint?: string;
}
7 changes: 4 additions & 3 deletions apps/api/src/domain/generated/bankAccount/dto/index.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
export * from './connect-bankAccount.dto'
export * from './create-bankAccount.dto'
export * from './update-bankAccount.dto'

export * from './connect-bankAccount.dto';
export * from './create-bankAccount.dto';
export * from './update-bankAccount.dto';
Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
import { AccountHolderType } from '@prisma/client'
import { ApiProperty } from '@nestjs/swagger'

import {AccountHolderType} from '@prisma/client'
import {ApiProperty} from '@nestjs/swagger'




export class UpdateBankAccountDto {
ibanNumber?: string
accountHolderName?: string
@ApiProperty({ enum: AccountHolderType })
accountHolderType?: AccountHolderType
bankName?: string
bankIdCode?: string
fingerprint?: string
ibanNumber?: string;
accountHolderName?: string;
@ApiProperty({ enum: AccountHolderType})
accountHolderType?: AccountHolderType;
bankName?: string;
bankIdCode?: string;
fingerprint?: string;
}
Original file line number Diff line number Diff line change
@@ -1,16 +1,18 @@
import { BankAccountStatus, AccountHolderType } from '@prisma/client'
import { Withdrawal } from '../../withdrawal/entities/withdrawal.entity'

import {BankAccountStatus,AccountHolderType} from '@prisma/client'
import {Withdrawal} from '../../withdrawal/entities/withdrawal.entity'


export class BankAccount {
id: string
status: BankAccountStatus
ibanNumber: string
accountHolderName: string
accountHolderType: AccountHolderType
bankName: string | null
bankIdCode: string | null
fingerprint: string | null
createdAt: Date
updatedAt: Date | null
withdraws?: Withdrawal[]
id: string ;
status: BankAccountStatus ;
ibanNumber: string ;
accountHolderName: string ;
accountHolderType: AccountHolderType ;
bankName: string | null;
bankIdCode: string | null;
fingerprint: string | null;
createdAt: Date ;
updatedAt: Date | null;
withdraws?: Withdrawal[] ;
}
3 changes: 2 additions & 1 deletion apps/api/src/domain/generated/bankAccount/entities/index.ts
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
export * from './bankAccount.entity'

export * from './bankAccount.entity';
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
export class ConnectBankTransactionDto {
id: string
}

export class ConnectBankTransactionDto {
id: string;
}

Original file line number Diff line number Diff line change
@@ -1,21 +1,25 @@
import { BankTransactionType, BankDonationStatus } from '@prisma/client'
import { ApiProperty } from '@nestjs/swagger'

import {BankTransactionType,BankDonationStatus} from '@prisma/client'
import {ApiProperty} from '@nestjs/swagger'




export class CreateBankTransactionDto {
id: string
ibanNumber: string
bankName: string
bankIdCode: string
transactionDate: Date
senderName?: string
recipientName?: string
senderIban?: string
recipientIban?: string
description: string
matchedRef?: string
@ApiProperty({ enum: BankTransactionType })
type: BankTransactionType
@ApiProperty({ enum: BankDonationStatus })
bankDonationStatus?: BankDonationStatus
notified?: boolean
id: string;
ibanNumber: string;
bankName: string;
bankIdCode: string;
transactionDate: Date;
senderName?: string;
recipientName?: string;
senderIban?: string;
recipientIban?: string;
description: string;
matchedRef?: string;
@ApiProperty({ enum: BankTransactionType})
type: BankTransactionType;
@ApiProperty({ enum: BankDonationStatus})
bankDonationStatus?: BankDonationStatus;
notified?: boolean;
}
7 changes: 4 additions & 3 deletions apps/api/src/domain/generated/bankTransaction/dto/index.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
export * from './connect-bankTransaction.dto'
export * from './create-bankTransaction.dto'
export * from './update-bankTransaction.dto'

export * from './connect-bankTransaction.dto';
export * from './create-bankTransaction.dto';
export * from './update-bankTransaction.dto';
Original file line number Diff line number Diff line change
@@ -1,20 +1,24 @@
import { BankTransactionType, BankDonationStatus } from '@prisma/client'
import { ApiProperty } from '@nestjs/swagger'

import {BankTransactionType,BankDonationStatus} from '@prisma/client'
import {ApiProperty} from '@nestjs/swagger'




export class UpdateBankTransactionDto {
ibanNumber?: string
bankName?: string
bankIdCode?: string
transactionDate?: Date
senderName?: string
recipientName?: string
senderIban?: string
recipientIban?: string
description?: string
matchedRef?: string
@ApiProperty({ enum: BankTransactionType })
type?: BankTransactionType
@ApiProperty({ enum: BankDonationStatus })
bankDonationStatus?: BankDonationStatus
notified?: boolean
ibanNumber?: string;
bankName?: string;
bankIdCode?: string;
transactionDate?: Date;
senderName?: string;
recipientName?: string;
senderIban?: string;
recipientIban?: string;
description?: string;
matchedRef?: string;
@ApiProperty({ enum: BankTransactionType})
type?: BankTransactionType;
@ApiProperty({ enum: BankDonationStatus})
bankDonationStatus?: BankDonationStatus;
notified?: boolean;
}
Original file line number Diff line number Diff line change
@@ -1,20 +1,22 @@
import { Currency, BankTransactionType, BankDonationStatus } from '@prisma/client'

import {Currency,BankTransactionType,BankDonationStatus} from '@prisma/client'


export class BankTransaction {
id: string
ibanNumber: string
bankName: string
bankIdCode: string
transactionDate: Date
senderName: string | null
recipientName: string | null
senderIban: string | null
recipientIban: string | null
amount: number
currency: Currency
description: string
matchedRef: string | null
type: BankTransactionType
bankDonationStatus: BankDonationStatus | null
notified: boolean | null
id: string ;
ibanNumber: string ;
bankName: string ;
bankIdCode: string ;
transactionDate: Date ;
senderName: string | null;
recipientName: string | null;
senderIban: string | null;
recipientIban: string | null;
amount: number ;
currency: Currency ;
description: string ;
matchedRef: string | null;
type: BankTransactionType ;
bankDonationStatus: BankDonationStatus | null;
notified: boolean | null;
}
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
export * from './bankTransaction.entity'

export * from './bankTransaction.entity';
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
export class ConnectBankTransactionsFileDto {
id: string
}

export class ConnectBankTransactionsFileDto {
id: string;
}

Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
export * from './connect-bankTransactionsFile.dto'
export * from './create-bankTransactionsFile.dto'
export * from './update-bankTransactionsFile.dto'

export * from './connect-bankTransactionsFile.dto';
export * from './create-bankTransactionsFile.dto';
export * from './update-bankTransactionsFile.dto';
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
import { BankTransactionsFileType } from '@prisma/client'

import {BankTransactionsFileType} from '@prisma/client'


export class BankTransactionsFile {
id: string
filename: string
mimetype: string
bankTransactionsFileId: string
type: BankTransactionsFileType
personId: string
id: string ;
filename: string ;
mimetype: string ;
bankTransactionsFileId: string ;
type: BankTransactionsFileType ;
personId: string ;
}
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
export * from './bankTransactionsFile.entity'

export * from './bankTransactionsFile.entity';
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
export class ConnectBenefactorDto {
id?: string
extCustomerId?: string
}

export class ConnectBenefactorDto {
id?: string;
extCustomerId?: string;
}

Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@






export class CreateBenefactorDto {
extCustomerId?: string
extCustomerId?: string;
}
7 changes: 4 additions & 3 deletions apps/api/src/domain/generated/benefactor/dto/index.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
export * from './connect-benefactor.dto'
export * from './create-benefactor.dto'
export * from './update-benefactor.dto'

export * from './connect-benefactor.dto';
export * from './create-benefactor.dto';
export * from './update-benefactor.dto';
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@






export class UpdateBenefactorDto {
extCustomerId?: string
extCustomerId?: string;
}
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
import { Person } from '../../person/entities/person.entity'

import {Person} from '../../person/entities/person.entity'


export class Benefactor {
id: string
personId: string
extCustomerId: string | null
createdAt: Date
updatedAt: Date | null
person?: Person
id: string ;
personId: string ;
extCustomerId: string | null;
createdAt: Date ;
updatedAt: Date | null;
person?: Person ;
}
3 changes: 2 additions & 1 deletion apps/api/src/domain/generated/benefactor/entities/index.ts
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
export * from './benefactor.entity'

export * from './benefactor.entity';
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
export class ConnectBeneficiaryDto {
id: string
}

export class ConnectBeneficiaryDto {
id: string;
}

Loading