1 | ;
|
2 |
|
3 | var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
|
4 |
|
5 | var _Requestable2 = require('./Requestable');
|
6 |
|
7 | var _Requestable3 = _interopRequireDefault(_Requestable2);
|
8 |
|
9 | var _debug = require('debug');
|
10 |
|
11 | var _debug2 = _interopRequireDefault(_debug);
|
12 |
|
13 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
14 |
|
15 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
16 |
|
17 | function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
|
18 |
|
19 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /**
|
20 | * @file
|
21 | * @copyright 2016 Matt Smith (Development Seed)
|
22 | * @license Licensed under {@link https://spdx.org/licenses/BSD-3-Clause-Clear.html BSD-3-Clause-Clear}.
|
23 | * Github.js is freely distributable.
|
24 | */
|
25 |
|
26 | var log = (0, _debug2.default)('github:team');
|
27 |
|
28 | /**
|
29 | * A Team allows scoping of API requests to a particular Github Organization Team.
|
30 | */
|
31 |
|
32 | var Team = function (_Requestable) {
|
33 | _inherits(Team, _Requestable);
|
34 |
|
35 | /**
|
36 | * Create a Team.
|
37 | * @param {string} [teamId] - the id for the team
|
38 | * @param {Requestable.auth} [auth] - information required to authenticate to Github
|
39 | * @param {string} [apiBase=https://api.github.com] - the base Github API URL
|
40 | */
|
41 | function Team(teamId, auth, apiBase) {
|
42 | _classCallCheck(this, Team);
|
43 |
|
44 | var _this = _possibleConstructorReturn(this, (Team.__proto__ || Object.getPrototypeOf(Team)).call(this, auth, apiBase));
|
45 |
|
46 | _this.__teamId = teamId;
|
47 | return _this;
|
48 | }
|
49 |
|
50 | /**
|
51 | * Get Team information
|
52 | * @see https://developer.github.com/v3/orgs/teams/#get-team
|
53 | * @param {Requestable.callback} [cb] - will receive the team
|
54 | * @return {Promise} - the promise for the http request
|
55 | */
|
56 |
|
57 |
|
58 | _createClass(Team, [{
|
59 | key: 'getTeam',
|
60 | value: function getTeam(cb) {
|
61 | log('Fetching Team ' + this.__teamId);
|
62 | return this._request('Get', '/teams/' + this.__teamId, undefined, cb);
|
63 | }
|
64 |
|
65 | /**
|
66 | * List the Team's repositories
|
67 | * @see https://developer.github.com/v3/orgs/teams/#list-team-repos
|
68 | * @param {Requestable.callback} [cb] - will receive the list of repositories
|
69 | * @return {Promise} - the promise for the http request
|
70 | */
|
71 |
|
72 | }, {
|
73 | key: 'listRepos',
|
74 | value: function listRepos(cb) {
|
75 | log('Fetching repositories for Team ' + this.__teamId);
|
76 | return this._requestAllPages('/teams/' + this.__teamId + '/repos', undefined, cb);
|
77 | }
|
78 |
|
79 | /**
|
80 | * Edit Team information
|
81 | * @see https://developer.github.com/v3/orgs/teams/#edit-team
|
82 | * @param {object} options - Parameters for team edit
|
83 | * @param {string} options.name - The name of the team
|
84 | * @param {string} [options.description] - Team description
|
85 | * @param {string} [options.repo_names] - Repos to add the team to
|
86 | * @param {string} [options.privacy=secret] - The level of privacy the team should have. Can be either one
|
87 | * of: `secret`, or `closed`
|
88 | * @param {Requestable.callback} [cb] - will receive the updated team
|
89 | * @return {Promise} - the promise for the http request
|
90 | */
|
91 |
|
92 | }, {
|
93 | key: 'editTeam',
|
94 | value: function editTeam(options, cb) {
|
95 | log('Editing Team ' + this.__teamId);
|
96 | return this._request('PATCH', '/teams/' + this.__teamId, options, cb);
|
97 | }
|
98 |
|
99 | /**
|
100 | * List the users who are members of the Team
|
101 | * @see https://developer.github.com/v3/orgs/teams/#list-team-members
|
102 | * @param {object} options - Parameters for listing team users
|
103 | * @param {string} [options.role=all] - can be one of: `all`, `maintainer`, or `member`
|
104 | * @param {Requestable.callback} [cb] - will receive the list of users
|
105 | * @return {Promise} - the promise for the http request
|
106 | */
|
107 |
|
108 | }, {
|
109 | key: 'listMembers',
|
110 | value: function listMembers(options, cb) {
|
111 | log('Getting members of Team ' + this.__teamId);
|
112 | return this._requestAllPages('/teams/' + this.__teamId + '/members', options, cb);
|
113 | }
|
114 |
|
115 | /**
|
116 | * Get Team membership status for a user
|
117 | * @see https://developer.github.com/v3/orgs/teams/#get-team-membership
|
118 | * @param {string} username - can be one of: `all`, `maintainer`, or `member`
|
119 | * @param {Requestable.callback} [cb] - will receive the membership status of a user
|
120 | * @return {Promise} - the promise for the http request
|
121 | */
|
122 |
|
123 | }, {
|
124 | key: 'getMembership',
|
125 | value: function getMembership(username, cb) {
|
126 | log('Getting membership of user ' + username + ' in Team ' + this.__teamId);
|
127 | return this._request('GET', '/teams/' + this.__teamId + '/memberships/' + username, undefined, cb);
|
128 | }
|
129 |
|
130 | /**
|
131 | * Add a member to the Team
|
132 | * @see https://developer.github.com/v3/orgs/teams/#add-team-membership
|
133 | * @param {string} username - can be one of: `all`, `maintainer`, or `member`
|
134 | * @param {object} options - Parameters for adding a team member
|
135 | * @param {string} [options.role=member] - The role that this user should have in the team. Can be one
|
136 | * of: `member`, or `maintainer`
|
137 | * @param {Requestable.callback} [cb] - will receive the membership status of added user
|
138 | * @return {Promise} - the promise for the http request
|
139 | */
|
140 |
|
141 | }, {
|
142 | key: 'addMembership',
|
143 | value: function addMembership(username, options, cb) {
|
144 | log('Adding user ' + username + ' to Team ' + this.__teamId);
|
145 | return this._request('PUT', '/teams/' + this.__teamId + '/memberships/' + username, options, cb);
|
146 | }
|
147 |
|
148 | /**
|
149 | * Get repo management status for team
|
150 | * @see https://developer.github.com/v3/orgs/teams/#remove-team-membership
|
151 | * @param {string} owner - Organization name
|
152 | * @param {string} repo - Repo name
|
153 | * @param {Requestable.callback} [cb] - will receive the membership status of added user
|
154 | * @return {Promise} - the promise for the http request
|
155 | */
|
156 |
|
157 | }, {
|
158 | key: 'isManagedRepo',
|
159 | value: function isManagedRepo(owner, repo, cb) {
|
160 | log('Getting repo management by Team ' + this.__teamId + ' for repo ' + owner + '/' + repo);
|
161 | return this._request204or404('/teams/' + this.__teamId + '/repos/' + owner + '/' + repo, undefined, cb);
|
162 | }
|
163 |
|
164 | /**
|
165 | * Add or Update repo management status for team
|
166 | * @see https://developer.github.com/v3/orgs/teams/#add-or-update-team-repository
|
167 | * @param {string} owner - Organization name
|
168 | * @param {string} repo - Repo name
|
169 | * @param {object} options - Parameters for adding or updating repo management for the team
|
170 | * @param {string} [options.permission] - The permission to grant the team on this repository. Can be one
|
171 | * of: `pull`, `push`, or `admin`
|
172 | * @param {Requestable.callback} [cb] - will receive the membership status of added user
|
173 | * @return {Promise} - the promise for the http request
|
174 | */
|
175 |
|
176 | }, {
|
177 | key: 'manageRepo',
|
178 | value: function manageRepo(owner, repo, options, cb) {
|
179 | log('Adding or Updating repo management by Team ' + this.__teamId + ' for repo ' + owner + '/' + repo);
|
180 | return this._request204or404('/teams/' + this.__teamId + '/repos/' + owner + '/' + repo, options, cb, 'PUT');
|
181 | }
|
182 |
|
183 | /**
|
184 | * Remove repo management status for team
|
185 | * @see https://developer.github.com/v3/orgs/teams/#remove-team-repository
|
186 | * @param {string} owner - Organization name
|
187 | * @param {string} repo - Repo name
|
188 | * @param {Requestable.callback} [cb] - will receive the membership status of added user
|
189 | * @return {Promise} - the promise for the http request
|
190 | */
|
191 |
|
192 | }, {
|
193 | key: 'unmanageRepo',
|
194 | value: function unmanageRepo(owner, repo, cb) {
|
195 | log('Remove repo management by Team ' + this.__teamId + ' for repo ' + owner + '/' + repo);
|
196 | return this._request204or404('/teams/' + this.__teamId + '/repos/' + owner + '/' + repo, undefined, cb, 'DELETE');
|
197 | }
|
198 |
|
199 | /**
|
200 | * Delete Team
|
201 | * @see https://developer.github.com/v3/orgs/teams/#delete-team
|
202 | * @param {Requestable.callback} [cb] - will receive the list of repositories
|
203 | * @return {Promise} - the promise for the http request
|
204 | */
|
205 |
|
206 | }, {
|
207 | key: 'deleteTeam',
|
208 | value: function deleteTeam(cb) {
|
209 | log('Deleting Team ' + this.__teamId);
|
210 | return this._request204or404('/teams/' + this.__teamId, undefined, cb, 'DELETE');
|
211 | }
|
212 | }]);
|
213 |
|
214 | return Team;
|
215 | }(_Requestable3.default);
|
216 |
|
217 | module.exports = Team;
|
218 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Team.js"],"names":["log","Team","teamId","auth","apiBase","__teamId","cb","_request","undefined","_requestAllPages","options","username","owner","repo","_request204or404","Requestable","module","exports"],"mappings":";;;;AAOA;;;;AACA;;;;;;;;;;+eARA;;;;;;;AASA,IAAMA,MAAM,qBAAM,aAAN,CAAZ;;AAEA;;;;IAGMC,I;;;AACH;;;;;;AAMA,gBAAYC,MAAZ,EAAoBC,IAApB,EAA0BC,OAA1B,EAAmC;AAAA;;AAAA,4GAC1BD,IAD0B,EACpBC,OADoB;;AAEhC,UAAKC,QAAL,GAAgBH,MAAhB;AAFgC;AAGlC;;AAED;;;;;;;;;;4BAMQI,E,EAAI;AACTN,6BAAqB,KAAKK,QAA1B;AACA,aAAO,KAAKE,QAAL,CAAc,KAAd,cAA+B,KAAKF,QAApC,EAAgDG,SAAhD,EAA2DF,EAA3D,CAAP;AACF;;AAED;;;;;;;;;8BAMUA,E,EAAI;AACXN,8CAAsC,KAAKK,QAA3C;AACA,aAAO,KAAKI,gBAAL,aAAgC,KAAKJ,QAArC,aAAuDG,SAAvD,EAAkEF,EAAlE,CAAP;AACF;;AAED;;;;;;;;;;;;;;;6BAYSI,O,EAASJ,E,EAAI;AACnBN,4BAAoB,KAAKK,QAAzB;AACA,aAAO,KAAKE,QAAL,CAAc,OAAd,cAAiC,KAAKF,QAAtC,EAAkDK,OAAlD,EAA2DJ,EAA3D,CAAP;AACF;;AAED;;;;;;;;;;;gCAQYI,O,EAASJ,E,EAAI;AACtBN,uCAA+B,KAAKK,QAApC;AACA,aAAO,KAAKI,gBAAL,aAAgC,KAAKJ,QAArC,eAAyDK,OAAzD,EAAkEJ,EAAlE,CAAP;AACF;;AAED;;;;;;;;;;kCAOcK,Q,EAAUL,E,EAAI;AACzBN,0CAAkCW,QAAlC,iBAAsD,KAAKN,QAA3D;AACA,aAAO,KAAKE,QAAL,CAAc,KAAd,cAA+B,KAAKF,QAApC,qBAA4DM,QAA5D,EAAwEH,SAAxE,EAAmFF,EAAnF,CAAP;AACF;;AAED;;;;;;;;;;;;;kCAUcK,Q,EAAUD,O,EAASJ,E,EAAI;AAClCN,2BAAmBW,QAAnB,iBAAuC,KAAKN,QAA5C;AACA,aAAO,KAAKE,QAAL,CAAc,KAAd,cAA+B,KAAKF,QAApC,qBAA4DM,QAA5D,EAAwED,OAAxE,EAAiFJ,EAAjF,CAAP;AACF;;AAED;;;;;;;;;;;kCAQcM,K,EAAOC,I,EAAMP,E,EAAI;AAC5BN,+CAAuC,KAAKK,QAA5C,kBAAiEO,KAAjE,SAA0EC,IAA1E;AACA,aAAO,KAAKC,gBAAL,aAAgC,KAAKT,QAArC,eAAuDO,KAAvD,SAAgEC,IAAhE,EAAwEL,SAAxE,EAAmFF,EAAnF,CAAP;AACF;;AAED;;;;;;;;;;;;;;+BAWWM,K,EAAOC,I,EAAMH,O,EAASJ,E,EAAI;AAClCN,0DAAkD,KAAKK,QAAvD,kBAA4EO,KAA5E,SAAqFC,IAArF;AACA,aAAO,KAAKC,gBAAL,aAAgC,KAAKT,QAArC,eAAuDO,KAAvD,SAAgEC,IAAhE,EAAwEH,OAAxE,EAAiFJ,EAAjF,EAAqF,KAArF,CAAP;AACF;;AAED;;;;;;;;;;;iCAQaM,K,EAAOC,I,EAAMP,E,EAAI;AAC3BN,8CAAsC,KAAKK,QAA3C,kBAAgEO,KAAhE,SAAyEC,IAAzE;AACA,aAAO,KAAKC,gBAAL,aAAgC,KAAKT,QAArC,eAAuDO,KAAvD,SAAgEC,IAAhE,EAAwEL,SAAxE,EAAmFF,EAAnF,EAAuF,QAAvF,CAAP;AACF;;AAED;;;;;;;;;+BAMWA,E,EAAI;AACZN,6BAAqB,KAAKK,QAA1B;AACA,aAAO,KAAKS,gBAAL,aAAgC,KAAKT,QAArC,EAAiDG,SAAjD,EAA4DF,EAA5D,EAAgE,QAAhE,CAAP;AACF;;;;EA9IeS,qB;;AAiJnBC,OAAOC,OAAP,GAAiBhB,IAAjB","file":"Team.js","sourcesContent":["/**\n * @file\n * @copyright  2016 Matt Smith (Development Seed)\n * @license    Licensed under {@link https://spdx.org/licenses/BSD-3-Clause-Clear.html BSD-3-Clause-Clear}.\n *             Github.js is freely distributable.\n */\n\nimport Requestable from './Requestable';\nimport debug from 'debug';\nconst log = debug('github:team');\n\n/**\n * A Team allows scoping of API requests to a particular Github Organization Team.\n */\nclass Team extends Requestable {\n   /**\n    * Create a Team.\n    * @param {string} [teamId] - the id for the team\n    * @param {Requestable.auth} [auth] - information required to authenticate to Github\n    * @param {string} [apiBase=https://api.github.com] - the base Github API URL\n    */\n   constructor(teamId, auth, apiBase) {\n      super(auth, apiBase);\n      this.__teamId = teamId;\n   }\n\n   /**\n    * Get Team information\n    * @see https://developer.github.com/v3/orgs/teams/#get-team\n    * @param {Requestable.callback} [cb] - will receive the team\n    * @return {Promise} - the promise for the http request\n    */\n   getTeam(cb) {\n      log(`Fetching Team ${this.__teamId}`);\n      return this._request('Get', `/teams/${this.__teamId}`, undefined, cb);\n   }\n\n   /**\n    * List the Team's repositories\n    * @see https://developer.github.com/v3/orgs/teams/#list-team-repos\n    * @param {Requestable.callback} [cb] - will receive the list of repositories\n    * @return {Promise} - the promise for the http request\n    */\n   listRepos(cb) {\n      log(`Fetching repositories for Team ${this.__teamId}`);\n      return this._requestAllPages(`/teams/${this.__teamId}/repos`, undefined, cb);\n   }\n\n   /**\n    * Edit Team information\n    * @see https://developer.github.com/v3/orgs/teams/#edit-team\n    * @param {object} options - Parameters for team edit\n    * @param {string} options.name - The name of the team\n    * @param {string} [options.description] - Team description\n    * @param {string} [options.repo_names] - Repos to add the team to\n    * @param {string} [options.privacy=secret] - The level of privacy the team should have. Can be either one\n    * of: `secret`, or `closed`\n    * @param {Requestable.callback} [cb] - will receive the updated team\n    * @return {Promise} - the promise for the http request\n    */\n   editTeam(options, cb) {\n      log(`Editing Team ${this.__teamId}`);\n      return this._request('PATCH', `/teams/${this.__teamId}`, options, cb);\n   }\n\n   /**\n    * List the users who are members of the Team\n    * @see https://developer.github.com/v3/orgs/teams/#list-team-members\n    * @param {object} options - Parameters for listing team users\n    * @param {string} [options.role=all] - can be one of: `all`, `maintainer`, or `member`\n    * @param {Requestable.callback} [cb] - will receive the list of users\n    * @return {Promise} - the promise for the http request\n    */\n   listMembers(options, cb) {\n      log(`Getting members of Team ${this.__teamId}`);\n      return this._requestAllPages(`/teams/${this.__teamId}/members`, options, cb);\n   }\n\n   /**\n    * Get Team membership status for a user\n    * @see https://developer.github.com/v3/orgs/teams/#get-team-membership\n    * @param {string} username - can be one of: `all`, `maintainer`, or `member`\n    * @param {Requestable.callback} [cb] - will receive the membership status of a user\n    * @return {Promise} - the promise for the http request\n    */\n   getMembership(username, cb) {\n      log(`Getting membership of user ${username} in Team ${this.__teamId}`);\n      return this._request('GET', `/teams/${this.__teamId}/memberships/${username}`, undefined, cb);\n   }\n\n   /**\n    * Add a member to the Team\n    * @see https://developer.github.com/v3/orgs/teams/#add-team-membership\n    * @param {string} username - can be one of: `all`, `maintainer`, or `member`\n    * @param {object} options - Parameters for adding a team member\n    * @param {string} [options.role=member] - The role that this user should have in the team. Can be one\n    * of: `member`, or `maintainer`\n    * @param {Requestable.callback} [cb] - will receive the membership status of added user\n    * @return {Promise} - the promise for the http request\n    */\n   addMembership(username, options, cb) {\n      log(`Adding user ${username} to Team ${this.__teamId}`);\n      return this._request('PUT', `/teams/${this.__teamId}/memberships/${username}`, options, cb);\n   }\n\n   /**\n    * Get repo management status for team\n    * @see https://developer.github.com/v3/orgs/teams/#remove-team-membership\n    * @param {string} owner - Organization name\n    * @param {string} repo - Repo name\n    * @param {Requestable.callback} [cb] - will receive the membership status of added user\n    * @return {Promise} - the promise for the http request\n    */\n   isManagedRepo(owner, repo, cb) {\n      log(`Getting repo management by Team ${this.__teamId} for repo ${owner}/${repo}`);\n      return this._request204or404(`/teams/${this.__teamId}/repos/${owner}/${repo}`, undefined, cb);\n   }\n\n   /**\n    * Add or Update repo management status for team\n    * @see https://developer.github.com/v3/orgs/teams/#add-or-update-team-repository\n    * @param {string} owner - Organization name\n    * @param {string} repo - Repo name\n    * @param {object} options - Parameters for adding or updating repo management for the team\n    * @param {string} [options.permission] - The permission to grant the team on this repository. Can be one\n    * of: `pull`, `push`, or `admin`\n    * @param {Requestable.callback} [cb] - will receive the membership status of added user\n    * @return {Promise} - the promise for the http request\n    */\n   manageRepo(owner, repo, options, cb) {\n      log(`Adding or Updating repo management by Team ${this.__teamId} for repo ${owner}/${repo}`);\n      return this._request204or404(`/teams/${this.__teamId}/repos/${owner}/${repo}`, options, cb, 'PUT');\n   }\n\n   /**\n    * Remove repo management status for team\n    * @see https://developer.github.com/v3/orgs/teams/#remove-team-repository\n    * @param {string} owner - Organization name\n    * @param {string} repo - Repo name\n    * @param {Requestable.callback} [cb] - will receive the membership status of added user\n    * @return {Promise} - the promise for the http request\n    */\n   unmanageRepo(owner, repo, cb) {\n      log(`Remove repo management by Team ${this.__teamId} for repo ${owner}/${repo}`);\n      return this._request204or404(`/teams/${this.__teamId}/repos/${owner}/${repo}`, undefined, cb, 'DELETE');\n   }\n\n   /**\n    * Delete Team\n    * @see https://developer.github.com/v3/orgs/teams/#delete-team\n    * @param {Requestable.callback} [cb] - will receive the list of repositories\n    * @return {Promise} - the promise for the http request\n    */\n   deleteTeam(cb) {\n      log(`Deleting Team ${this.__teamId}`);\n      return this._request204or404(`/teams/${this.__teamId}`, undefined, cb, 'DELETE');\n   }\n}\n\nmodule.exports = Team;\n"]}
|
219 | //# sourceMappingURL=Team.js.map
|