modem-pay
Version:
A TypeScript SDK for integrating with the Modem Pay payment gateway, enabling seamless payment processing and financial services in your applications.
71 lines (70 loc) • 2.84 kB
JavaScript
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const base_1 = __importDefault(require("./base"));
class SessionsResource extends base_1.default {
constructor(apiKey, maxRetries, timeout) {
super(apiKey, maxRetries, timeout);
}
/** Creates a new Session */
create(params) {
return __awaiter(this, void 0, void 0, function* () {
return this.request({
method: "post",
url: `${this.apiURL}/v1/sessions`,
headers: this.getHeaders(),
data: { data: Object.assign({}, params) },
});
});
}
/** Retrieves a Session. */
retrieve(id) {
return __awaiter(this, void 0, void 0, function* () {
return this.request({
method: "get",
url: `${this.apiURL}/v1/sessions/single/${id}`,
headers: this.getHeaders(),
});
});
}
/**
* Expires an active session.
*
* Once expired, customers can no longer complete the session.
* Any customer attempting to load the session will receive a message indicating that the session has expired.
*/
expire(id) {
return __awaiter(this, void 0, void 0, function* () {
return this.request({
method: "put",
url: `${this.apiURL}/v1/sessions/single/${id}`,
headers: this.getHeaders(),
data: { data: { expired: true } },
});
});
}
/** Returns a list of Checkout Sessions. */
list(options = { limit: 10 }) {
return __awaiter(this, void 0, void 0, function* () {
const data = yield this.request({
method: "get",
url: `${this.apiURL}/v1/sessions`,
headers: this.getHeaders(),
params: Object.assign({ offset: 0 }, options),
});
return data;
});
}
}
exports.default = SessionsResource;