Merge branch 'master' into delete-transaction-link-mutation

This commit is contained in:
Moriz Wahl 2022-03-10 18:10:33 +01:00 committed by GitHub
commit ff9dde8870
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 33 additions and 25 deletions

View File

@ -5,7 +5,7 @@ import { User } from './User'
@ObjectType()
export class TransactionLink {
constructor(transactionLink: dbTransactionLink, user: User) {
constructor(transactionLink: dbTransactionLink, user: User, redeemedBy: User | null = null) {
this.id = transactionLink.id
this.user = user
this.amount = transactionLink.amount
@ -15,9 +15,9 @@ export class TransactionLink {
this.createdAt = transactionLink.createdAt
this.validUntil = transactionLink.validUntil
this.showEmail = transactionLink.showEmail
this.deletedAt = null
this.redeemedAt = null
this.redeemedBy = null
this.deletedAt = transactionLink.deletedAt
this.redeemedAt = transactionLink.redeemedAt
this.redeemedBy = redeemedBy
}
@Field(() => Number)

View File

@ -19,13 +19,14 @@ import { Order } from '@enum/Order'
import { UserRepository } from '@repository/User'
import { TransactionRepository } from '@repository/Transaction'
import { TransactionLinkRepository } from '@repository/TransactionLink'
import { User as dbUser } from '@entity/User'
import { Transaction as dbTransaction } from '@entity/Transaction'
import { apiPost } from '@/apis/HttpRequest'
import { TransactionTypeId } from '@enum/TransactionTypeId'
import { calculateBalance, isHexPublicKey, holdAvailable } from '@/util/validate'
import { calculateBalance, isHexPublicKey } from '@/util/validate'
import { RIGHTS } from '@/auth/RIGHTS'
import { User } from '@model/User'
import { communityUser } from '@/util/communityUser'
@ -127,7 +128,8 @@ export class TransactionResolver {
transactions.push(new Transaction(userTransaction, self, linkedUser))
})
const toHoldAvailable = await holdAvailable(user.id, now)
const transactionLinkRepository = getCustomRepository(TransactionLinkRepository)
const toHoldAvailable = await transactionLinkRepository.sumAmountToHoldAvailable(user.id, now)
// Construct Result
return new TransactionList(

View File

@ -0,0 +1,16 @@
import { Repository, EntityRepository } from '@dbTools/typeorm'
import { TransactionLink as dbTransactionLink } from '@entity/TransactionLink'
import Decimal from 'decimal.js-light'
@EntityRepository(dbTransactionLink)
export class TransactionLinkRepository extends Repository<dbTransactionLink> {
async sumAmountToHoldAvailable(userId: number, date: Date): Promise<Decimal> {
const { sum } = await this.createQueryBuilder('transactionLinks')
.select('SUM(transactionLinks.holdAvailableAmount)', 'sum')
.where('transactionLinks.userId = :userId', { userId })
.andWhere('transactionLinks.redeemedAt is NULL')
.andWhere('transactionLinks.validUntil > :date', { date })
.getRawOne()
return sum ? new Decimal(sum) : new Decimal(0)
}
}

View File

@ -2,8 +2,8 @@ import { calculateDecay } from './decay'
import Decimal from 'decimal.js-light'
import { Transaction } from '@entity/Transaction'
import { Decay } from '@model/Decay'
import { TransactionLink as dbTransactionLink } from '@entity/TransactionLink'
import { MoreThan } from '@dbTools/typeorm'
import { getCustomRepository } from '@dbTools/typeorm'
import { TransactionLinkRepository } from '@repository/TransactionLink'
function isStringBoolean(value: string): boolean {
const lowerValue = value.toLowerCase()
@ -29,23 +29,13 @@ async function calculateBalance(
// TODO why we have to use toString() here?
const balance = decay.balance.add(amount.toString())
const toHoldAvailable = await holdAvailable(userId, time)
const transactionLinkRepository = getCustomRepository(TransactionLinkRepository)
const toHoldAvailable = await transactionLinkRepository.sumAmountToHoldAvailable(userId, time)
if (balance.minus(toHoldAvailable.toString()).lessThan(0)) {
return null
}
return { balance, lastTransactionId: lastTransaction.id, decay }
}
async function holdAvailable(userId: number, date: Date): Promise<Decimal> {
const openTransactionLinks = await dbTransactionLink.find({
select: ['holdAvailableAmount'],
where: { userId, redeemedAt: null, validUntil: MoreThan(date) },
})
return openTransactionLinks.reduce(
(previousValue, currentValue) => previousValue.add(currentValue.holdAvailableAmount.toString()),
new Decimal(0),
)
}
export { isHexPublicKey, calculateBalance, isStringBoolean, holdAvailable }
export { isHexPublicKey, calculateBalance, isStringBoolean }

View File

@ -42,7 +42,7 @@ export class TransactionLink extends BaseEntity {
createdAt: Date
@DeleteDateColumn()
deletedAt?: Date | null
deletedAt: Date | null
@Column({
type: 'datetime',
@ -61,8 +61,8 @@ export class TransactionLink extends BaseEntity {
type: 'datetime',
nullable: true,
})
redeemedAt?: Date | null
redeemedAt: Date | null
@Column({ type: 'int', unsigned: true, nullable: true })
redeemedBy?: number | null
redeemedBy: number | null
}