Skip to content
Snippets Groups Projects
onDeleteAccount.js 3.15 KiB
Newer Older
  • Learn to ignore specific revisions
  • // @ts-check
    const { log, errors } = require('cozy-konnector-libs')
    
    const {
      getAccountRev,
      getAccountSecret,
      getAccountId,
    } = require('./helpers/account')
    
    const { getBoConsent, deleteBoConsent } = require('./requests/bo')
    const { terminateContract } = require('./core/contractTermination')
    
    const { getAccountForDelete } = require('./requests/cozy')
    
    const moment = require('moment')
    require('moment-timezone')
    
    const { isLocal, isDev } = require('./helpers/env')
    
    Bastien DUMONT's avatar
    Bastien DUMONT committed
    const Sentry = require('@sentry/node')
    
    Bastien DUMONT's avatar
    Bastien DUMONT committed
    moment.locale('fr') // set the language
    moment.tz.setDefault('Europe/Paris') // set the timezone
    
    
    Bastien DUMONT's avatar
    Bastien DUMONT committed
      try {
        log('info', 'Deleting account ...')
        log('info', 'Getting secrets ...')
        const ACCOUNT_ID = getAccountId()
        const accountRev = getAccountRev()
    
    Bastien DUMONT's avatar
    Bastien DUMONT committed
        if (accountRev) {
          log('info', 'Account rev exist')
          const accountData = await getAccountForDelete(ACCOUNT_ID, accountRev)
          // Parse local info for deletion test
          if (isLocal()) {
            log('warn', 'Local run')
            const fields = JSON.parse(
              process.env.COZY_FIELDS ? process.env.COZY_FIELDS : '{}'
            )
            process.env.COZY_FIELDS = JSON.stringify({
              ...fields,
              ...accountData.auth,
            })
          }
          const secrets = getAccountSecret()
    
    Bastien DUMONT's avatar
    Bastien DUMONT committed
          const userConsent = await getBoConsent(
            secrets.boBaseUrl,
            secrets.boToken,
            accountData.data.consentId
          )
    
    Bastien DUMONT's avatar
    Bastien DUMONT committed
          log('info', `isAlpha: ${isDev()}`)
          log('info', `userConsent: ${JSON.stringify(userConsent)}`)
          if (userConsent.ID && userConsent.pointID) {
            log('log', `Consent ${userConsent.ID} found for user`)
            if (userConsent.serviceID) {
              await deleteBoConsent(
                secrets.boBaseUrl,
                secrets.boToken,
                userConsent.ID
    
    Bastien DUMONT's avatar
    Bastien DUMONT committed
              // Verify if it's dev env to prevent delete of real data
              if (!isDev()) {
                await terminateContract(
                  secrets.wso2BaseUrl,
                  secrets.apiToken,
                  secrets.sgeLogin,
                  secrets.contractId,
                  userConsent.pointID,
                  userConsent.serviceID
                )
              }
            } else {
              const errorMessage = `No service id retrieved from BO`
              log('error', errorMessage)
              Sentry.captureException(errorMessage)
              throw errors.VENDOR_DOWN
    
    Bastien DUMONT's avatar
    Bastien DUMONT committed
          log('info', 'Deleting account succeed')
        } else {
          const errorMessage =
            'No account revision was found, something went wrong during the deletion of said account'
          log('error', errorMessage)
          Sentry.captureException(errorMessage)
          throw errors.VENDOR_DOWN
        }
      } catch (error) {
        log('debug', 'error catched in onDeleteAccount()', error)
        await Sentry.flush()
        throw error
    
      }
    }
    
    onDeleteAccount().then(
      () => {
        log('info', `onDeleteAccount: Successfully delete consent and account.`)
      },
      err => {
    
    Bastien DUMONT's avatar
    Bastien DUMONT committed
        const errorMessage = `onDeleteAccount: An error occurred during script: ${err.message}`
        log('error', errorMessage)
        Sentry.captureException(errorMessage)
    
        throw errors.VENDOR_DOWN
      }
    )
    
    module.exports = { onDeleteAccount }