-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
96 lines (90 loc) · 1.67 KB
/
index.js
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
const axios = require("axios");
const {getForbidden} = require("@verdaccio/commons-api");
class AuthCustomPlugin {
constructor(config) {
this.url = config.url;
this.secret = config.secret;
return this;
}
authenticate(username, password, cb) {
axios
.post(
`${this.url}/authenticate`,
{
username,
password
},
{
headers: {
authorization: this.secret
}
}
)
.then(res => cb(null, res.data))
.catch(() => cb(null, false));
}
allow_access(user, pkg, cb) {
axios
.post(
`${this.url}/allow_access`,
{
user,
package: pkg
},
{
headers: {
authorization: this.secret
}
}
)
.then(res =>
res.data
? cb(null, true)
: cb(getForbidden("not allowed to access package"))
)
.catch(() => cb(getForbidden("not allowed to access package")));
}
allow_publish(user, pkg, cb) {
axios
.post(
`${this.url}/allow_publish`,
{
user,
package: pkg
},
{
headers: {
authorization: this.secret
}
}
)
.then(res =>
res.data
? cb(null, true)
: cb(getForbidden("not allowed to publish package"))
)
.catch(() => cb(getForbidden("not allowed to publish package")));
}
allow_unpublish(user, pkg, cb) {
axios
.post(
`${this.url}/allow_unpublish`,
{
user,
package: pkg
},
{
headers: {
authorization: this.secret
}
}
)
.then(res =>
res.data
? cb(null, true)
: cb(getForbidden("not allowed to unpublish package"))
)
.catch(() => cb(getForbidden("not allowed to unpublish package")));
}
}
module.exports = config => new AuthCustomPlugin(config);