summaryrefslogtreecommitdiff
path: root/deps/npm/lib/adduser.js
blob: b6d08ed760f335e6e233d6c86c33fd113e355324 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50

module.exports = adduser

var registry = require("./utils/npm-registry-client/index.js")
  , ini = require("./utils/ini.js")
  , log = require("./utils/log.js")
  , npm = require("./npm.js")
  , prompt = require("./utils/prompt.js")
  , promiseChain = require("./utils/promise-chain.js")
  , crypto

try {
  crypto = process.binding("crypto") && require("crypto")
} catch (ex) {}

adduser.usage = "npm adduser\nThen enter stuff at the prompts"

function adduser (args, cb) {
  if (!crypto) return cb(new Error(
    "You must compile node with ssl support to use the adduser feature"))

  var u = { u : npm.config.get("username")
          , p : npm.config.get("_password")
          , e : npm.config.get("email")
          }
    , changed = false

  promiseChain(cb)
    (prompt, ["Username: ", u.u], function (un) {
      changed = u.u !== un
      u.u = un
    })
    (function (cb) {
      if (u.p && !changed) return cb(null, u.p)
      prompt("Password: ", u.p, true, cb)
    }, [], function (pw) { u.p = pw })
    (prompt, ["Email: ", u.e], function (em) { u.e = em })
    (function (cb) {
      if (changed) npm.config.del("_auth")
      registry.adduser(u.u, u.p, u.e, function (er) {
        if (er) return cb(er)
        ini.set("username", u.u, "user")
        ini.set("_password", u.p, "user")
        ini.set("email", u.e, "user")
        log("Authorized user " + u.u, "adduser")
        ini.save("user", cb)
      })
    })
    ()
}