HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/quadcode.com/node_modules/@pm2/js-api/src/auth_strategies/standalone_strategy.js
'use strict'

const AuthStrategy = require('./strategy')

module.exports = class StandaloneFlow extends AuthStrategy {
  retrieveTokens (km, cb) {
    if (this._opts.refresh_token && this._opts.access_token) {
      // if both access and refresh tokens are provided, we are good
      return cb(null, {
        access_token: this._opts.access_token,
        refresh_token: this._opts.refresh_token
      })
    } else if (this._opts.refresh_token && this._opts.client_id) {
      // we can also make a request to get an access token
      km.auth.retrieveToken({
        client_id: this._opts.client_id,
        refresh_token: this._opts.refresh_token
      }).then((res) => {
        let tokens = res.data
        return cb(null, tokens)
      }).catch(cb)
    } else {
      // otherwise the flow isn't used correctly
      throw new Error(`If you want to use the standalone flow you need to provide either 
        a refresh and access token OR a refresh token and a client id`)
    }
  }

  deleteTokens (km) {
    return km.auth.revoke
  }
}