- Mark backend as complete in IMPLEMENTATION_PLAN.md - Create ADMIN_BACKEND_COMPLETE.md with full documentation - Document all API endpoints - Add testing instructions - Add deployment notes
213 lines
7.4 KiB
TypeScript
213 lines
7.4 KiB
TypeScript
import { PrismaService } from '../prisma/prisma.service';
|
|
export declare class AdminPaymentsService {
|
|
private readonly prisma;
|
|
constructor(prisma: PrismaService);
|
|
findAll(status?: string): Promise<({
|
|
user: {
|
|
id: string;
|
|
email: string;
|
|
name: string | null;
|
|
};
|
|
subscription: ({
|
|
plan: {
|
|
id: string;
|
|
createdAt: Date;
|
|
updatedAt: Date;
|
|
name: string;
|
|
currency: string;
|
|
slug: string;
|
|
description: string | null;
|
|
price: import("@prisma/client/runtime/library").Decimal;
|
|
durationType: string;
|
|
durationDays: number | null;
|
|
trialDays: number;
|
|
features: import("@prisma/client/runtime/library").JsonValue;
|
|
badge: string | null;
|
|
badgeColor: string | null;
|
|
highlightColor: string | null;
|
|
sortOrder: number;
|
|
isActive: boolean;
|
|
isVisible: boolean;
|
|
isFeatured: boolean;
|
|
maxWallets: number | null;
|
|
maxGoals: number | null;
|
|
maxTeamMembers: number | null;
|
|
apiEnabled: boolean;
|
|
apiRateLimit: number | null;
|
|
};
|
|
} & {
|
|
id: string;
|
|
createdAt: Date;
|
|
updatedAt: Date;
|
|
status: string;
|
|
userId: string;
|
|
planId: string;
|
|
startDate: Date;
|
|
endDate: Date;
|
|
isTrialUsed: boolean;
|
|
trialEndDate: Date | null;
|
|
cancelledAt: Date | null;
|
|
cancellationReason: string | null;
|
|
}) | null;
|
|
} & {
|
|
id: string;
|
|
createdAt: Date;
|
|
updatedAt: Date;
|
|
status: string;
|
|
method: string;
|
|
userId: string;
|
|
currency: string;
|
|
amount: import("@prisma/client/runtime/library").Decimal;
|
|
subscriptionId: string | null;
|
|
invoiceNumber: string;
|
|
tripayReference: string | null;
|
|
tripayFee: import("@prisma/client/runtime/library").Decimal | null;
|
|
totalAmount: import("@prisma/client/runtime/library").Decimal;
|
|
paymentChannel: string | null;
|
|
paymentUrl: string | null;
|
|
qrUrl: string | null;
|
|
proofImageUrl: string | null;
|
|
transferDate: Date | null;
|
|
verifiedBy: string | null;
|
|
verifiedAt: Date | null;
|
|
rejectionReason: string | null;
|
|
couponId: string | null;
|
|
discountAmount: import("@prisma/client/runtime/library").Decimal | null;
|
|
notes: string | null;
|
|
expiresAt: Date | null;
|
|
paidAt: Date | null;
|
|
})[]>;
|
|
findOne(id: string): Promise<({
|
|
user: {
|
|
id: string;
|
|
email: string;
|
|
name: string | null;
|
|
};
|
|
subscription: ({
|
|
plan: {
|
|
id: string;
|
|
createdAt: Date;
|
|
updatedAt: Date;
|
|
name: string;
|
|
currency: string;
|
|
slug: string;
|
|
description: string | null;
|
|
price: import("@prisma/client/runtime/library").Decimal;
|
|
durationType: string;
|
|
durationDays: number | null;
|
|
trialDays: number;
|
|
features: import("@prisma/client/runtime/library").JsonValue;
|
|
badge: string | null;
|
|
badgeColor: string | null;
|
|
highlightColor: string | null;
|
|
sortOrder: number;
|
|
isActive: boolean;
|
|
isVisible: boolean;
|
|
isFeatured: boolean;
|
|
maxWallets: number | null;
|
|
maxGoals: number | null;
|
|
maxTeamMembers: number | null;
|
|
apiEnabled: boolean;
|
|
apiRateLimit: number | null;
|
|
};
|
|
} & {
|
|
id: string;
|
|
createdAt: Date;
|
|
updatedAt: Date;
|
|
status: string;
|
|
userId: string;
|
|
planId: string;
|
|
startDate: Date;
|
|
endDate: Date;
|
|
isTrialUsed: boolean;
|
|
trialEndDate: Date | null;
|
|
cancelledAt: Date | null;
|
|
cancellationReason: string | null;
|
|
}) | null;
|
|
} & {
|
|
id: string;
|
|
createdAt: Date;
|
|
updatedAt: Date;
|
|
status: string;
|
|
method: string;
|
|
userId: string;
|
|
currency: string;
|
|
amount: import("@prisma/client/runtime/library").Decimal;
|
|
subscriptionId: string | null;
|
|
invoiceNumber: string;
|
|
tripayReference: string | null;
|
|
tripayFee: import("@prisma/client/runtime/library").Decimal | null;
|
|
totalAmount: import("@prisma/client/runtime/library").Decimal;
|
|
paymentChannel: string | null;
|
|
paymentUrl: string | null;
|
|
qrUrl: string | null;
|
|
proofImageUrl: string | null;
|
|
transferDate: Date | null;
|
|
verifiedBy: string | null;
|
|
verifiedAt: Date | null;
|
|
rejectionReason: string | null;
|
|
couponId: string | null;
|
|
discountAmount: import("@prisma/client/runtime/library").Decimal | null;
|
|
notes: string | null;
|
|
expiresAt: Date | null;
|
|
paidAt: Date | null;
|
|
}) | null>;
|
|
verify(id: string, adminUserId: string): Promise<{
|
|
id: string;
|
|
createdAt: Date;
|
|
updatedAt: Date;
|
|
status: string;
|
|
method: string;
|
|
userId: string;
|
|
currency: string;
|
|
amount: import("@prisma/client/runtime/library").Decimal;
|
|
subscriptionId: string | null;
|
|
invoiceNumber: string;
|
|
tripayReference: string | null;
|
|
tripayFee: import("@prisma/client/runtime/library").Decimal | null;
|
|
totalAmount: import("@prisma/client/runtime/library").Decimal;
|
|
paymentChannel: string | null;
|
|
paymentUrl: string | null;
|
|
qrUrl: string | null;
|
|
proofImageUrl: string | null;
|
|
transferDate: Date | null;
|
|
verifiedBy: string | null;
|
|
verifiedAt: Date | null;
|
|
rejectionReason: string | null;
|
|
couponId: string | null;
|
|
discountAmount: import("@prisma/client/runtime/library").Decimal | null;
|
|
notes: string | null;
|
|
expiresAt: Date | null;
|
|
paidAt: Date | null;
|
|
}>;
|
|
reject(id: string, adminUserId: string, reason: string): Promise<{
|
|
id: string;
|
|
createdAt: Date;
|
|
updatedAt: Date;
|
|
status: string;
|
|
method: string;
|
|
userId: string;
|
|
currency: string;
|
|
amount: import("@prisma/client/runtime/library").Decimal;
|
|
subscriptionId: string | null;
|
|
invoiceNumber: string;
|
|
tripayReference: string | null;
|
|
tripayFee: import("@prisma/client/runtime/library").Decimal | null;
|
|
totalAmount: import("@prisma/client/runtime/library").Decimal;
|
|
paymentChannel: string | null;
|
|
paymentUrl: string | null;
|
|
qrUrl: string | null;
|
|
proofImageUrl: string | null;
|
|
transferDate: Date | null;
|
|
verifiedBy: string | null;
|
|
verifiedAt: Date | null;
|
|
rejectionReason: string | null;
|
|
couponId: string | null;
|
|
discountAmount: import("@prisma/client/runtime/library").Decimal | null;
|
|
notes: string | null;
|
|
expiresAt: Date | null;
|
|
paidAt: Date | null;
|
|
}>;
|
|
getPendingCount(): Promise<number>;
|
|
}
|