From 488c42cc2beb98bd18e938f74edb94a29074e5e3 Mon Sep 17 00:00:00 2001 From: swikars1 Date: Mon, 8 Apr 2024 01:45:16 +0545 Subject: [PATCH 1/5] add builder --- epaymentv2/paymentLookup.ts | 27 +++++--- index.ts | 131 +++++++++++++++++++++++++++--------- 2 files changed, 119 insertions(+), 39 deletions(-) diff --git a/epaymentv2/paymentLookup.ts b/epaymentv2/paymentLookup.ts index 3946b35..71ac8da 100644 --- a/epaymentv2/paymentLookup.ts +++ b/epaymentv2/paymentLookup.ts @@ -21,16 +21,13 @@ export interface PaymentLookupRequest { /** * Represents the base structure of a successful lookup API response. */ -export interface PaymentLookupSuccessResponse { +interface PaymentLookupGeneralResponse { /** The initial payment identifier. */ pidx: string; /** The total amount of the transaction (in what currency? Assuming Paisa here). */ total_amount: number; - /** The current status of the transaction. */ - status: PaymentStatus; - /** The unique transaction identifier assigned by Khalti. */ transaction_id: string | null; @@ -39,13 +36,24 @@ export interface PaymentLookupSuccessResponse { /** Indicates whether the transaction has been refunded. */ refunded: boolean; + + /** The current status of the transaction. */ + status: PaymentStatus; +} + +/** + * Represents a specific lookup response for a 'Success' transaction. + */ +export interface PaymentLookupSuccessResponse + extends PaymentLookupGeneralResponse { + status: "Completed"; // Enforce the specific status } /** * Represents a specific lookup response for a 'Pending' transaction. */ export interface PaymentLookupPendingResponse - extends PaymentLookupSuccessResponse { + extends PaymentLookupGeneralResponse { status: "Pending"; // Enforce the specific status transaction_id: null; // Transaction ID not yet generated } @@ -54,7 +62,7 @@ export interface PaymentLookupPendingResponse * Represents a specific lookup response for an 'Initiated' transaction. */ export interface PaymentLookupInitiatedResponse - extends PaymentLookupSuccessResponse { + extends PaymentLookupGeneralResponse { status: "Initiated"; } @@ -62,7 +70,7 @@ export interface PaymentLookupInitiatedResponse * Represents a specific lookup response for a 'Refunded' transaction. */ export interface PaymentLookupRefundedResponse - extends PaymentLookupSuccessResponse { + extends PaymentLookupGeneralResponse { status: "Refunded"; refunded: true; } @@ -71,7 +79,7 @@ export interface PaymentLookupRefundedResponse * Represents a specific lookup response for an 'Expired' transaction. */ export interface PaymentLookupExpiredResponse - extends PaymentLookupSuccessResponse { + extends PaymentLookupGeneralResponse { status: "Expired"; transaction_id: null; } @@ -80,12 +88,13 @@ export interface PaymentLookupExpiredResponse * Represents a specific lookup response for a 'UserCanceled' transaction. */ export interface PaymentLookupCanceledResponse - extends PaymentLookupSuccessResponse { + extends PaymentLookupGeneralResponse { status: "UserCanceled"; transaction_id: null; } export type AllLookupResponse = + | PaymentLookupSuccessResponse | PaymentLookupPendingResponse | PaymentLookupInitiatedResponse | PaymentLookupRefundedResponse diff --git a/index.ts b/index.ts index fb3443b..5942e8d 100644 --- a/index.ts +++ b/index.ts @@ -1,9 +1,12 @@ -import axios from "axios"; +import axios, { AxiosInstance } from "axios"; import type { InitiatePaymentRequest, InitiatePaymentResponse, } from "./epaymentv2/initiatePayment"; -import type { AllLookupResponse } from "./epaymentv2/paymentLookup"; +import type { + AllLookupResponse, + PaymentLookupRequest, +} from "./epaymentv2/paymentLookup"; async function awTry(promise: unknown) { try { @@ -15,36 +18,104 @@ async function awTry(promise: unknown) { } } -const khaltiInstanceServer = axios.create({ - baseURL: "https://a.khalti.com/api/v2", - headers: { - "Content-Type": "application/json", - Authorization: `Key f79110302bbf46828fca3a7b7514da97`, // live secret key - }, - responseType: "json", -}); - -const paymentLookup = async (pidx: string) => { - const [response, error] = await awTry<{ data: AllLookupResponse }>( - khaltiInstanceServer.get(`/epayment/lookup?pidx=${pidx}`) - ); - if (error) { - console.log("Error, in lookupPayment: ", error); - } - return response.data; +const paymentLookup = (instance: AxiosInstance) => { + return async ({ pidx }: PaymentLookupRequest) => { + const [response, error] = await awTry<{ data: AllLookupResponse }>( + instance.get(`/epayment/lookup?pidx=${pidx}`) + ); + if (error) { + console.log("Error, in lookupPayment: ", error); + } + return response.data; + }; }; -const initiatePayment = async (payload: InitiatePaymentRequest) => { - const [response, error] = await awTry<{ data: InitiatePaymentResponse }>( - khaltiInstanceServer.post("/epayment/initiate/", payload) - ); - if (error) { - console.log("Error, in initiatePayment: ", error); - } - return response.data; +const initiatePayment = (instance: AxiosInstance) => { + return async (payload: InitiatePaymentRequest) => { + const [response, error] = await awTry<{ data: InitiatePaymentResponse }>( + instance.post("/epayment/initiate/", payload) + ); + + if (error) { + console.log("Error, in initiatePayment: ", error); + } + return response.data; + }; }; -export const khaltiApi = { - initiatePayment, - paymentLookup, +export const createKhaltiInstance = ({ + env, + secretKey, +}: { + env: "sandbox" | "production"; + secretKey: string; +}) => { + const urls = { + sandbox: "https://a.khalti.com/api/v2", + production: "https://khalti.com/api/v2", + }; + const instance = axios.create({ + baseURL: urls[env], + headers: { + "Content-Type": "application/json", + Authorization: `Key ${secretKey}`, // live secret key + }, + responseType: "json", + }); + + return { + paymentLookup: paymentLookup(instance), + initiatePayment: initiatePayment(instance), + }; }; + +// const ins = createKhaltiInstance({ +// env: "sandbox", +// secretKey: "Asd", +// }); + +// async function a() { +// const { payment_url, pidx } = await ins.initiatePayment({ +// return_url: "https://example.com/payment/", +// website_url: "https://example.com/", +// amount: 1300, +// purchase_order_id: "test12", +// purchase_order_name: "test", +// customer_info: { +// name: "Khalti Bahadur", +// email: "example@gmail.com", +// phone: "9800000123", +// }, +// amount_breakdown: [ +// { +// label: "Mark Price", +// amount: 1000, +// }, +// { +// label: "VAT", +// amount: 300, +// }, +// ], +// product_details: [ +// { +// identity: "1234567890", +// name: "Khalti logo", +// total_price: 1300, +// quantity: 1, +// unit_price: 1300, +// }, +// ], +// merchant_username: "merchant_name", +// merchant_extra: "merchant_extra", +// }); + +// const ff = await ins.paymentLookup({ +// pidx, +// }); + +// if (ff.status === "Completed") { +// console.log("Payment Success"); +// } + +// console.log({ payment_url, pidx }); +// } From 7c3b643410b775896710cc5d0df43871a1ea28ca Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Sun, 7 Apr 2024 07:27:56 +0000 Subject: [PATCH 2/5] Version Packages --- .changeset/metal-planets-whisper.md | 5 ----- CHANGELOG.md | 6 ++++++ package.json | 2 +- 3 files changed, 7 insertions(+), 6 deletions(-) delete mode 100644 .changeset/metal-planets-whisper.md diff --git a/.changeset/metal-planets-whisper.md b/.changeset/metal-planets-whisper.md deleted file mode 100644 index 3c273b9..0000000 --- a/.changeset/metal-planets-whisper.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -"khalti-epayment": patch ---- - -test changeset diff --git a/CHANGELOG.md b/CHANGELOG.md index 0add28b..d503d33 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,11 @@ # khalti-epayment +## 0.0.6 + +### Patch Changes + +- f4f8a9f: test changeset + ## 0.0.5 ### Patch Changes diff --git a/package.json b/package.json index cf1e372..f82b3ee 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "khalti-epayment", "license": "MIT", - "version": "0.0.5", + "version": "0.0.6", "main": "dist/index.js", "module": "dist/index.mjs", "types": "dist/index.d.ts", From fa06952e47ac8f3ba63b7e0f257d3f17467abbbc Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Sun, 7 Apr 2024 08:59:08 +0000 Subject: [PATCH 3/5] Version Packages --- .changeset/eight-ladybugs-drop.md | 5 ----- CHANGELOG.md | 6 ++++++ package.json | 2 +- 3 files changed, 7 insertions(+), 6 deletions(-) delete mode 100644 .changeset/eight-ladybugs-drop.md diff --git a/.changeset/eight-ladybugs-drop.md b/.changeset/eight-ladybugs-drop.md deleted file mode 100644 index bf82d71..0000000 --- a/.changeset/eight-ladybugs-drop.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -"khalti-epayment": minor ---- - -add khalti api calls diff --git a/CHANGELOG.md b/CHANGELOG.md index d503d33..fad3743 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,11 @@ # khalti-epayment +## 0.1.0 + +### Minor Changes + +- 2db5b55: add khalti api calls + ## 0.0.6 ### Patch Changes diff --git a/package.json b/package.json index f82b3ee..17f91e8 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "khalti-epayment", "license": "MIT", - "version": "0.0.6", + "version": "0.1.0", "main": "dist/index.js", "module": "dist/index.mjs", "types": "dist/index.d.ts", From 29c97028260a5eba1d3acfae9a28e34aaa7cb482 Mon Sep 17 00:00:00 2001 From: swikars1 Date: Mon, 8 Apr 2024 01:46:50 +0545 Subject: [PATCH 4/5] add changeset --- .changeset/orange-dragons-repair.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/orange-dragons-repair.md diff --git a/.changeset/orange-dragons-repair.md b/.changeset/orange-dragons-repair.md new file mode 100644 index 0000000..63da30a --- /dev/null +++ b/.changeset/orange-dragons-repair.md @@ -0,0 +1,5 @@ +--- +"khalti-epayment": patch +--- + +add builders From e78e2a92664b361070126479396ae2d0a1c8a63c Mon Sep 17 00:00:00 2001 From: swikars1 Date: Mon, 8 Apr 2024 01:48:30 +0545 Subject: [PATCH 5/5] remove file --- epaymentv2/khaltiInstanceServer.ts | 0 1 file changed, 0 insertions(+), 0 deletions(-) delete mode 100644 epaymentv2/khaltiInstanceServer.ts diff --git a/epaymentv2/khaltiInstanceServer.ts b/epaymentv2/khaltiInstanceServer.ts deleted file mode 100644 index e69de29..0000000