UNPKG

17.2 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 * @file
5 * @copyright 2013 Michael Aufreiter (Development Seed) and 2016 Yahoo Inc.
6 * @license Licensed under {@link https://spdx.org/licenses/BSD-3-Clause-Clear.html BSD-3-Clause-Clear}.
7 * Github.js is freely distributable.
8 */
9/* eslint valid-jsdoc: ["error", {"requireReturnDescription": false}] */
10
11var _Gist = require('./Gist');
12
13var _Gist2 = _interopRequireDefault(_Gist);
14
15var _User = require('./User');
16
17var _User2 = _interopRequireDefault(_User);
18
19var _Issue = require('./Issue');
20
21var _Issue2 = _interopRequireDefault(_Issue);
22
23var _Search = require('./Search');
24
25var _Search2 = _interopRequireDefault(_Search);
26
27var _RateLimit = require('./RateLimit');
28
29var _RateLimit2 = _interopRequireDefault(_RateLimit);
30
31var _Repository = require('./Repository');
32
33var _Repository2 = _interopRequireDefault(_Repository);
34
35var _Organization = require('./Organization');
36
37var _Organization2 = _interopRequireDefault(_Organization);
38
39var _Team = require('./Team');
40
41var _Team2 = _interopRequireDefault(_Team);
42
43var _Markdown = require('./Markdown');
44
45var _Markdown2 = _interopRequireDefault(_Markdown);
46
47var _Project = require('./Project');
48
49var _Project2 = _interopRequireDefault(_Project);
50
51function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
52
53function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
54
55/**
56 * GitHub encapsulates the functionality to create various API wrapper objects.
57 */
58var GitHub = function () {
59 /**
60 * Create a new GitHub.
61 * @param {Requestable.auth} [auth] - the credentials to authenticate to Github. If auth is
62 * not provided requests will be made unauthenticated
63 * @param {string} [apiBase=https://api.github.com] - the base Github API URL
64 */
65 function GitHub(auth) {
66 var apiBase = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'https://api.github.com';
67
68 _classCallCheck(this, GitHub);
69
70 this.__apiBase = apiBase;
71 this.__auth = auth || {};
72 }
73
74 /**
75 * Create a new Gist wrapper
76 * @param {string} [id] - the id for the gist, leave undefined when creating a new gist
77 * @return {Gist}
78 */
79
80
81 _createClass(GitHub, [{
82 key: 'getGist',
83 value: function getGist(id) {
84 return new _Gist2.default(id, this.__auth, this.__apiBase);
85 }
86
87 /**
88 * Create a new User wrapper
89 * @param {string} [user] - the name of the user to get information about
90 * leave undefined for the authenticated user
91 * @return {User}
92 */
93
94 }, {
95 key: 'getUser',
96 value: function getUser(user) {
97 return new _User2.default(user, this.__auth, this.__apiBase);
98 }
99
100 /**
101 * Create a new Organization wrapper
102 * @param {string} organization - the name of the organization
103 * @return {Organization}
104 */
105
106 }, {
107 key: 'getOrganization',
108 value: function getOrganization(organization) {
109 return new _Organization2.default(organization, this.__auth, this.__apiBase);
110 }
111
112 /**
113 * create a new Team wrapper
114 * @param {string} teamId - the name of the team
115 * @return {team}
116 */
117
118 }, {
119 key: 'getTeam',
120 value: function getTeam(teamId) {
121 return new _Team2.default(teamId, this.__auth, this.__apiBase);
122 }
123
124 /**
125 * Create a new Repository wrapper
126 * @param {string} user - the user who owns the repository
127 * @param {string} repo - the name of the repository
128 * @return {Repository}
129 */
130
131 }, {
132 key: 'getRepo',
133 value: function getRepo(user, repo) {
134 return new _Repository2.default(this._getFullName(user, repo), this.__auth, this.__apiBase);
135 }
136
137 /**
138 * Create a new Issue wrapper
139 * @param {string} user - the user who owns the repository
140 * @param {string} repo - the name of the repository
141 * @return {Issue}
142 */
143
144 }, {
145 key: 'getIssues',
146 value: function getIssues(user, repo) {
147 return new _Issue2.default(this._getFullName(user, repo), this.__auth, this.__apiBase);
148 }
149
150 /**
151 * Create a new Search wrapper
152 * @param {string} query - the query to search for
153 * @return {Search}
154 */
155
156 }, {
157 key: 'search',
158 value: function search(query) {
159 return new _Search2.default(query, this.__auth, this.__apiBase);
160 }
161
162 /**
163 * Create a new RateLimit wrapper
164 * @return {RateLimit}
165 */
166
167 }, {
168 key: 'getRateLimit',
169 value: function getRateLimit() {
170 return new _RateLimit2.default(this.__auth, this.__apiBase);
171 }
172
173 /**
174 * Create a new Markdown wrapper
175 * @return {Markdown}
176 */
177
178 }, {
179 key: 'getMarkdown',
180 value: function getMarkdown() {
181 return new _Markdown2.default(this.__auth, this.__apiBase);
182 }
183
184 /**
185 * Create a new Project wrapper
186 * @param {string} id - the id of the project
187 * @return {Project}
188 */
189
190 }, {
191 key: 'getProject',
192 value: function getProject(id) {
193 return new _Project2.default(id, this.__auth, this.__apiBase);
194 }
195
196 /**
197 * Computes the full repository name
198 * @param {string} user - the username (or the full name)
199 * @param {string} repo - the repository name, must not be passed if `user` is the full name
200 * @return {string} the repository's full name
201 */
202
203 }, {
204 key: '_getFullName',
205 value: function _getFullName(user, repo) {
206 var fullname = user;
207
208 if (repo) {
209 fullname = user + '/' + repo;
210 }
211
212 return fullname;
213 }
214 }]);
215
216 return GitHub;
217}();
218
219module.exports = GitHub;
220//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["GitHub.js"],"names":["GitHub","auth","apiBase","__apiBase","__auth","id","Gist","user","User","organization","Organization","teamId","Team","repo","Repository","_getFullName","Issue","query","Search","RateLimit","Markdown","Project","fullname","module","exports"],"mappings":";;qjBAAA;;;;;;AAMA;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;;;AAEA;;;IAGMA,M;AACH;;;;;;AAMA,kBAAYC,IAAZ,EAAsD;AAAA,QAApCC,OAAoC,uEAA1B,wBAA0B;;AAAA;;AACnD,SAAKC,SAAL,GAAiBD,OAAjB;AACA,SAAKE,MAAL,GAAcH,QAAQ,EAAtB;AACF;;AAED;;;;;;;;;4BAKQI,E,EAAI;AACT,aAAO,IAAIC,cAAJ,CAASD,EAAT,EAAa,KAAKD,MAAlB,EAA0B,KAAKD,SAA/B,CAAP;AACF;;AAED;;;;;;;;;4BAMQI,I,EAAM;AACX,aAAO,IAAIC,cAAJ,CAASD,IAAT,EAAe,KAAKH,MAApB,EAA4B,KAAKD,SAAjC,CAAP;AACF;;AAED;;;;;;;;oCAKgBM,Y,EAAc;AAC3B,aAAO,IAAIC,sBAAJ,CAAiBD,YAAjB,EAA+B,KAAKL,MAApC,EAA4C,KAAKD,SAAjD,CAAP;AACF;;AAED;;;;;;;;4BAKQQ,M,EAAQ;AACb,aAAO,IAAIC,cAAJ,CAASD,MAAT,EAAiB,KAAKP,MAAtB,EAA8B,KAAKD,SAAnC,CAAP;AACF;;AAED;;;;;;;;;4BAMQI,I,EAAMM,I,EAAM;AACjB,aAAO,IAAIC,oBAAJ,CAAe,KAAKC,YAAL,CAAkBR,IAAlB,EAAwBM,IAAxB,CAAf,EAA8C,KAAKT,MAAnD,EAA2D,KAAKD,SAAhE,CAAP;AACF;;AAED;;;;;;;;;8BAMUI,I,EAAMM,I,EAAM;AACnB,aAAO,IAAIG,eAAJ,CAAU,KAAKD,YAAL,CAAkBR,IAAlB,EAAwBM,IAAxB,CAAV,EAAyC,KAAKT,MAA9C,EAAsD,KAAKD,SAA3D,CAAP;AACF;;AAED;;;;;;;;2BAKOc,K,EAAO;AACX,aAAO,IAAIC,gBAAJ,CAAWD,KAAX,EAAkB,KAAKb,MAAvB,EAA+B,KAAKD,SAApC,CAAP;AACF;;AAED;;;;;;;mCAIe;AACZ,aAAO,IAAIgB,mBAAJ,CAAc,KAAKf,MAAnB,EAA2B,KAAKD,SAAhC,CAAP;AACF;;AAED;;;;;;;kCAIc;AACX,aAAO,IAAIiB,kBAAJ,CAAa,KAAKhB,MAAlB,EAA0B,KAAKD,SAA/B,CAAP;AACF;;AAED;;;;;;;;+BAKWE,E,EAAI;AACZ,aAAO,IAAIgB,iBAAJ,CAAYhB,EAAZ,EAAgB,KAAKD,MAArB,EAA6B,KAAKD,SAAlC,CAAP;AACF;;AAED;;;;;;;;;iCAMaI,I,EAAMM,I,EAAM;AACtB,UAAIS,WAAWf,IAAf;;AAEA,UAAIM,IAAJ,EAAU;AACPS,mBAAcf,IAAd,SAAsBM,IAAtB;AACF;;AAED,aAAOS,QAAP;AACF;;;;;;AAGJC,OAAOC,OAAP,GAAiBxB,MAAjB","file":"GitHub.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/* eslint valid-jsdoc: [\"error\", {\"requireReturnDescription\": false}] */\n\nimport Gist from './Gist';\nimport User from './User';\nimport Issue from './Issue';\nimport Search from './Search';\nimport RateLimit from './RateLimit';\nimport Repository from './Repository';\nimport Organization from './Organization';\nimport Team from './Team';\nimport Markdown from './Markdown';\nimport Project from './Project';\n\n/**\n * GitHub encapsulates the functionality to create various API wrapper objects.\n */\nclass GitHub {\n   /**\n    * Create a new GitHub.\n    * @param {Requestable.auth} [auth] - the credentials to authenticate to Github. If auth is\n    *                                  not provided requests will be made unauthenticated\n    * @param {string} [apiBase=https://api.github.com] - the base Github API URL\n    */\n   constructor(auth, apiBase = 'https://api.github.com') {\n      this.__apiBase = apiBase;\n      this.__auth = auth || {};\n   }\n\n   /**\n    * Create a new Gist wrapper\n    * @param {string} [id] - the id for the gist, leave undefined when creating a new gist\n    * @return {Gist}\n    */\n   getGist(id) {\n      return new Gist(id, this.__auth, this.__apiBase);\n   }\n\n   /**\n    * Create a new User wrapper\n    * @param {string} [user] - the name of the user to get information about\n    *                        leave undefined for the authenticated user\n    * @return {User}\n    */\n   getUser(user) {\n      return new User(user, this.__auth, this.__apiBase);\n   }\n\n   /**\n    * Create a new Organization wrapper\n    * @param {string} organization - the name of the organization\n    * @return {Organization}\n    */\n   getOrganization(organization) {\n      return new Organization(organization, this.__auth, this.__apiBase);\n   }\n\n   /**\n    * create a new Team wrapper\n    * @param {string} teamId - the name of the team\n    * @return {team}\n    */\n   getTeam(teamId) {\n      return new Team(teamId, this.__auth, this.__apiBase);\n   }\n\n   /**\n    * Create a new Repository wrapper\n    * @param {string} user - the user who owns the repository\n    * @param {string} repo - the name of the repository\n    * @return {Repository}\n    */\n   getRepo(user, repo) {\n      return new Repository(this._getFullName(user, repo), this.__auth, this.__apiBase);\n   }\n\n   /**\n    * Create a new Issue wrapper\n    * @param {string} user - the user who owns the repository\n    * @param {string} repo - the name of the repository\n    * @return {Issue}\n    */\n   getIssues(user, repo) {\n      return new Issue(this._getFullName(user, repo), this.__auth, this.__apiBase);\n   }\n\n   /**\n    * Create a new Search wrapper\n    * @param {string} query - the query to search for\n    * @return {Search}\n    */\n   search(query) {\n      return new Search(query, this.__auth, this.__apiBase);\n   }\n\n   /**\n    * Create a new RateLimit wrapper\n    * @return {RateLimit}\n    */\n   getRateLimit() {\n      return new RateLimit(this.__auth, this.__apiBase);\n   }\n\n   /**\n    * Create a new Markdown wrapper\n    * @return {Markdown}\n    */\n   getMarkdown() {\n      return new Markdown(this.__auth, this.__apiBase);\n   }\n\n   /**\n    * Create a new Project wrapper\n    * @param {string} id - the id of the project\n    * @return {Project}\n    */\n   getProject(id) {\n      return new Project(id, this.__auth, this.__apiBase);\n   }\n\n   /**\n    * Computes the full repository name\n    * @param {string} user - the username (or the full name)\n    * @param {string} repo - the repository name, must not be passed if `user` is the full name\n    * @return {string} the repository's full name\n    */\n   _getFullName(user, repo) {\n      let fullname = user;\n\n      if (repo) {\n         fullname = `${user}/${repo}`;\n      }\n\n      return fullname;\n   }\n}\n\nmodule.exports = GitHub;\n"]}
221//# sourceMappingURL=GitHub.js.map