@morambacrypto/connect 0.0.12 → 0.0.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.mts +137 -0
- package/dist/index.d.ts +137 -2
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +2 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +4 -3
- package/dist/MorambaClient.d.ts +0 -13
- package/dist/MorambaClient.js +0 -12
- package/dist/apis/auth.api.d.ts +0 -9
- package/dist/apis/auth.api.js +0 -15
- package/dist/apis/company.api.d.ts +0 -9
- package/dist/apis/company.api.js +0 -17
- package/dist/apis/index.d.ts +0 -2
- package/dist/apis/index.js +0 -2
- package/dist/client/HttpClient.d.ts +0 -12
- package/dist/client/HttpClient.js +0 -45
- package/dist/client/index.d.ts +0 -1
- package/dist/client/index.js +0 -1
- package/dist/signature/index.d.ts +0 -2
- package/dist/signature/index.js +0 -2
- package/dist/signature/monad.approve.d.ts +0 -10
- package/dist/signature/monad.approve.js +0 -29
- package/dist/signature/sepolia.approve.d.ts +0 -10
- package/dist/signature/sepolia.approve.js +0 -29
- package/dist/types/auth.types.d.ts +0 -11
- package/dist/types/auth.types.js +0 -1
- package/dist/types/company.types.d.ts +0 -23
- package/dist/types/company.types.js +0 -1
- package/dist/types/index.d.ts +0 -2
- package/dist/types/index.js +0 -2
- package/dist/utils/networks.d.ts +0 -9
- package/dist/utils/networks.js +0 -16
package/dist/index.d.mts
ADDED
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { AxiosInstance } from 'axios';
|
|
2
|
+
|
|
3
|
+
declare class HttpClient {
|
|
4
|
+
private client;
|
|
5
|
+
private maxRetries;
|
|
6
|
+
private retryDelay;
|
|
7
|
+
constructor(baseURL: string, headers?: Record<string, string>, maxRetries?: number, // default: 4 retries
|
|
8
|
+
retryDelay?: number);
|
|
9
|
+
get axiosInstance(): AxiosInstance;
|
|
10
|
+
private setupRetryInterceptor;
|
|
11
|
+
post<T = any>(url: string, data: any, extraHeaders?: Record<string, string>): Promise<T>;
|
|
12
|
+
patch<T = any>(url: string, data: any, extraHeaders?: Record<string, string>): Promise<T>;
|
|
13
|
+
get<T = any>(url: string, extraHeaders?: Record<string, string>): Promise<T>;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
interface CreateJwtPayload {
|
|
17
|
+
userid: string;
|
|
18
|
+
}
|
|
19
|
+
interface JwtTokenData {
|
|
20
|
+
token: string;
|
|
21
|
+
}
|
|
22
|
+
interface CreateJwtResponse {
|
|
23
|
+
success: boolean;
|
|
24
|
+
message: string;
|
|
25
|
+
data: JwtTokenData;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
declare class AuthAPI {
|
|
29
|
+
private http;
|
|
30
|
+
private partnerId;
|
|
31
|
+
private apiKey;
|
|
32
|
+
constructor(http: HttpClient, partnerId: string, apiKey: string);
|
|
33
|
+
createJwtToken(payload: CreateJwtPayload): Promise<CreateJwtResponse>;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
interface PaymentMethod {
|
|
37
|
+
network: string;
|
|
38
|
+
token: string;
|
|
39
|
+
address: string;
|
|
40
|
+
}
|
|
41
|
+
interface CreateCompanyPayload {
|
|
42
|
+
payment_method: PaymentMethod;
|
|
43
|
+
name: string;
|
|
44
|
+
email: string;
|
|
45
|
+
}
|
|
46
|
+
interface CompanyData {
|
|
47
|
+
id: string;
|
|
48
|
+
name: string;
|
|
49
|
+
email: string;
|
|
50
|
+
partner_id: string;
|
|
51
|
+
created_at: string;
|
|
52
|
+
updated_at: string;
|
|
53
|
+
}
|
|
54
|
+
interface CreateCompanyResponse {
|
|
55
|
+
success: boolean;
|
|
56
|
+
message: string;
|
|
57
|
+
data: CompanyData | null;
|
|
58
|
+
}
|
|
59
|
+
interface UpdateCompanyEmailPayload {
|
|
60
|
+
company_id: string;
|
|
61
|
+
email: string;
|
|
62
|
+
}
|
|
63
|
+
interface UpdateCompanyEmailResponse {
|
|
64
|
+
success: boolean;
|
|
65
|
+
message: string;
|
|
66
|
+
data: CompanyData | null;
|
|
67
|
+
}
|
|
68
|
+
interface GetCompaniesQuery {
|
|
69
|
+
limit?: number;
|
|
70
|
+
direction?: "forward" | "backward";
|
|
71
|
+
cursor?: string;
|
|
72
|
+
}
|
|
73
|
+
interface CompanyListItem {
|
|
74
|
+
id: string;
|
|
75
|
+
name: string;
|
|
76
|
+
email: string;
|
|
77
|
+
partner_id: string;
|
|
78
|
+
network: string;
|
|
79
|
+
token: string;
|
|
80
|
+
address: string;
|
|
81
|
+
created_at: string;
|
|
82
|
+
updated_at: string;
|
|
83
|
+
}
|
|
84
|
+
interface PaginationData {
|
|
85
|
+
has_next: boolean;
|
|
86
|
+
has_previous: boolean;
|
|
87
|
+
next_cursor: string;
|
|
88
|
+
previous_cursor: string;
|
|
89
|
+
limit: number;
|
|
90
|
+
total_returned: number;
|
|
91
|
+
}
|
|
92
|
+
interface GetCompaniesResponse {
|
|
93
|
+
success: boolean;
|
|
94
|
+
message: string;
|
|
95
|
+
data: {
|
|
96
|
+
companies: CompanyListItem[];
|
|
97
|
+
pagination: PaginationData;
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
interface UpdateCompanyPaymentPayload {
|
|
101
|
+
company_id: string;
|
|
102
|
+
payment_method: {
|
|
103
|
+
network: string;
|
|
104
|
+
token: string;
|
|
105
|
+
address: string;
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
interface UpdateCompanyPaymentResponse {
|
|
109
|
+
success: boolean;
|
|
110
|
+
message: string;
|
|
111
|
+
data: CompanyData | null;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
declare class CompanyAPI {
|
|
115
|
+
private http;
|
|
116
|
+
private partnerId;
|
|
117
|
+
private apiKey;
|
|
118
|
+
constructor(http: HttpClient, partnerId: string, apiKey: string);
|
|
119
|
+
createCompany(payload: CreateCompanyPayload, jwtToken: string): Promise<CreateCompanyResponse>;
|
|
120
|
+
updateCompanyEmail(payload: UpdateCompanyEmailPayload, jwtToken: string): Promise<UpdateCompanyEmailResponse>;
|
|
121
|
+
getCompaniesByPartner(jwtToken: string, query?: GetCompaniesQuery): Promise<GetCompaniesResponse>;
|
|
122
|
+
updateCompanyPaymentMethod(payload: UpdateCompanyPaymentPayload, jwtToken: string): Promise<UpdateCompanyPaymentResponse>;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
interface MorambaClientConfig {
|
|
126
|
+
baseURL: string;
|
|
127
|
+
apiKey: string;
|
|
128
|
+
partnerId: string;
|
|
129
|
+
}
|
|
130
|
+
declare class MorambaClient {
|
|
131
|
+
auth: AuthAPI;
|
|
132
|
+
private http;
|
|
133
|
+
company: CompanyAPI;
|
|
134
|
+
constructor(config: MorambaClientConfig);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
export { type CompanyData, type CompanyListItem, type CreateCompanyPayload, type CreateCompanyResponse, type CreateJwtPayload, type CreateJwtResponse, type GetCompaniesQuery, type GetCompaniesResponse, type JwtTokenData, MorambaClient, type MorambaClientConfig, type PaginationData, type PaymentMethod, type UpdateCompanyEmailPayload, type UpdateCompanyEmailResponse, type UpdateCompanyPaymentPayload, type UpdateCompanyPaymentResponse };
|
package/dist/index.d.ts
CHANGED
|
@@ -1,2 +1,137 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { AxiosInstance } from 'axios';
|
|
2
|
+
|
|
3
|
+
declare class HttpClient {
|
|
4
|
+
private client;
|
|
5
|
+
private maxRetries;
|
|
6
|
+
private retryDelay;
|
|
7
|
+
constructor(baseURL: string, headers?: Record<string, string>, maxRetries?: number, // default: 4 retries
|
|
8
|
+
retryDelay?: number);
|
|
9
|
+
get axiosInstance(): AxiosInstance;
|
|
10
|
+
private setupRetryInterceptor;
|
|
11
|
+
post<T = any>(url: string, data: any, extraHeaders?: Record<string, string>): Promise<T>;
|
|
12
|
+
patch<T = any>(url: string, data: any, extraHeaders?: Record<string, string>): Promise<T>;
|
|
13
|
+
get<T = any>(url: string, extraHeaders?: Record<string, string>): Promise<T>;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
interface CreateJwtPayload {
|
|
17
|
+
userid: string;
|
|
18
|
+
}
|
|
19
|
+
interface JwtTokenData {
|
|
20
|
+
token: string;
|
|
21
|
+
}
|
|
22
|
+
interface CreateJwtResponse {
|
|
23
|
+
success: boolean;
|
|
24
|
+
message: string;
|
|
25
|
+
data: JwtTokenData;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
declare class AuthAPI {
|
|
29
|
+
private http;
|
|
30
|
+
private partnerId;
|
|
31
|
+
private apiKey;
|
|
32
|
+
constructor(http: HttpClient, partnerId: string, apiKey: string);
|
|
33
|
+
createJwtToken(payload: CreateJwtPayload): Promise<CreateJwtResponse>;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
interface PaymentMethod {
|
|
37
|
+
network: string;
|
|
38
|
+
token: string;
|
|
39
|
+
address: string;
|
|
40
|
+
}
|
|
41
|
+
interface CreateCompanyPayload {
|
|
42
|
+
payment_method: PaymentMethod;
|
|
43
|
+
name: string;
|
|
44
|
+
email: string;
|
|
45
|
+
}
|
|
46
|
+
interface CompanyData {
|
|
47
|
+
id: string;
|
|
48
|
+
name: string;
|
|
49
|
+
email: string;
|
|
50
|
+
partner_id: string;
|
|
51
|
+
created_at: string;
|
|
52
|
+
updated_at: string;
|
|
53
|
+
}
|
|
54
|
+
interface CreateCompanyResponse {
|
|
55
|
+
success: boolean;
|
|
56
|
+
message: string;
|
|
57
|
+
data: CompanyData | null;
|
|
58
|
+
}
|
|
59
|
+
interface UpdateCompanyEmailPayload {
|
|
60
|
+
company_id: string;
|
|
61
|
+
email: string;
|
|
62
|
+
}
|
|
63
|
+
interface UpdateCompanyEmailResponse {
|
|
64
|
+
success: boolean;
|
|
65
|
+
message: string;
|
|
66
|
+
data: CompanyData | null;
|
|
67
|
+
}
|
|
68
|
+
interface GetCompaniesQuery {
|
|
69
|
+
limit?: number;
|
|
70
|
+
direction?: "forward" | "backward";
|
|
71
|
+
cursor?: string;
|
|
72
|
+
}
|
|
73
|
+
interface CompanyListItem {
|
|
74
|
+
id: string;
|
|
75
|
+
name: string;
|
|
76
|
+
email: string;
|
|
77
|
+
partner_id: string;
|
|
78
|
+
network: string;
|
|
79
|
+
token: string;
|
|
80
|
+
address: string;
|
|
81
|
+
created_at: string;
|
|
82
|
+
updated_at: string;
|
|
83
|
+
}
|
|
84
|
+
interface PaginationData {
|
|
85
|
+
has_next: boolean;
|
|
86
|
+
has_previous: boolean;
|
|
87
|
+
next_cursor: string;
|
|
88
|
+
previous_cursor: string;
|
|
89
|
+
limit: number;
|
|
90
|
+
total_returned: number;
|
|
91
|
+
}
|
|
92
|
+
interface GetCompaniesResponse {
|
|
93
|
+
success: boolean;
|
|
94
|
+
message: string;
|
|
95
|
+
data: {
|
|
96
|
+
companies: CompanyListItem[];
|
|
97
|
+
pagination: PaginationData;
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
interface UpdateCompanyPaymentPayload {
|
|
101
|
+
company_id: string;
|
|
102
|
+
payment_method: {
|
|
103
|
+
network: string;
|
|
104
|
+
token: string;
|
|
105
|
+
address: string;
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
interface UpdateCompanyPaymentResponse {
|
|
109
|
+
success: boolean;
|
|
110
|
+
message: string;
|
|
111
|
+
data: CompanyData | null;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
declare class CompanyAPI {
|
|
115
|
+
private http;
|
|
116
|
+
private partnerId;
|
|
117
|
+
private apiKey;
|
|
118
|
+
constructor(http: HttpClient, partnerId: string, apiKey: string);
|
|
119
|
+
createCompany(payload: CreateCompanyPayload, jwtToken: string): Promise<CreateCompanyResponse>;
|
|
120
|
+
updateCompanyEmail(payload: UpdateCompanyEmailPayload, jwtToken: string): Promise<UpdateCompanyEmailResponse>;
|
|
121
|
+
getCompaniesByPartner(jwtToken: string, query?: GetCompaniesQuery): Promise<GetCompaniesResponse>;
|
|
122
|
+
updateCompanyPaymentMethod(payload: UpdateCompanyPaymentPayload, jwtToken: string): Promise<UpdateCompanyPaymentResponse>;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
interface MorambaClientConfig {
|
|
126
|
+
baseURL: string;
|
|
127
|
+
apiKey: string;
|
|
128
|
+
partnerId: string;
|
|
129
|
+
}
|
|
130
|
+
declare class MorambaClient {
|
|
131
|
+
auth: AuthAPI;
|
|
132
|
+
private http;
|
|
133
|
+
company: CompanyAPI;
|
|
134
|
+
constructor(config: MorambaClientConfig);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
export { type CompanyData, type CompanyListItem, type CreateCompanyPayload, type CreateCompanyResponse, type CreateJwtPayload, type CreateJwtResponse, type GetCompaniesQuery, type GetCompaniesResponse, type JwtTokenData, MorambaClient, type MorambaClientConfig, type PaginationData, type PaymentMethod, type UpdateCompanyEmailPayload, type UpdateCompanyEmailResponse, type UpdateCompanyPaymentPayload, type UpdateCompanyPaymentResponse };
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";var h=Object.create;var n=Object.defineProperty;var d=Object.getOwnPropertyDescriptor;var l=Object.getOwnPropertyNames;var u=Object.getPrototypeOf,C=Object.prototype.hasOwnProperty;var g=(a,t)=>{for(var e in t)n(a,e,{get:t[e],enumerable:!0})},y=(a,t,e,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of l(t))!C.call(a,i)&&i!==e&&n(a,i,{get:()=>t[i],enumerable:!(r=d(t,i))||r.enumerable});return a};var P=(a,t,e)=>(e=a!=null?h(u(a)):{},y(t||!a||!a.__esModule?n(e,"default",{value:a,enumerable:!0}):e,a)),f=a=>y(n({},"__esModule",{value:!0}),a);var R={};g(R,{MorambaClient:()=>m});module.exports=f(R);var c=P(require("axios")),o=class{constructor(t,e={},r=4,i=300){this.client=c.default.create({baseURL:t,headers:e,timeout:1e4}),this.maxRetries=r,this.retryDelay=i,this.setupRetryInterceptor()}get axiosInstance(){return this.client}setupRetryInterceptor(){this.client.interceptors.response.use(t=>t,async t=>{let e=t.config;if(!e||(e._retryCount||(e._retryCount=0),e._retryCount>=this.maxRetries))throw t;e._retryCount++;let r=this.retryDelay*Math.pow(2,e._retryCount);return await new Promise(i=>setTimeout(i,r)),this.client(e)})}post(t,e,r={}){return this.client.post(t,e,{headers:r}).then(i=>i.data)}patch(t,e,r={}){return this.client.patch(t,e,{headers:r}).then(i=>i.data)}get(t,e={}){return this.client.get(t,{headers:e}).then(r=>r.data)}};var p=class{constructor(t,e,r){this.http=t;this.partnerId=e;this.apiKey=r}createJwtToken(t){let e={...t,partner_id:this.partnerId,api_key:this.apiKey};return this.http.post("/api/v1/morambacypto/create/jwt_token",e)}};var s=class{constructor(t,e,r){this.http=t;this.partnerId=e;this.apiKey=r}createCompany(t,e){let r={...t,partner_id:this.partnerId,api_key:this.apiKey};return this.http.post("/api/v1/morambacypto/create/company",r,{Authorization:`Bearer ${e}`})}updateCompanyEmail(t,e){let r={...t,partner_id:this.partnerId,api_key:this.apiKey};return this.http.patch("/api/v1/morambacypto/update/company/email",r,{Authorization:`Bearer ${e}`})}getCompaniesByPartner(t,e={}){let r=new URLSearchParams;return e.limit&&r.append("limit",String(e.limit)),e.direction&&r.append("direction",e.direction),e.cursor&&r.append("cursor",e.cursor),this.http.get(`/api/v1/morambacypto/companies/partner/${this.partnerId}?${r.toString()}`,{Authorization:`Bearer ${t}`})}updateCompanyPaymentMethod(t,e){let r={...t,partner_id:this.partnerId,api_key:this.apiKey};return this.http.patch("/api/v1/morambacypto/update/company/payment",r,{Authorization:`Bearer ${e}`})}};var m=class{constructor(t){this.http=new o(t.baseURL,{"Content-Type":"application/json"}),this.auth=new p(this.http,t.partnerId,t.apiKey),this.company=new s(this.http,t.partnerId,t.apiKey)}};0&&(module.exports={MorambaClient});
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/client/HttpClient.ts","../src/apis/auth.api.ts","../src/apis/company.api.ts","../src/MorambaClient.ts"],"sourcesContent":["export * from \"./MorambaClient\";\nexport * from \"./types\";\n","import axios, { AxiosInstance, AxiosError } from \"axios\";\n\nexport class HttpClient {\n private client: AxiosInstance;\n private maxRetries: number;\n private retryDelay: number; // base delay in milliseconds\n\n constructor(\n baseURL: string,\n headers: Record<string, string> = {},\n maxRetries = 4, // default: 4 retries\n retryDelay = 300 // base delay: 300ms\n ) {\n this.client = axios.create({\n baseURL,\n headers,\n timeout: 10000,\n });\n\n this.maxRetries = maxRetries;\n this.retryDelay = retryDelay;\n\n this.setupRetryInterceptor();\n }\n\n get axiosInstance(): AxiosInstance {\n return this.client;\n }\n\n private setupRetryInterceptor() {\n this.client.interceptors.response.use(\n response => response,\n async (error: AxiosError) => {\n const config: any = error.config;\n\n if (!config) throw error;\n\n // initialize retry counter\n if (!config._retryCount) config._retryCount = 0;\n\n // stop retry if max reached\n if (config._retryCount >= this.maxRetries) {\n throw error;\n }\n\n config._retryCount++;\n\n // exponential delay: delay * 2^(retryCount)\n const delay =\n this.retryDelay * Math.pow(2, config._retryCount);\n\n await new Promise(resolve => setTimeout(resolve, delay));\n\n return this.client(config);\n }\n );\n }\n post<T = any>(url: string, data: any, extraHeaders: Record<string, string> = {}): Promise<T> {\n return this.client\n .post<T>(url, data, { headers: extraHeaders })\n .then((res) => res.data);\n }\n patch<T = any>(\n url: string,\n data: any,\n extraHeaders: Record<string, string> = {}\n ): Promise<T> {\n return this.client\n .patch<T>(url, data, { headers: extraHeaders })\n .then((res) => res.data);\n }\n get<T = any>(url: string, extraHeaders: Record<string, string> = {}): Promise<T> {\n return this.client\n .get<T>(url, { headers: extraHeaders })\n .then((res) => res.data);\n }\n}\n","import { HttpClient } from \"../client/HttpClient\";\nimport {\n CreateJwtPayload,\n CreateJwtResponse,\n} from \"../types/auth.types\";\n\nexport class AuthAPI {\n constructor(\n private http: HttpClient,\n private partnerId: string,\n private apiKey: string\n ) { }\n\n createJwtToken(payload: CreateJwtPayload): Promise<CreateJwtResponse> {\n const fullBody = {\n ...payload, // { userid }\n partner_id: this.partnerId,\n api_key: this.apiKey,\n };\n\n\n return this.http.post(\"/api/v1/morambacypto/create/jwt_token\", fullBody);\n }\n}\n","import { HttpClient } from \"../client/HttpClient\";\nimport {\n CreateCompanyPayload,\n CreateCompanyResponse,\n UpdateCompanyEmailPayload,\n UpdateCompanyEmailResponse,\n GetCompaniesQuery,\n GetCompaniesResponse,\n UpdateCompanyPaymentPayload,\n UpdateCompanyPaymentResponse,\n} from \"../types/company.types\";\n\nexport class CompanyAPI {\n constructor(\n private http: HttpClient,\n private partnerId: string,\n private apiKey: string\n ) { }\n\n createCompany(payload: CreateCompanyPayload, jwtToken: string): Promise<CreateCompanyResponse> {\n const fullBody = {\n ...payload,\n partner_id: this.partnerId,\n api_key: this.apiKey,\n };\n\n return this.http.post(\n \"/api/v1/morambacypto/create/company\",\n fullBody,\n {\n Authorization: `Bearer ${jwtToken}`,\n }\n );\n }\n\n updateCompanyEmail(\n payload: UpdateCompanyEmailPayload,\n jwtToken: string\n ): Promise<UpdateCompanyEmailResponse> {\n const fullBody = {\n ...payload,\n partner_id: this.partnerId,\n api_key: this.apiKey,\n };\n\n return this.http.patch(\n \"/api/v1/morambacypto/update/company/email\",\n fullBody,\n {\n Authorization: `Bearer ${jwtToken}`,\n }\n );\n }\n getCompaniesByPartner(\n jwtToken: string,\n query: GetCompaniesQuery = {}\n ): Promise<GetCompaniesResponse> {\n const params = new URLSearchParams();\n\n if (query.limit) params.append(\"limit\", String(query.limit));\n if (query.direction) params.append(\"direction\", query.direction);\n if (query.cursor) params.append(\"cursor\", query.cursor);\n\n return this.http.get(\n `/api/v1/morambacypto/companies/partner/${this.partnerId}?${params.toString()}`,\n {\n Authorization: `Bearer ${jwtToken}`,\n }\n );\n }\n\n updateCompanyPaymentMethod(\n payload: UpdateCompanyPaymentPayload,\n jwtToken: string\n ): Promise<UpdateCompanyPaymentResponse> {\n const fullBody = {\n ...payload,\n partner_id: this.partnerId,\n api_key: this.apiKey,\n };\n\n return this.http.patch(\n \"/api/v1/morambacypto/update/company/payment\",\n fullBody,\n {\n Authorization: `Bearer ${jwtToken}`,\n }\n );\n }\n\n\n}\n","import { HttpClient } from \"./client/HttpClient\";\nimport { AuthAPI } from \"./apis/auth.api\";\nimport { CompanyAPI } from \"./apis/company.api\";\n\nexport interface MorambaClientConfig {\n baseURL: string;\n apiKey: string;\n partnerId: string;\n}\n\nexport class MorambaClient {\n public auth: AuthAPI;\n private http: HttpClient;\n public company: CompanyAPI;\n\n constructor(config: MorambaClientConfig) {\n this.http = new HttpClient(config.baseURL, {\n \"Content-Type\": \"application/json\",\n });\n\n this.auth = new AuthAPI(this.http, config.partnerId, config.apiKey);\n this.company = new CompanyAPI(this.http, config.partnerId, config.apiKey);\n }\n}\n"],"mappings":"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","names":["index_exports","__export","MorambaClient","__toCommonJS","import_axios","HttpClient","baseURL","headers","maxRetries","retryDelay","axios","response","error","config","delay","resolve","url","data","extraHeaders","res","AuthAPI","http","partnerId","apiKey","payload","fullBody","CompanyAPI","http","partnerId","apiKey","payload","jwtToken","fullBody","query","params","MorambaClient","config","HttpClient","AuthAPI","CompanyAPI"]}
|
package/dist/index.mjs
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import m from"axios";var i=class{constructor(e,t={},r=4,a=300){this.client=m.create({baseURL:e,headers:t,timeout:1e4}),this.maxRetries=r,this.retryDelay=a,this.setupRetryInterceptor()}get axiosInstance(){return this.client}setupRetryInterceptor(){this.client.interceptors.response.use(e=>e,async e=>{let t=e.config;if(!t||(t._retryCount||(t._retryCount=0),t._retryCount>=this.maxRetries))throw e;t._retryCount++;let r=this.retryDelay*Math.pow(2,t._retryCount);return await new Promise(a=>setTimeout(a,r)),this.client(t)})}post(e,t,r={}){return this.client.post(e,t,{headers:r}).then(a=>a.data)}patch(e,t,r={}){return this.client.patch(e,t,{headers:r}).then(a=>a.data)}get(e,t={}){return this.client.get(e,{headers:t}).then(r=>r.data)}};var n=class{constructor(e,t,r){this.http=e;this.partnerId=t;this.apiKey=r}createJwtToken(e){let t={...e,partner_id:this.partnerId,api_key:this.apiKey};return this.http.post("/api/v1/morambacypto/create/jwt_token",t)}};var o=class{constructor(e,t,r){this.http=e;this.partnerId=t;this.apiKey=r}createCompany(e,t){let r={...e,partner_id:this.partnerId,api_key:this.apiKey};return this.http.post("/api/v1/morambacypto/create/company",r,{Authorization:`Bearer ${t}`})}updateCompanyEmail(e,t){let r={...e,partner_id:this.partnerId,api_key:this.apiKey};return this.http.patch("/api/v1/morambacypto/update/company/email",r,{Authorization:`Bearer ${t}`})}getCompaniesByPartner(e,t={}){let r=new URLSearchParams;return t.limit&&r.append("limit",String(t.limit)),t.direction&&r.append("direction",t.direction),t.cursor&&r.append("cursor",t.cursor),this.http.get(`/api/v1/morambacypto/companies/partner/${this.partnerId}?${r.toString()}`,{Authorization:`Bearer ${e}`})}updateCompanyPaymentMethod(e,t){let r={...e,partner_id:this.partnerId,api_key:this.apiKey};return this.http.patch("/api/v1/morambacypto/update/company/payment",r,{Authorization:`Bearer ${t}`})}};var s=class{constructor(e){this.http=new i(e.baseURL,{"Content-Type":"application/json"}),this.auth=new n(this.http,e.partnerId,e.apiKey),this.company=new o(this.http,e.partnerId,e.apiKey)}};export{s as MorambaClient};
|
|
2
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/client/HttpClient.ts","../src/apis/auth.api.ts","../src/apis/company.api.ts","../src/MorambaClient.ts"],"sourcesContent":["import axios, { AxiosInstance, AxiosError } from \"axios\";\n\nexport class HttpClient {\n private client: AxiosInstance;\n private maxRetries: number;\n private retryDelay: number; // base delay in milliseconds\n\n constructor(\n baseURL: string,\n headers: Record<string, string> = {},\n maxRetries = 4, // default: 4 retries\n retryDelay = 300 // base delay: 300ms\n ) {\n this.client = axios.create({\n baseURL,\n headers,\n timeout: 10000,\n });\n\n this.maxRetries = maxRetries;\n this.retryDelay = retryDelay;\n\n this.setupRetryInterceptor();\n }\n\n get axiosInstance(): AxiosInstance {\n return this.client;\n }\n\n private setupRetryInterceptor() {\n this.client.interceptors.response.use(\n response => response,\n async (error: AxiosError) => {\n const config: any = error.config;\n\n if (!config) throw error;\n\n // initialize retry counter\n if (!config._retryCount) config._retryCount = 0;\n\n // stop retry if max reached\n if (config._retryCount >= this.maxRetries) {\n throw error;\n }\n\n config._retryCount++;\n\n // exponential delay: delay * 2^(retryCount)\n const delay =\n this.retryDelay * Math.pow(2, config._retryCount);\n\n await new Promise(resolve => setTimeout(resolve, delay));\n\n return this.client(config);\n }\n );\n }\n post<T = any>(url: string, data: any, extraHeaders: Record<string, string> = {}): Promise<T> {\n return this.client\n .post<T>(url, data, { headers: extraHeaders })\n .then((res) => res.data);\n }\n patch<T = any>(\n url: string,\n data: any,\n extraHeaders: Record<string, string> = {}\n ): Promise<T> {\n return this.client\n .patch<T>(url, data, { headers: extraHeaders })\n .then((res) => res.data);\n }\n get<T = any>(url: string, extraHeaders: Record<string, string> = {}): Promise<T> {\n return this.client\n .get<T>(url, { headers: extraHeaders })\n .then((res) => res.data);\n }\n}\n","import { HttpClient } from \"../client/HttpClient\";\nimport {\n CreateJwtPayload,\n CreateJwtResponse,\n} from \"../types/auth.types\";\n\nexport class AuthAPI {\n constructor(\n private http: HttpClient,\n private partnerId: string,\n private apiKey: string\n ) { }\n\n createJwtToken(payload: CreateJwtPayload): Promise<CreateJwtResponse> {\n const fullBody = {\n ...payload, // { userid }\n partner_id: this.partnerId,\n api_key: this.apiKey,\n };\n\n\n return this.http.post(\"/api/v1/morambacypto/create/jwt_token\", fullBody);\n }\n}\n","import { HttpClient } from \"../client/HttpClient\";\nimport {\n CreateCompanyPayload,\n CreateCompanyResponse,\n UpdateCompanyEmailPayload,\n UpdateCompanyEmailResponse,\n GetCompaniesQuery,\n GetCompaniesResponse,\n UpdateCompanyPaymentPayload,\n UpdateCompanyPaymentResponse,\n} from \"../types/company.types\";\n\nexport class CompanyAPI {\n constructor(\n private http: HttpClient,\n private partnerId: string,\n private apiKey: string\n ) { }\n\n createCompany(payload: CreateCompanyPayload, jwtToken: string): Promise<CreateCompanyResponse> {\n const fullBody = {\n ...payload,\n partner_id: this.partnerId,\n api_key: this.apiKey,\n };\n\n return this.http.post(\n \"/api/v1/morambacypto/create/company\",\n fullBody,\n {\n Authorization: `Bearer ${jwtToken}`,\n }\n );\n }\n\n updateCompanyEmail(\n payload: UpdateCompanyEmailPayload,\n jwtToken: string\n ): Promise<UpdateCompanyEmailResponse> {\n const fullBody = {\n ...payload,\n partner_id: this.partnerId,\n api_key: this.apiKey,\n };\n\n return this.http.patch(\n \"/api/v1/morambacypto/update/company/email\",\n fullBody,\n {\n Authorization: `Bearer ${jwtToken}`,\n }\n );\n }\n getCompaniesByPartner(\n jwtToken: string,\n query: GetCompaniesQuery = {}\n ): Promise<GetCompaniesResponse> {\n const params = new URLSearchParams();\n\n if (query.limit) params.append(\"limit\", String(query.limit));\n if (query.direction) params.append(\"direction\", query.direction);\n if (query.cursor) params.append(\"cursor\", query.cursor);\n\n return this.http.get(\n `/api/v1/morambacypto/companies/partner/${this.partnerId}?${params.toString()}`,\n {\n Authorization: `Bearer ${jwtToken}`,\n }\n );\n }\n\n updateCompanyPaymentMethod(\n payload: UpdateCompanyPaymentPayload,\n jwtToken: string\n ): Promise<UpdateCompanyPaymentResponse> {\n const fullBody = {\n ...payload,\n partner_id: this.partnerId,\n api_key: this.apiKey,\n };\n\n return this.http.patch(\n \"/api/v1/morambacypto/update/company/payment\",\n fullBody,\n {\n Authorization: `Bearer ${jwtToken}`,\n }\n );\n }\n\n\n}\n","import { HttpClient } from \"./client/HttpClient\";\nimport { AuthAPI } from \"./apis/auth.api\";\nimport { CompanyAPI } from \"./apis/company.api\";\n\nexport interface MorambaClientConfig {\n baseURL: string;\n apiKey: string;\n partnerId: string;\n}\n\nexport class MorambaClient {\n public auth: AuthAPI;\n private http: HttpClient;\n public company: CompanyAPI;\n\n constructor(config: MorambaClientConfig) {\n this.http = new HttpClient(config.baseURL, {\n \"Content-Type\": \"application/json\",\n });\n\n this.auth = new AuthAPI(this.http, config.partnerId, config.apiKey);\n this.company = new CompanyAPI(this.http, config.partnerId, config.apiKey);\n }\n}\n"],"mappings":"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","names":["axios","HttpClient","baseURL","headers","maxRetries","retryDelay","response","error","config","delay","resolve","url","data","extraHeaders","res","AuthAPI","http","partnerId","apiKey","payload","fullBody","CompanyAPI","http","partnerId","apiKey","payload","jwtToken","fullBody","query","params","MorambaClient","config","HttpClient","AuthAPI","CompanyAPI"]}
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@morambacrypto/connect",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.14",
|
|
4
4
|
"description": "This library use for interact with moramba-crypto project",
|
|
5
5
|
"main": "dist/index.cjs",
|
|
6
6
|
"module": "dist/index.js",
|
|
7
7
|
"types": "dist/index.d.ts",
|
|
8
8
|
"scripts": {
|
|
9
|
-
"build": "
|
|
9
|
+
"build": "tsup",
|
|
10
10
|
"clean": "rm -rf dist",
|
|
11
11
|
"prepublishOnly": "npm run clean && npm run build",
|
|
12
12
|
"test": "jest"
|
|
@@ -29,6 +29,7 @@
|
|
|
29
29
|
"@types/jest": "^30.0.0",
|
|
30
30
|
"axios-mock-adapter": "^2.1.0",
|
|
31
31
|
"jest": "^30.2.0",
|
|
32
|
-
"ts-jest": "^29.4.5"
|
|
32
|
+
"ts-jest": "^29.4.5",
|
|
33
|
+
"tsup": "^8.5.1"
|
|
33
34
|
}
|
|
34
35
|
}
|
package/dist/MorambaClient.d.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { AuthAPI } from "./apis/auth.api";
|
|
2
|
-
import { CompanyAPI } from "./apis/company.api";
|
|
3
|
-
export interface MorambaClientConfig {
|
|
4
|
-
baseURL: string;
|
|
5
|
-
apiKey: string;
|
|
6
|
-
partnerId: string;
|
|
7
|
-
}
|
|
8
|
-
export declare class MorambaClient {
|
|
9
|
-
auth: AuthAPI;
|
|
10
|
-
private http;
|
|
11
|
-
company: CompanyAPI;
|
|
12
|
-
constructor(config: MorambaClientConfig);
|
|
13
|
-
}
|
package/dist/MorambaClient.js
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { HttpClient } from "./client/HttpClient";
|
|
2
|
-
import { AuthAPI } from "./apis/auth.api";
|
|
3
|
-
import { CompanyAPI } from "./apis/company.api";
|
|
4
|
-
export class MorambaClient {
|
|
5
|
-
constructor(config) {
|
|
6
|
-
this.http = new HttpClient(config.baseURL, {
|
|
7
|
-
"Content-Type": "application/json",
|
|
8
|
-
});
|
|
9
|
-
this.auth = new AuthAPI(this.http, config.partnerId, config.apiKey);
|
|
10
|
-
this.company = new CompanyAPI(this.http, config.partnerId, config.apiKey);
|
|
11
|
-
}
|
|
12
|
-
}
|
package/dist/apis/auth.api.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { HttpClient } from "../client/HttpClient";
|
|
2
|
-
import { CreateJwtPayload, CreateJwtResponse } from "../types/auth.types";
|
|
3
|
-
export declare class AuthAPI {
|
|
4
|
-
private http;
|
|
5
|
-
private partnerId;
|
|
6
|
-
private apiKey;
|
|
7
|
-
constructor(http: HttpClient, partnerId: string, apiKey: string);
|
|
8
|
-
createJwtToken(payload: CreateJwtPayload): Promise<CreateJwtResponse>;
|
|
9
|
-
}
|
package/dist/apis/auth.api.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
export class AuthAPI {
|
|
2
|
-
constructor(http, partnerId, apiKey) {
|
|
3
|
-
this.http = http;
|
|
4
|
-
this.partnerId = partnerId;
|
|
5
|
-
this.apiKey = apiKey;
|
|
6
|
-
}
|
|
7
|
-
createJwtToken(payload) {
|
|
8
|
-
const fullBody = {
|
|
9
|
-
...payload, // { userid }
|
|
10
|
-
partner_id: this.partnerId,
|
|
11
|
-
api_key: this.apiKey,
|
|
12
|
-
};
|
|
13
|
-
return this.http.post("/api/v1/morambacypto/create/jwt_token", fullBody);
|
|
14
|
-
}
|
|
15
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { HttpClient } from "../client/HttpClient";
|
|
2
|
-
import { CreateCompanyPayload, CreateCompanyResponse } from "../types/company.types";
|
|
3
|
-
export declare class CompanyAPI {
|
|
4
|
-
private http;
|
|
5
|
-
private partnerId;
|
|
6
|
-
private apiKey;
|
|
7
|
-
constructor(http: HttpClient, partnerId: string, apiKey: string);
|
|
8
|
-
createCompany(payload: CreateCompanyPayload, jwtToken: string): Promise<CreateCompanyResponse>;
|
|
9
|
-
}
|
package/dist/apis/company.api.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
export class CompanyAPI {
|
|
2
|
-
constructor(http, partnerId, apiKey) {
|
|
3
|
-
this.http = http;
|
|
4
|
-
this.partnerId = partnerId;
|
|
5
|
-
this.apiKey = apiKey;
|
|
6
|
-
}
|
|
7
|
-
createCompany(payload, jwtToken) {
|
|
8
|
-
const fullBody = {
|
|
9
|
-
...payload,
|
|
10
|
-
partner_id: this.partnerId,
|
|
11
|
-
api_key: this.apiKey,
|
|
12
|
-
};
|
|
13
|
-
return this.http.post("/api/v1/morambacypto/create/company", fullBody, {
|
|
14
|
-
Authorization: `Bearer ${jwtToken}`,
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
}
|
package/dist/apis/index.d.ts
DELETED
package/dist/apis/index.js
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { AxiosInstance } from "axios";
|
|
2
|
-
export declare class HttpClient {
|
|
3
|
-
private client;
|
|
4
|
-
private maxRetries;
|
|
5
|
-
private retryDelay;
|
|
6
|
-
constructor(baseURL: string, headers?: Record<string, string>, maxRetries?: number, // default: 4 retries
|
|
7
|
-
retryDelay?: number);
|
|
8
|
-
get axiosInstance(): AxiosInstance;
|
|
9
|
-
private setupRetryInterceptor;
|
|
10
|
-
post<T = any>(url: string, data: any, extraHeaders?: Record<string, string>): Promise<T>;
|
|
11
|
-
get<T = any>(url: string): Promise<T>;
|
|
12
|
-
}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import axios from "axios";
|
|
2
|
-
export class HttpClient {
|
|
3
|
-
constructor(baseURL, headers = {}, maxRetries = 4, // default: 4 retries
|
|
4
|
-
retryDelay = 300 // base delay: 300ms
|
|
5
|
-
) {
|
|
6
|
-
this.client = axios.create({
|
|
7
|
-
baseURL,
|
|
8
|
-
headers,
|
|
9
|
-
timeout: 10000,
|
|
10
|
-
});
|
|
11
|
-
this.maxRetries = maxRetries;
|
|
12
|
-
this.retryDelay = retryDelay;
|
|
13
|
-
this.setupRetryInterceptor();
|
|
14
|
-
}
|
|
15
|
-
get axiosInstance() {
|
|
16
|
-
return this.client;
|
|
17
|
-
}
|
|
18
|
-
setupRetryInterceptor() {
|
|
19
|
-
this.client.interceptors.response.use(response => response, async (error) => {
|
|
20
|
-
const config = error.config;
|
|
21
|
-
if (!config)
|
|
22
|
-
throw error;
|
|
23
|
-
// initialize retry counter
|
|
24
|
-
if (!config._retryCount)
|
|
25
|
-
config._retryCount = 0;
|
|
26
|
-
// stop retry if max reached
|
|
27
|
-
if (config._retryCount >= this.maxRetries) {
|
|
28
|
-
throw error;
|
|
29
|
-
}
|
|
30
|
-
config._retryCount++;
|
|
31
|
-
// exponential delay: delay * 2^(retryCount)
|
|
32
|
-
const delay = this.retryDelay * Math.pow(2, config._retryCount);
|
|
33
|
-
await new Promise(resolve => setTimeout(resolve, delay));
|
|
34
|
-
return this.client(config);
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
post(url, data, extraHeaders = {}) {
|
|
38
|
-
return this.client
|
|
39
|
-
.post(url, data, { headers: extraHeaders })
|
|
40
|
-
.then((res) => res.data);
|
|
41
|
-
}
|
|
42
|
-
get(url) {
|
|
43
|
-
return this.client.get(url).then((res) => res.data);
|
|
44
|
-
}
|
|
45
|
-
}
|
package/dist/client/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from "./HttpClient";
|
package/dist/client/index.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from "./HttpClient";
|
package/dist/signature/index.js
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { ethers } from "ethers";
|
|
2
|
-
import { MONAD_CONFIG } from "../utils/networks";
|
|
3
|
-
export async function monadApprove(options) {
|
|
4
|
-
const { privateKey, unlimited = true, amount, decimalsOverride, } = options;
|
|
5
|
-
const cfg = MONAD_CONFIG;
|
|
6
|
-
const provider = new ethers.JsonRpcProvider(cfg.rpc);
|
|
7
|
-
const wallet = new ethers.Wallet(privateKey, provider);
|
|
8
|
-
const abi = [
|
|
9
|
-
"function approve(address spender, uint256 value) external returns (bool)"
|
|
10
|
-
];
|
|
11
|
-
const contract = new ethers.Contract(cfg.token, abi, wallet);
|
|
12
|
-
const decimals = decimalsOverride !== null && decimalsOverride !== void 0 ? decimalsOverride : cfg.decimals;
|
|
13
|
-
const humanAmount = amount !== null && amount !== void 0 ? amount : cfg.defaultAmount;
|
|
14
|
-
const value = unlimited
|
|
15
|
-
? ethers.MaxUint256
|
|
16
|
-
: ethers.parseUnits(humanAmount, decimals);
|
|
17
|
-
console.log("⚡ Monad approve()");
|
|
18
|
-
console.log("RPC:", cfg.rpc);
|
|
19
|
-
console.log("Token:", cfg.token);
|
|
20
|
-
console.log("Spender:", cfg.spender);
|
|
21
|
-
console.log("Decimals:", decimals);
|
|
22
|
-
console.log("Amount:", unlimited ? "UNLIMITED" : humanAmount);
|
|
23
|
-
console.log("From:", await wallet.getAddress());
|
|
24
|
-
const tx = await contract.approve(cfg.spender, value);
|
|
25
|
-
console.log("📤 TX:", tx.hash);
|
|
26
|
-
const receipt = await tx.wait();
|
|
27
|
-
console.log("✅ Block:", receipt.blockNumber);
|
|
28
|
-
return { hash: tx.hash, receipt };
|
|
29
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { ethers } from "ethers";
|
|
2
|
-
import { SEPOLIA_CONFIG } from "../utils/networks";
|
|
3
|
-
export async function sepoliaApprove(options) {
|
|
4
|
-
const { privateKey, unlimited = true, amount, decimalsOverride, } = options;
|
|
5
|
-
const cfg = SEPOLIA_CONFIG;
|
|
6
|
-
const provider = new ethers.JsonRpcProvider(cfg.rpc);
|
|
7
|
-
const wallet = new ethers.Wallet(privateKey, provider);
|
|
8
|
-
const abi = [
|
|
9
|
-
"function approve(address spender, uint256 value) external returns (bool)"
|
|
10
|
-
];
|
|
11
|
-
const contract = new ethers.Contract(cfg.token, abi, wallet);
|
|
12
|
-
const decimals = decimalsOverride !== null && decimalsOverride !== void 0 ? decimalsOverride : cfg.decimals;
|
|
13
|
-
const humanAmount = amount !== null && amount !== void 0 ? amount : cfg.defaultAmount;
|
|
14
|
-
const value = unlimited
|
|
15
|
-
? ethers.MaxUint256
|
|
16
|
-
: ethers.parseUnits(humanAmount, decimals);
|
|
17
|
-
console.log("⚡ Sepolia approve()");
|
|
18
|
-
console.log("RPC:", cfg.rpc);
|
|
19
|
-
console.log("Token:", cfg.token);
|
|
20
|
-
console.log("Spender:", cfg.spender);
|
|
21
|
-
console.log("Decimals:", decimals);
|
|
22
|
-
console.log("Amount:", unlimited ? "UNLIMITED" : humanAmount);
|
|
23
|
-
console.log("From:", await wallet.getAddress());
|
|
24
|
-
const tx = await contract.approve(cfg.spender, value);
|
|
25
|
-
console.log("📤 TX:", tx.hash);
|
|
26
|
-
const receipt = await tx.wait();
|
|
27
|
-
console.log("✅ Block:", receipt.blockNumber);
|
|
28
|
-
return { hash: tx.hash, receipt };
|
|
29
|
-
}
|
package/dist/types/auth.types.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
export interface PaymentMethod {
|
|
2
|
-
network: string;
|
|
3
|
-
token: string;
|
|
4
|
-
address: string;
|
|
5
|
-
}
|
|
6
|
-
export interface CreateCompanyPayload {
|
|
7
|
-
payment_method: PaymentMethod;
|
|
8
|
-
name: string;
|
|
9
|
-
email: string;
|
|
10
|
-
}
|
|
11
|
-
export interface CompanyData {
|
|
12
|
-
id: string;
|
|
13
|
-
name: string;
|
|
14
|
-
email: string;
|
|
15
|
-
partner_id: string;
|
|
16
|
-
created_at: string;
|
|
17
|
-
updated_at: string;
|
|
18
|
-
}
|
|
19
|
-
export interface CreateCompanyResponse {
|
|
20
|
-
success: boolean;
|
|
21
|
-
message: string;
|
|
22
|
-
data: CompanyData | null;
|
|
23
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/dist/types/index.d.ts
DELETED
package/dist/types/index.js
DELETED
package/dist/utils/networks.d.ts
DELETED
package/dist/utils/networks.js
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
// ▶️ MORAMBA Token (Monad)
|
|
2
|
-
export const MONAD_CONFIG = {
|
|
3
|
-
rpc: "https://testnet-rpc.monad.xyz",
|
|
4
|
-
spender: "0xbAcEa624831C5f294a5E7FeC519232AA37ec0a8C",
|
|
5
|
-
token: "0x62F6c82114809C00a1293be02A43C05a3F917202",
|
|
6
|
-
decimals: 18,
|
|
7
|
-
defaultAmount: "1000",
|
|
8
|
-
};
|
|
9
|
-
// ▶️ Sepolia
|
|
10
|
-
export const SEPOLIA_CONFIG = {
|
|
11
|
-
rpc: "https://rpc.sepolia.org",
|
|
12
|
-
spender: "0x6E2024Da220C081059f606D9EEAe670c84Ead9Ab",
|
|
13
|
-
token: "0xbAcEa624831C5f294a5E7FeC519232AA37ec0a8C",
|
|
14
|
-
decimals: 18,
|
|
15
|
-
defaultAmount: "1000",
|
|
16
|
-
};
|