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 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
10 |
|
11 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
12 |
|
13 | 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; }
|
14 |
|
15 | 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; } /**
|
16 | * @file
|
17 | * @copyright 2013 Michael Aufreiter (Development Seed) and 2016 Yahoo Inc.
|
18 | * @license Licensed under {@link https://spdx.org/licenses/BSD-3-Clause-Clear.html BSD-3-Clause-Clear}.
|
19 | * Github.js is freely distributable.
|
20 | */
|
21 |
|
22 | /**
|
23 | * Organization encapsulates the functionality to create repositories in organizations
|
24 | */
|
25 | var Organization = function (_Requestable) {
|
26 | _inherits(Organization, _Requestable);
|
27 |
|
28 | /**
|
29 | * Create a new Organization
|
30 | * @param {string} organization - the name of the organization
|
31 | * @param {Requestable.auth} [auth] - information required to authenticate to Github
|
32 | * @param {string} [apiBase=https://api.github.com] - the base Github API URL
|
33 | */
|
34 | function Organization(organization, auth, apiBase) {
|
35 | _classCallCheck(this, Organization);
|
36 |
|
37 | var _this = _possibleConstructorReturn(this, (Organization.__proto__ || Object.getPrototypeOf(Organization)).call(this, auth, apiBase));
|
38 |
|
39 | _this.__name = organization;
|
40 | return _this;
|
41 | }
|
42 |
|
43 | /**
|
44 | * Create a repository in an organization
|
45 | * @see https://developer.github.com/v3/repos/#create
|
46 | * @param {Object} options - the repository definition
|
47 | * @param {Requestable.callback} [cb] - will receive the created repository
|
48 | * @return {Promise} - the promise for the http request
|
49 | */
|
50 |
|
51 |
|
52 | _createClass(Organization, [{
|
53 | key: 'createRepo',
|
54 | value: function createRepo(options, cb) {
|
55 | return this._request('POST', '/orgs/' + this.__name + '/repos', options, cb);
|
56 | }
|
57 |
|
58 | /**
|
59 | * List the repositories in an organization
|
60 | * @see https://developer.github.com/v3/repos/#list-organization-repositories
|
61 | * @param {Requestable.callback} [cb] - will receive the list of repositories
|
62 | * @return {Promise} - the promise for the http request
|
63 | */
|
64 |
|
65 | }, {
|
66 | key: 'getRepos',
|
67 | value: function getRepos(cb) {
|
68 | var requestOptions = this._getOptionsWithDefaults({ direction: 'desc' });
|
69 |
|
70 | return this._requestAllPages('/orgs/' + this.__name + '/repos', requestOptions, cb);
|
71 | }
|
72 |
|
73 | /**
|
74 | * Query if the user is a member or not
|
75 | * @param {string} username - the user in question
|
76 | * @param {Requestable.callback} [cb] - will receive true if the user is a member
|
77 | * @return {Promise} - the promise for the http request
|
78 | */
|
79 |
|
80 | }, {
|
81 | key: 'isMember',
|
82 | value: function isMember(username, cb) {
|
83 | return this._request204or404('/orgs/' + this.__name + '/members/' + username, null, cb);
|
84 | }
|
85 |
|
86 | /**
|
87 | * List the users who are members of the company
|
88 | * @see https://developer.github.com/v3/orgs/members/#members-list
|
89 | * @param {object} options - filtering options
|
90 | * @param {string} [options.filter=all] - can be either `2fa_disabled` or `all`
|
91 | * @param {string} [options.role=all] - can be one of: `all`, `admin`, or `member`
|
92 | * @param {Requestable.callback} [cb] - will receive the list of users
|
93 | * @return {Promise} - the promise for the http request
|
94 | */
|
95 |
|
96 | }, {
|
97 | key: 'listMembers',
|
98 | value: function listMembers(options, cb) {
|
99 | return this._request('GET', '/orgs/' + this.__name + '/members', options, cb);
|
100 | }
|
101 |
|
102 | /**
|
103 | * List the Teams in the Organization
|
104 | * @see https://developer.github.com/v3/orgs/teams/#list-teams
|
105 | * @param {Requestable.callback} [cb] - will receive the list of teams
|
106 | * @return {Promise} - the promise for the http request
|
107 | */
|
108 |
|
109 | }, {
|
110 | key: 'getTeams',
|
111 | value: function getTeams(cb) {
|
112 | return this._requestAllPages('/orgs/' + this.__name + '/teams', undefined, cb);
|
113 | }
|
114 |
|
115 | /**
|
116 | * Create a team
|
117 | * @see https://developer.github.com/v3/orgs/teams/#create-team
|
118 | * @param {object} options - Team creation parameters
|
119 | * @param {string} options.name - The name of the team
|
120 | * @param {string} [options.description] - Team description
|
121 | * @param {string} [options.repo_names] - Repos to add the team to
|
122 | * @param {string} [options.privacy=secret] - The level of privacy the team should have. Can be either one
|
123 | * of: `secret`, or `closed`
|
124 | * @param {Requestable.callback} [cb] - will receive the created team
|
125 | * @return {Promise} - the promise for the http request
|
126 | */
|
127 |
|
128 | }, {
|
129 | key: 'createTeam',
|
130 | value: function createTeam(options, cb) {
|
131 | return this._request('POST', '/orgs/' + this.__name + '/teams', options, cb);
|
132 | }
|
133 |
|
134 | /**
|
135 | * Get information about all projects
|
136 | * @see https://developer.github.com/v3/projects/#list-organization-projects
|
137 | * @param {Requestable.callback} [cb] - will receive the list of projects
|
138 | * @return {Promise} - the promise for the http request
|
139 | */
|
140 |
|
141 | }, {
|
142 | key: 'listProjects',
|
143 | value: function listProjects(cb) {
|
144 | return this._requestAllPages('/orgs/' + this.__name + '/projects', { AcceptHeader: 'inertia-preview' }, cb);
|
145 | }
|
146 |
|
147 | /**
|
148 | * Create a new project
|
149 | * @see https://developer.github.com/v3/repos/projects/#create-a-project
|
150 | * @param {Object} options - the description of the project
|
151 | * @param {Requestable.callback} cb - will receive the newly created project
|
152 | * @return {Promise} - the promise for the http request
|
153 | */
|
154 |
|
155 | }, {
|
156 | key: 'createProject',
|
157 | value: function createProject(options, cb) {
|
158 | options = options || {};
|
159 | options.AcceptHeader = 'inertia-preview';
|
160 | return this._request('POST', '/orgs/' + this.__name + '/projects', options, cb);
|
161 | }
|
162 | }]);
|
163 |
|
164 | return Organization;
|
165 | }(_Requestable3.default);
|
166 |
|
167 | module.exports = Organization;
|
168 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Organization.js"],"names":["Organization","organization","auth","apiBase","__name","options","cb","_request","requestOptions","_getOptionsWithDefaults","direction","_requestAllPages","username","_request204or404","undefined","AcceptHeader","Requestable","module","exports"],"mappings":";;;;AAOA;;;;;;;;;;+eAPA;;;;;;;AASA;;;IAGMA,Y;;;AACH;;;;;;AAMA,wBAAYC,YAAZ,EAA0BC,IAA1B,EAAgCC,OAAhC,EAAyC;AAAA;;AAAA,4HAChCD,IADgC,EAC1BC,OAD0B;;AAEtC,UAAKC,MAAL,GAAcH,YAAd;AAFsC;AAGxC;;AAED;;;;;;;;;;;+BAOWI,O,EAASC,E,EAAI;AACrB,aAAO,KAAKC,QAAL,CAAc,MAAd,aAA+B,KAAKH,MAApC,aAAoDC,OAApD,EAA6DC,EAA7D,CAAP;AACF;;AAED;;;;;;;;;6BAMSA,E,EAAI;AACV,UAAIE,iBAAiB,KAAKC,uBAAL,CAA6B,EAACC,WAAW,MAAZ,EAA7B,CAArB;;AAEA,aAAO,KAAKC,gBAAL,YAA+B,KAAKP,MAApC,aAAoDI,cAApD,EAAoEF,EAApE,CAAP;AACF;;AAED;;;;;;;;;6BAMSM,Q,EAAUN,E,EAAI;AACpB,aAAO,KAAKO,gBAAL,YAA+B,KAAKT,MAApC,iBAAsDQ,QAAtD,EAAkE,IAAlE,EAAwEN,EAAxE,CAAP;AACF;;AAED;;;;;;;;;;;;gCASYD,O,EAASC,E,EAAI;AACtB,aAAO,KAAKC,QAAL,CAAc,KAAd,aAA8B,KAAKH,MAAnC,eAAqDC,OAArD,EAA8DC,EAA9D,CAAP;AACF;;AAED;;;;;;;;;6BAMSA,E,EAAI;AACV,aAAO,KAAKK,gBAAL,YAA+B,KAAKP,MAApC,aAAoDU,SAApD,EAA+DR,EAA/D,CAAP;AACF;;AAED;;;;;;;;;;;;;;;+BAYWD,O,EAASC,E,EAAI;AACrB,aAAO,KAAKC,QAAL,CAAc,MAAd,aAA+B,KAAKH,MAApC,aAAoDC,OAApD,EAA6DC,EAA7D,CAAP;AACF;;AAED;;;;;;;;;iCAMaA,E,EAAI;AACd,aAAO,KAAKK,gBAAL,YAA+B,KAAKP,MAApC,gBAAuD,EAACW,cAAc,iBAAf,EAAvD,EAA0FT,EAA1F,CAAP;AACF;;AAED;;;;;;;;;;kCAOcD,O,EAASC,E,EAAI;AACxBD,gBAAUA,WAAW,EAArB;AACAA,cAAQU,YAAR,GAAuB,iBAAvB;AACA,aAAO,KAAKR,QAAL,CAAc,MAAd,aAA+B,KAAKH,MAApC,gBAAuDC,OAAvD,EAAgEC,EAAhE,CAAP;AACF;;;;EAzGuBU,qB;;AA4G3BC,OAAOC,OAAP,GAAiBlB,YAAjB","file":"Organization.js","sourcesContent":["/**\n * @file\n * @copyright  2013 Michael Aufreiter (Development Seed) and 2016 Yahoo Inc.\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';\n\n/**\n * Organization encapsulates the functionality to create repositories in organizations\n */\nclass Organization extends Requestable {\n   /**\n    * Create a new Organization\n    * @param {string} organization - the name of the organization\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(organization, auth, apiBase) {\n      super(auth, apiBase);\n      this.__name = organization;\n   }\n\n   /**\n    * Create a repository in an organization\n    * @see https://developer.github.com/v3/repos/#create\n    * @param {Object} options - the repository definition\n    * @param {Requestable.callback} [cb] - will receive the created repository\n    * @return {Promise} - the promise for the http request\n    */\n   createRepo(options, cb) {\n      return this._request('POST', `/orgs/${this.__name}/repos`, options, cb);\n   }\n\n   /**\n    * List the repositories in an organization\n    * @see https://developer.github.com/v3/repos/#list-organization-repositories\n    * @param {Requestable.callback} [cb] - will receive the list of repositories\n    * @return {Promise} - the promise for the http request\n    */\n   getRepos(cb) {\n      let requestOptions = this._getOptionsWithDefaults({direction: 'desc'});\n\n      return this._requestAllPages(`/orgs/${this.__name}/repos`, requestOptions, cb);\n   }\n\n   /**\n    * Query if the user is a member or not\n    * @param {string} username - the user in question\n    * @param {Requestable.callback} [cb] - will receive true if the user is a member\n    * @return {Promise} - the promise for the http request\n    */\n   isMember(username, cb) {\n      return this._request204or404(`/orgs/${this.__name}/members/${username}`, null, cb);\n   }\n\n   /**\n    * List the users who are members of the company\n    * @see https://developer.github.com/v3/orgs/members/#members-list\n    * @param {object} options - filtering options\n    * @param {string} [options.filter=all] - can be either `2fa_disabled` or `all`\n    * @param {string} [options.role=all] - can be one of: `all`, `admin`, 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      return this._request('GET', `/orgs/${this.__name}/members`, options, cb);\n   }\n\n   /**\n    * List the Teams in the Organization\n    * @see https://developer.github.com/v3/orgs/teams/#list-teams\n    * @param {Requestable.callback} [cb] - will receive the list of teams\n    * @return {Promise} - the promise for the http request\n    */\n   getTeams(cb) {\n      return this._requestAllPages(`/orgs/${this.__name}/teams`, undefined, cb);\n   }\n\n   /**\n    * Create a team\n    * @see https://developer.github.com/v3/orgs/teams/#create-team\n    * @param {object} options - Team creation parameters\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 created team\n    * @return {Promise} - the promise for the http request\n    */\n   createTeam(options, cb) {\n      return this._request('POST', `/orgs/${this.__name}/teams`, options, cb);\n   }\n\n   /**\n    * Get information about all projects\n    * @see https://developer.github.com/v3/projects/#list-organization-projects\n    * @param {Requestable.callback} [cb] - will receive the list of projects\n    * @return {Promise} - the promise for the http request\n    */\n   listProjects(cb) {\n      return this._requestAllPages(`/orgs/${this.__name}/projects`, {AcceptHeader: 'inertia-preview'}, cb);\n   }\n\n   /**\n    * Create a new project\n    * @see https://developer.github.com/v3/repos/projects/#create-a-project\n    * @param {Object} options - the description of the project\n    * @param {Requestable.callback} cb - will receive the newly created project\n    * @return {Promise} - the promise for the http request\n    */\n   createProject(options, cb) {\n      options = options || {};\n      options.AcceptHeader = 'inertia-preview';\n      return this._request('POST', `/orgs/${this.__name}/projects`, options, cb);\n   }\n}\n\nmodule.exports = Organization;\n"]}
|
169 | //# sourceMappingURL=Organization.js.map
|