hrms-api-kpi/src/interfaces/call-api.ts

97 lines
2.4 KiB
TypeScript
Raw Normal View History

2024-04-19 09:44:46 +07:00
import {
Controller,
Request,
Get,
Post,
Put,
Delete,
Patch,
Route,
Security,
Tags,
Path,
} from "tsoa";
import axios from "axios";
2024-08-22 14:23:50 +07:00
import { addLogSequence } from "./utils";
2024-04-19 09:44:46 +07:00
class CallAPI {
//Get
2024-10-25 17:00:48 +07:00
public async GetData(request: any, @Path() path: any, log = true) {
2024-09-30 09:46:01 +07:00
const token = "Bearer " + request.headers.authorization.replace("Bearer ", "");
2024-07-09 17:03:35 +07:00
const url = process.env.API_URL + path;
2024-04-19 09:44:46 +07:00
try {
const response = await axios.get(url, {
headers: {
Authorization: `${token}`,
"Content-Type": "application/json",
2024-08-15 13:28:28 +07:00
api_key: process.env.API_KEY,
2024-04-19 09:44:46 +07:00
},
});
2024-10-25 17:00:48 +07:00
if(log) addLogSequence(request, {
2024-08-22 14:23:50 +07:00
action: "request",
status: "success",
description: "connected",
request: {
method: "GET",
url: url,
response: JSON.stringify(response.data.result),
},
});
2024-04-19 09:44:46 +07:00
return response.data.result;
} catch (error) {
2024-10-25 17:00:48 +07:00
if(log) addLogSequence(request, {
2024-08-22 14:23:50 +07:00
action: "request",
status: "error",
description: "unconnected",
request: {
method: "GET",
url: url,
response: JSON.stringify(error),
},
});
2024-04-19 09:44:46 +07:00
throw error;
}
}
//Post
public async PostData(request: any, @Path() path: any, sendData: any) {
2024-09-30 09:46:01 +07:00
const token = "Bearer " + request.headers.authorization.replace("Bearer ", "");
2024-07-09 17:03:35 +07:00
const url = process.env.API_URL + path;
2024-04-19 09:44:46 +07:00
try {
const response = await axios.post(url, sendData, {
headers: {
Authorization: `${token}`,
"Content-Type": "application/json",
2024-08-15 13:28:28 +07:00
api_key: process.env.API_KEY,
2024-04-19 09:44:46 +07:00
},
});
2024-08-22 14:23:50 +07:00
addLogSequence(request, {
action: "request",
status: "success",
description: "connected",
request: {
method: "POST",
url: url,
payload: JSON.stringify(sendData),
response: JSON.stringify(response.data.result),
},
});
2024-04-19 09:44:46 +07:00
return response.data.result;
} catch (error) {
2024-08-22 14:23:50 +07:00
addLogSequence(request, {
action: "request",
status: "error",
description: "unconnected",
request: {
method: "POST",
url: url,
payload: JSON.stringify(sendData),
response: JSON.stringify(error),
},
});
2024-04-19 09:44:46 +07:00
throw error;
}
}
}
export default CallAPI;