front/modules/tax/avalaramodule.js

/* ============================================================================ *\
|| ########################################################################## ||
|| # Auction Software Marketplace          Release: 0.6   Build 0.7         # ||
|| # ---------------------------------------------------------------------- # ||
|| # License # 35YAHCNR9344X6O666C123AB                                     # ||
|| # ---------------------------------------------------------------------- # ||
|| # Copyright ©2014–2021 Develop Scripts LLC. All Rights Reserved          # ||
|| # This file may not be redistributed in whole or significant part.       # ||
|| # ------------- AUCTION SOFTWARE IS NOT FREE SOFTWARE ------------------ # ||
|| # http://www.auctionsoftwaremarketplace.com|support@auctionsoftware.com  # ||
|| # ---------------------------------------------------------------------- # ||
|| ########################################################################## ||
\* ============================================================================ */

const dateFormat = require('dateformat')
const md5 = require('md5')
const _ = require('underscore')

const mysqclass = require('../mysqli').default
/**
 * @class class to handle deposit functions
 */
class avalaraTaxModule {
    /**
     * insert log
     *
     * @param {string} nameID email ID to check in the database.
     * @returns {object} sql response
     */
    static async insertLog(data, options, type) {
        const mysql = {}
        const escapeData = [
            data.user_id,
            data.project_id,
            type,
            JSON.stringify(options.data),
            dateFormat(new Date(), 'yyyy-mm-dd HH:MM:ss'),
        ]
        const strQuery = await mysqclass.mysqli(mysql, 'avalara_log_insert')
        const dataReturn = await global.mysql.query(strQuery, escapeData)
        return dataReturn
    }
    /**
     * update log
     *
     * @param {string} data log data
     * @returns {object} sql response
     */
    static async updateLog(data) {
        const mysql = {}
        const escapeData = [
            JSON.stringify(data.response),
            data.status,
            dateFormat(new Date(), 'yyyy-mm-dd HH:MM:ss'),
            data.id,
        ]
        const strQuery = await mysqclass.mysqli(mysql, 'avalara_log_update')
        const dataReturn = await global.mysql.query(strQuery, escapeData)
        return dataReturn
    }
}

module.exports.default = avalaraTaxModule