Skip to content

Commit

Permalink
NetSuite: Update startTime and endTime with updateCallLog
Browse files Browse the repository at this point in the history
  • Loading branch information
SushilMallRC committed Nov 27, 2024
1 parent e5f18ea commit 75d59d6
Show file tree
Hide file tree
Showing 8 changed files with 52 additions and 17 deletions.
4 changes: 2 additions & 2 deletions src/adapters/bullhorn/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ async function tempMigrateUserId({ existingUser }) {
}
}
const newUserId = userInfoResponse.data.data[0]?.masterUserID;
if(!!!newUserId){
if (!!!newUserId) {
return null;
}
const newUser = await UserModel.create({
Expand Down Expand Up @@ -341,7 +341,7 @@ async function createCallLog({ user, contactInfo, authHeader, callLog, note, add
};
}

async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note }) {
async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note, incomingData }) {
const existingBullhornLogId = existingCallLog.thirdPartyLogId;
let getLogRes
try {
Expand Down
2 changes: 1 addition & 1 deletion src/adapters/clio/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -244,7 +244,7 @@ async function createCallLog({ user, contactInfo, authHeader, callLog, note, add
};
}

async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note }) {
async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note, incomingData }) {
const existingClioLogId = existingCallLog.thirdPartyLogId.split('.')[0];
const getLogRes = await axios.get(
`https://${user.hostname}/api/v4/communications/${existingClioLogId}.json?fields=body`,
Expand Down
2 changes: 1 addition & 1 deletion src/adapters/insightly/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -344,7 +344,7 @@ async function createCallLog({ user, contactInfo, authHeader, callLog, note, add
};
}

async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note }) {
async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note, incomingData }) {
const existingInsightlyLogId = existingCallLog.thirdPartyLogId;
const urlDecodedRecordingLink = decodeURIComponent(recordingLink);
const getLogRes = await axios.get(
Expand Down
43 changes: 40 additions & 3 deletions src/adapters/netsuite/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -280,7 +280,7 @@ async function createCallLog({ user, contactInfo, authHeader, callLog, note, add
} catch (error) {
console.log({ message: "Error in getting timezone" });
}
const callEndTime = moment(callStartTime).add(callLog.duration, 'seconds');
const callEndTime = (callLog.duration === 'pending') ? moment(callStartTime) : moment(callStartTime).add(callLog.duration, 'seconds');
const formatedStartTime = callStartTime.format('YYYY-MM-DD HH:mm:ss');
const formatedEndTime = callEndTime.format('YYYY-MM-DD HH:mm:ss');
let endTimeSlot = callEndTime.format('HH:mm');
Expand Down Expand Up @@ -308,7 +308,6 @@ async function createCallLog({ user, contactInfo, authHeader, callLog, note, add
} else if (contactInfo.type === 'custjob') {
postBody.company = { id: contactInfo.id };
}

const addLogRes = await axios.post(
`https://${user.hostname.split(".")[0]}.suitetalk.api.netsuite.com/services/rest/record/v1/phonecall`,
postBody,
Expand Down Expand Up @@ -392,12 +391,50 @@ async function getCallLog({ user, callLogId, authHeader }) {

}

async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note }) {
async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note, incomingData }) {
try {
const existingLogId = existingCallLog.thirdPartyLogId;
const callLogResponse = await axios.get(`https://${user.hostname.split(".")[0]}.suitetalk.api.netsuite.com/services/rest/record/v1/phonecall/${existingLogId}`, { headers: { 'Authorization': authHeader } });
let messageBody = callLogResponse.data.message;
let patchBody = { title: subject };
if (incomingData?.startTime !== undefined && incomingData?.duration !== undefined) {
let callStartTime = moment(moment(incomingData.startTime).toISOString());
let startTimeSLot = moment(incomingData.startTime).format('HH:mm');
try {
const getTimeZoneUrl = `https://${user.hostname.split(".")[0]}.restlets.api.netsuite.com/app/site/hosting/restlet.nl?script=customscript_gettimezone&deploy=customdeploy_gettimezone`;
const timeZoneResponse = await axios.get(getTimeZoneUrl, {
headers: { 'Authorization': authHeader }
});
const timeZone = timeZoneResponse?.data?.userTimezone;
callStartTime = moment(moment(incomingData.startTime).toISOString()).tz(timeZone);
startTimeSLot = callStartTime.format('HH:mm');

} catch (error) {
console.log({ message: "Error in getting timezone in updateCallLog" });
}
const callEndTime = moment(callStartTime).add(incomingData.duration, 'seconds');
const formatedStartTime = callStartTime.format('YYYY-MM-DD HH:mm:ss');
const formatedEndTime = callEndTime.format('YYYY-MM-DD HH:mm:ss');
let endTimeSlot = callEndTime.format('HH:mm');
if (startTimeSLot === endTimeSlot) {
//If Start Time and End Time are same, then add 1 minute to End Time because endTime can not be less or equal to startTime
endTimeSlot = callEndTime.add(1, 'minutes').format('HH:mm');
}
patchBody.startDate = callStartTime;
patchBody.startTime = startTimeSLot;
patchBody.endTime = endTimeSlot;
const contactNumberMatch = messageBody.match(/Contact Number: (\+?\d+)/);
let phoneNumber;
if (contactNumberMatch) {
phoneNumber = contactNumberMatch[1];
}
let callRecordingLink;
const recordingLinkMatch = messageBody.match(/Call recording link: (\S+)/);
if (recordingLinkMatch) {
callRecordingLink = recordingLinkMatch[1];
}
messageBody = `\nCall Start Time: ${formatedStartTime}\n Duration In Second: ${incomingData.duration}Sec.\n Call End Time : ${formatedEndTime}\nContact Number: ${phoneNumber}\nNote: ${note}${callRecordingLink ? `\nCall recording link ${callRecordingLink}` : ''}\n\n--- Created via RingCentral CRM Extension`;
}
if (!!recordingLink) {
const urlDecodedRecordingLink = decodeURIComponent(recordingLink);
if (messageBody.includes('\n\n--- Created via RingCentral CRM Extension')) {
Expand Down
2 changes: 1 addition & 1 deletion src/adapters/pipedrive/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -203,7 +203,7 @@ async function createCallLog({ user, contactInfo, authHeader, callLog, note, add
};
}

async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note }) {
async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note, incomingData }) {
const existingPipedriveLogId = existingCallLog.thirdPartyLogId;
const getLogRes = await axios.get(
`https://${user.hostname}/v1/activities/${existingPipedriveLogId}`,
Expand Down
2 changes: 1 addition & 1 deletion src/adapters/redtail/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,7 @@ async function createCallLog({ user, contactInfo, callLog, note }) {
};
}

async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note }) {
async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note, incomingData }) {
const overrideAuthHeader = getAuthHeader({ userKey: user.platformAdditionalInfo.userResponse.user_key });
const existingRedtailLogId = existingCallLog.thirdPartyLogId;
const getLogRes = await axios.get(
Expand Down
7 changes: 3 additions & 4 deletions src/adapters/testCRM/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -151,11 +151,10 @@ async function findContact({ user, authHeader, phoneNumber, overridingFormat, is
console.log(`phone number: ${phoneNumber}`)
console.log(`is extesnion number? ${isExtension}`)
const numberToQueryArray = [];
if(isExtension)
{
if (isExtension) {
numberToQueryArray.push(phoneNumber);
}
else{
else {
numberToQueryArray.push(phoneNumber.replace(' ', '+'));
}
// You can use parsePhoneNumber functions to further parse the phone number
Expand Down Expand Up @@ -286,7 +285,7 @@ async function getCallLog({ user, callLogId, authHeader }) {
// - note: note submitted by user
// - subject: subject submitted by user
// - recordingLink: recordingLink updated from RingCentral. It's separated from createCallLog because recordings are not generated right after a call. It needs to be updated into existing call log
async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note }) {
async function updateCallLog({ user, existingCallLog, authHeader, recordingLink, subject, note, incomingData }) {
// ---------------------------------------
// ---TODO.6: Implement call log update---
// ---------------------------------------
Expand Down
7 changes: 3 additions & 4 deletions src/core/log.js
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,7 @@ async function updateCallLog({ platform, userId, incomingData }) {
authHeader = `Basic ${basicAuth}`;
break;
}
const { updatedNote, returnMessage } = await platformModule.updateCallLog({ user, existingCallLog, authHeader, recordingLink: incomingData.recordingLink, subject: incomingData.subject, note: incomingData.note });
const { updatedNote, returnMessage } = await platformModule.updateCallLog({ user, existingCallLog, authHeader, recordingLink: incomingData.recordingLink, subject: incomingData.subject, note: incomingData.note, incomingData });
return { successful: true, logId: existingCallLog.thirdPartyLogId, updatedNote, returnMessage };
}
return { successful: false };
Expand All @@ -188,11 +188,10 @@ async function updateCallLog({ platform, userId, incomingData }) {
if (e.response?.status === 429) {
return { successful: false, returnMessage: { message: `${platform} rate limit reached. Please try again the next minute.`, messageType: 'warning', ttl: 5000 } };
}
if(!!incomingData.recordingLink)
{
if (!!incomingData.recordingLink) {
return { successful: false, returnMessage: { message: `Failed to upload call recording link.`, messageType: 'warning', ttl: 5000 } };
}
else{
else {
return { successful: false, returnMessage: { message: `Failed to update call log. Please check if the log entity still exist on ${platform}`, messageType: 'warning', ttl: 5000 } };
}
}
Expand Down

0 comments on commit 75d59d6

Please sign in to comment.