Hacked By AnonymousFox

Current Path : /opt/alt/alt-nodejs16/root/lib/node_modules/npm/lib/commands/
Upload File :
Current File : //opt/alt/alt-nodejs16/root/lib/node_modules/npm/lib/commands/adduser.js

const log = require('../utils/log-shim.js')
const replaceInfo = require('../utils/replace-info.js')
const BaseCommand = require('../base-command.js')
const authTypes = {
  legacy: require('../auth/legacy.js'),
  web: require('../auth/legacy.js'),
  webauthn: require('../auth/legacy.js'),
  oauth: require('../auth/oauth.js'),
  saml: require('../auth/saml.js'),
  sso: require('../auth/sso.js'),
}

class AddUser extends BaseCommand {
  static description = 'Add a registry user account'
  static name = 'adduser'
  static params = [
    'registry',
    'scope',
    'auth-type',
  ]

  static ignoreImplicitWorkspace = true

  async exec (args) {
    const { scope } = this.npm.flatOptions
    const registry = this.getRegistry(this.npm.flatOptions)
    const auth = this.getAuthType(this.npm.flatOptions)
    const creds = this.npm.config.getCredentialsByURI(registry)

    log.disableProgress()

    log.warn('adduser',
      '`adduser` will be split into `login` and `register` in a future version.'
      + ' `adduser` will become an alias of `register`.'
      + ' `login` (currently an alias) will become its own command.')
    log.notice('', `Log in on ${replaceInfo(registry)}`)

    const { message, newCreds } = await auth(this.npm, {
      ...this.npm.flatOptions,
      creds,
      registry,
      scope,
    })

    await this.updateConfig({
      newCreds,
      registry,
      scope,
    })

    this.npm.output(message)
  }

  getRegistry ({ scope, registry }) {
    if (scope) {
      const scopedRegistry = this.npm.config.get(`${scope}:registry`)
      const cliRegistry = this.npm.config.get('registry', 'cli')
      if (scopedRegistry && !cliRegistry) {
        return scopedRegistry
      }
    }
    return registry
  }

  getAuthType ({ authType }) {
    const type = authTypes[authType]

    if (!type) {
      throw new Error('no such auth module')
    }

    return type
  }

  async updateConfig ({ newCreds, registry, scope }) {
    this.npm.config.delete('_token', 'user') // prevent legacy pollution
    this.npm.config.setCredentialsByURI(registry, newCreds)
    if (scope) {
      this.npm.config.set(scope + ':registry', registry, 'user')
    }
    await this.npm.config.save('user')
  }
}
module.exports = AddUser

Hacked By AnonymousFox1.0, Coded By AnonymousFox