xero-node
Version:
Xero NodeJS OAuth 2.0 client for xero-node
275 lines • 10.6 kB
JavaScript
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __exportStar = (this && this.__exportStar) || function(m, exports) {
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.VoidAuth = exports.OAuth = exports.ApiKeyAuth = exports.HttpBasicAuth = exports.ObjectSerializer = void 0;
__exportStar(require("././amount"), exports);
__exportStar(require("././chargeType"), exports);
__exportStar(require("././currencyCode"), exports);
__exportStar(require("././modelError"), exports);
__exportStar(require("././pagination"), exports);
__exportStar(require("././project"), exports);
__exportStar(require("././projectCreateOrUpdate"), exports);
__exportStar(require("././projectPatch"), exports);
__exportStar(require("././projectStatus"), exports);
__exportStar(require("././projectUser"), exports);
__exportStar(require("././projectUsers"), exports);
__exportStar(require("././projects"), exports);
__exportStar(require("././task"), exports);
__exportStar(require("././taskCreateOrUpdate"), exports);
__exportStar(require("././tasks"), exports);
__exportStar(require("././timeEntries"), exports);
__exportStar(require("././timeEntry"), exports);
__exportStar(require("././timeEntryCreateOrUpdate"), exports);
const amount_1 = require("././amount");
const chargeType_1 = require("././chargeType");
const currencyCode_1 = require("././currencyCode");
const modelError_1 = require("././modelError");
const pagination_1 = require("././pagination");
const project_1 = require("././project");
const projectCreateOrUpdate_1 = require("././projectCreateOrUpdate");
const projectPatch_1 = require("././projectPatch");
const projectStatus_1 = require("././projectStatus");
const projectUser_1 = require("././projectUser");
const projectUsers_1 = require("././projectUsers");
const projects_1 = require("././projects");
const task_1 = require("././task");
const taskCreateOrUpdate_1 = require("././taskCreateOrUpdate");
const tasks_1 = require("././tasks");
const timeEntries_1 = require("././timeEntries");
const timeEntry_1 = require("././timeEntry");
const timeEntryCreateOrUpdate_1 = require("././timeEntryCreateOrUpdate");
/* tslint:disable:no-unused-variable */
let primitives = [
"string",
"boolean",
"double",
"integer",
"long",
"float",
"number",
"any"
];
let enumsMap = {
"ChargeType": chargeType_1.ChargeType,
"CurrencyCode": currencyCode_1.CurrencyCode,
"ProjectStatus": projectStatus_1.ProjectStatus,
"Task.StatusEnum": task_1.Task.StatusEnum,
"TimeEntry.StatusEnum": timeEntry_1.TimeEntry.StatusEnum,
};
let typeMap = {
"Amount": amount_1.Amount,
"ModelError": modelError_1.ModelError,
"Pagination": pagination_1.Pagination,
"Project": project_1.Project,
"ProjectCreateOrUpdate": projectCreateOrUpdate_1.ProjectCreateOrUpdate,
"ProjectPatch": projectPatch_1.ProjectPatch,
"ProjectUser": projectUser_1.ProjectUser,
"ProjectUsers": projectUsers_1.ProjectUsers,
"Projects": projects_1.Projects,
"Task": task_1.Task,
"TaskCreateOrUpdate": taskCreateOrUpdate_1.TaskCreateOrUpdate,
"Tasks": tasks_1.Tasks,
"TimeEntries": timeEntries_1.TimeEntries,
"TimeEntry": timeEntry_1.TimeEntry,
"TimeEntryCreateOrUpdate": timeEntryCreateOrUpdate_1.TimeEntryCreateOrUpdate,
};
class ObjectSerializer {
static findCorrectType(data, expectedType) {
if (data == undefined) {
return expectedType;
}
else if (primitives.indexOf(expectedType.toLowerCase()) !== -1) {
return expectedType;
}
else if (expectedType === "Date") {
return expectedType;
}
else {
if (enumsMap[expectedType]) {
return expectedType;
}
if (!typeMap[expectedType]) {
return expectedType; // w/e we don't know the type
}
// Check the discriminator
let discriminatorProperty = typeMap[expectedType].discriminator;
if (discriminatorProperty == null) {
return expectedType; // the type does not have a discriminator. use it.
}
else {
if (data[discriminatorProperty]) {
var discriminatorType = data[discriminatorProperty];
if (typeMap[discriminatorType]) {
return discriminatorType; // use the type given in the discriminator
}
else {
return expectedType; // discriminator did not map to a type
}
}
else {
return expectedType; // discriminator was not present (or an empty string)
}
}
}
}
static serialize(data, type) {
if (data == undefined) {
return data;
}
else if (primitives.indexOf(type.toLowerCase()) !== -1) {
return data;
}
else if (type.lastIndexOf("Array<", 0) === 0) { // string.startsWith pre es6
let subType = type.replace("Array<", ""); // Array<Type> => Type>
subType = subType.substring(0, subType.length - 1); // Type> => Type
let transformedData = [];
for (let [index, date] of Object.entries(data)) {
transformedData.push(ObjectSerializer.serialize(date, subType));
}
if (subType === 'string') {
return transformedData.join(',');
}
else {
return transformedData;
}
}
else if (type === "Date") {
return data.toISOString();
}
else {
if (enumsMap[type]) {
return data;
}
if (!typeMap[type]) { // in case we dont know the type
return data;
}
// Get the actual type of this object
type = this.findCorrectType(data, type);
// get the map for the correct type.
let attributeTypes = typeMap[type].getAttributeTypeMap();
let instance = {};
for (let [index, attributeType] of Object.entries(attributeTypes)) {
instance[attributeType['baseName']] = ObjectSerializer.serialize(data[attributeType['name']], attributeType['type']);
}
return instance;
}
}
static deserializeDateFormats(type, data) {
const isDate = new Date(data);
if (isNaN(isDate.getTime())) {
const re = /-?\d+/;
const m = re.exec(data);
return new Date(parseInt(m[0], 10));
}
else {
return isDate;
}
}
static deserialize(data, type) {
// polymorphism may change the actual type.
type = ObjectSerializer.findCorrectType(data, type);
if (data == undefined) {
return data;
}
else if (primitives.indexOf(type.toLowerCase()) !== -1) {
if (type === "string" && data.toString().substring(0, 6) === "/Date(") {
return this.deserializeDateFormats(type, data); // For MS dates that are of type 'string'
}
else {
return data;
}
}
else if (type.lastIndexOf("Array<", 0) === 0) { // string.startsWith pre es6
let subType = type.replace("Array<", ""); // Array<Type> => Type>
subType = subType.substring(0, subType.length - 1); // Type> => Type
let transformedData = [];
// Asset API returns string even for Array<Model>
const dataFormatted = typeof data == 'string' ? JSON.parse(data) : data;
for (let [index, currentData] of Object.entries(dataFormatted)) {
transformedData.push(ObjectSerializer.deserialize(currentData, subType));
}
return transformedData;
}
else if (type === "Date") {
return this.deserializeDateFormats(type, data);
}
else {
if (enumsMap[type]) { // is Enum
return data;
}
if (!typeMap[type]) { // dont know the type
return data;
}
let instance = new typeMap[type]();
let attributeTypes = typeMap[type].getAttributeTypeMap();
for (let [index, attributeType] of Object.entries(attributeTypes)) {
instance[attributeType['name']] = ObjectSerializer.deserialize(data[attributeType['baseName']], attributeType['type']);
}
return instance;
}
}
}
exports.ObjectSerializer = ObjectSerializer;
class HttpBasicAuth {
constructor() {
this.username = '';
this.password = '';
}
applyToRequest(requestOptions) {
requestOptions.auth = {
username: this.username, password: this.password
};
}
}
exports.HttpBasicAuth = HttpBasicAuth;
class ApiKeyAuth {
constructor(location, paramName) {
this.location = location;
this.paramName = paramName;
this.apiKey = '';
}
applyToRequest(requestOptions) {
if (this.location == "query") {
requestOptions.params[this.paramName] = this.apiKey;
}
else if (this.location == "header" && requestOptions && requestOptions.headers) {
requestOptions.headers[this.paramName] = this.apiKey;
}
}
}
exports.ApiKeyAuth = ApiKeyAuth;
class OAuth {
constructor() {
this.accessToken = '';
}
applyToRequest(requestOptions) {
if (requestOptions && requestOptions.headers) {
requestOptions.headers["Authorization"] = "Bearer " + this.accessToken;
}
}
}
exports.OAuth = OAuth;
class VoidAuth {
constructor() {
this.username = '';
this.password = '';
}
applyToRequest(_) {
// Do nothing
}
}
exports.VoidAuth = VoidAuth;
//# sourceMappingURL=models.js.map