UNPKG

24.5 kBJavaScriptView Raw
1'use strict';
2
3var _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
5var _Requestable2 = require('./Requestable');
6
7var _Requestable3 = _interopRequireDefault(_Requestable2);
8
9var _debug = require('debug');
10
11var _debug2 = _interopRequireDefault(_debug);
12
13function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
15function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
16
17function _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
19function _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
26var log = (0, _debug2.default)('github:team');
27
28/**
29 * A Team allows scoping of API requests to a particular Github Organization Team.
30 */
31
32var 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
217module.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