'use strict' const request = require("request"); const constants = require('../utils/consts'); const db = require('../utils/db_config'); const crypto = require('crypto'); const { getCurrentDateTime } = require("./helper"); function generateHMACSHA256(input, key) { const hmac = crypto.createHmac('sha256', key); hmac.update(input, 'utf8'); // Ensure input encoding matches C# (UTF-8) return hmac.digest('hex'); } let arrayGetList = ["2509295", "2509", "2820644", "437290"] function getHashCode(req) { // console.log(`368907||${getCurrentDateTime()}`, "DKDDODKOODDOK"); const inputString_GetInvestorDashboard = `${req}||${getCurrentDateTime()}`; const key = "27E6A91CEE689"; const hash_GetInvestorDashboard = generateHMACSHA256(inputString_GetInvestorDashboard, key); return hash_GetInvestorDashboard } const createLiquiloanInvestor = () => { for (let i = 0; i < arrayGetList.length; i++) { var options = { method: 'POST', url: 'https://supply-integration.liquiloans.com/api/v2/GetInvestmentSummary', headers: { 'Content-Type': 'application/json', 'Cookie': 'AWSALB=9yK+sr19KPz9dgL+OcWl2hZ9MOhLlvF9PtNolmRnkviHh01CvjlIWH44NtfjIziyJFwnhrn3+JNhztFLJis+Ijq971nXr5QQVJBxId1uvjZyqKSl/6oFuidGkloW; AWSALBCORS=9yK+sr19KPz9dgL+OcWl2hZ9MOhLlvF9PtNolmRnkviHh01CvjlIWH44NtfjIziyJFwnhrn3+JNhztFLJis+Ijq971nXr5QQVJBxId1uvjZyqKSl/6oFuidGkloW' }, body: JSON.stringify({ "investor_id": arrayGetList[i], "timestamp": getCurrentDateTime(), "checksum": getHashCode(arrayGetList[i]), "mid": "M00201" }) }; request(options, function (error, response) { if (error) throw new Error(error); getUrlAndStore(response.body) }); } } const getUrlAndStore = async (body) => { try { const data = JSON.parse(body) // console.log(data, "111111111111111111111111111111111111111111"); let callsData = data; let calls = []; // if (callsData.length) { console.log(callsData.data.past_investments, "LDPDPLDPLDPLLPDPDLDLPDPLDPL"); for (let i = 0; i < callsData.length; i++) { let record = {}; // record.sid = callsData[i].Sid; // record.date_created = callsData[i].DateCreated; // record.date_updated = callsData[i].DateUpdated; // record.account_sid = callsData[i].AccountSid; // record.to = callsData[i].To; // record.from = callsData[i].From; // record.phone_number = callsData[i].PhoneNumber; // record.phone_number_sid = callsData[i].PhoneNumberSid; // record.status = callsData[i].Status; // record.start_time = callsData[i].StartTime; // record.end_time = callsData[i].EndTime; // record.duration = callsData[i].Duration; // record.price = callsData[i].Price; // record.direction = callsData[i].Direction; // record.recording_url = callsData[i].RecordingUrl; // record.conversation_duration = callsData[i].Details.ConversationDuration; // record.leg1_status = callsData[i].Details.Leg1Status; // record.leg2_status = callsData[i].Details.Leg2Status; // record.created_at = new Date(); // calls.push(record); // console.log('calls---->', calls.length); // await db.exotelCalls.bulkCreate(calls); } } catch (err) { console.log(err); winstonLogger.error('getUrlAndStore() error is : ' + err); } } module.exports = { createLiquiloanInvestor }