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 2013 Michael Aufreiter (Development Seed) and 2016 Yahoo Inc.
|
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:user');
|
27 |
|
28 | /**
|
29 | * A User allows scoping of API requests to a particular Github user.
|
30 | */
|
31 |
|
32 | var User = function (_Requestable) {
|
33 | _inherits(User, _Requestable);
|
34 |
|
35 | /**
|
36 | * Create a User.
|
37 | * @param {string} [username] - the user to use for user-scoped queries
|
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 User(username, auth, apiBase) {
|
42 | _classCallCheck(this, User);
|
43 |
|
44 | var _this = _possibleConstructorReturn(this, (User.__proto__ || Object.getPrototypeOf(User)).call(this, auth, apiBase));
|
45 |
|
46 | _this.__user = username;
|
47 | return _this;
|
48 | }
|
49 |
|
50 | /**
|
51 | * Get the url for the request. (dependent on if we're requesting for the authenticated user or not)
|
52 | * @private
|
53 | * @param {string} endpoint - the endpoint being requested
|
54 | * @return {string} - the resolved endpoint
|
55 | */
|
56 |
|
57 |
|
58 | _createClass(User, [{
|
59 | key: '__getScopedUrl',
|
60 | value: function __getScopedUrl(endpoint) {
|
61 | if (this.__user) {
|
62 | return endpoint ? '/users/' + this.__user + '/' + endpoint : '/users/' + this.__user;
|
63 | } else {
|
64 | // eslint-disable-line
|
65 | switch (endpoint) {
|
66 | case '':
|
67 | return '/user';
|
68 |
|
69 | case 'notifications':
|
70 | case 'gists':
|
71 | return '/' + endpoint;
|
72 |
|
73 | default:
|
74 | return '/user/' + endpoint;
|
75 | }
|
76 | }
|
77 | }
|
78 |
|
79 | /**
|
80 | * List the user's repositories
|
81 | * @see https://developer.github.com/v3/repos/#list-user-repositories
|
82 | * @param {Object} [options={}] - any options to refine the search
|
83 | * @param {Requestable.callback} [cb] - will receive the list of repositories
|
84 | * @return {Promise} - the promise for the http request
|
85 | */
|
86 |
|
87 | }, {
|
88 | key: 'listRepos',
|
89 | value: function listRepos(options, cb) {
|
90 | if (typeof options === 'function') {
|
91 | cb = options;
|
92 | options = {};
|
93 | }
|
94 |
|
95 | options = this._getOptionsWithDefaults(options);
|
96 |
|
97 | log('Fetching repositories with options: ' + JSON.stringify(options));
|
98 | return this._requestAllPages(this.__getScopedUrl('repos'), options, cb);
|
99 | }
|
100 |
|
101 | /**
|
102 | * List the orgs that the user belongs to
|
103 | * @see https://developer.github.com/v3/orgs/#list-user-organizations
|
104 | * @param {Requestable.callback} [cb] - will receive the list of organizations
|
105 | * @return {Promise} - the promise for the http request
|
106 | */
|
107 |
|
108 | }, {
|
109 | key: 'listOrgs',
|
110 | value: function listOrgs(cb) {
|
111 | return this._request('GET', this.__getScopedUrl('orgs'), null, cb);
|
112 | }
|
113 |
|
114 | /**
|
115 | * List followers of a user
|
116 | * @see https://developer.github.com/v3/users/followers/#list-followers-of-a-user
|
117 | * @param {Requestable.callback} [cb] - will receive the list of followers
|
118 | * @return {Promise} - the promise for the http request
|
119 | */
|
120 |
|
121 | }, {
|
122 | key: 'listFollowers',
|
123 | value: function listFollowers(cb) {
|
124 | return this._request('GET', this.__getScopedUrl('followers'), null, cb);
|
125 | }
|
126 |
|
127 | /**
|
128 | * List users followed by another user
|
129 | * @see https://developer.github.com/v3/users/followers/#list-users-followed-by-another-user
|
130 | * @param {Requestable.callback} [cb] - will receive the list of who a user is following
|
131 | * @return {Promise} - the promise for the http request
|
132 | */
|
133 |
|
134 | }, {
|
135 | key: 'listFollowing',
|
136 | value: function listFollowing(cb) {
|
137 | return this._request('GET', this.__getScopedUrl('following'), null, cb);
|
138 | }
|
139 |
|
140 | /**
|
141 | * List the user's gists
|
142 | * @see https://developer.github.com/v3/gists/#list-a-users-gists
|
143 | * @param {Requestable.callback} [cb] - will receive the list of gists
|
144 | * @return {Promise} - the promise for the http request
|
145 | */
|
146 |
|
147 | }, {
|
148 | key: 'listGists',
|
149 | value: function listGists(cb) {
|
150 | return this._request('GET', this.__getScopedUrl('gists'), null, cb);
|
151 | }
|
152 |
|
153 | /**
|
154 | * List the user's notifications
|
155 | * @see https://developer.github.com/v3/activity/notifications/#list-your-notifications
|
156 | * @param {Object} [options={}] - any options to refine the search
|
157 | * @param {Requestable.callback} [cb] - will receive the list of repositories
|
158 | * @return {Promise} - the promise for the http request
|
159 | */
|
160 |
|
161 | }, {
|
162 | key: 'listNotifications',
|
163 | value: function listNotifications(options, cb) {
|
164 | options = options || {};
|
165 | if (typeof options === 'function') {
|
166 | cb = options;
|
167 | options = {};
|
168 | }
|
169 |
|
170 | options.since = this._dateToISO(options.since);
|
171 | options.before = this._dateToISO(options.before);
|
172 |
|
173 | return this._request('GET', this.__getScopedUrl('notifications'), options, cb);
|
174 | }
|
175 |
|
176 | /**
|
177 | * Show the user's profile
|
178 | * @see https://developer.github.com/v3/users/#get-a-single-user
|
179 | * @param {Requestable.callback} [cb] - will receive the user's information
|
180 | * @return {Promise} - the promise for the http request
|
181 | */
|
182 |
|
183 | }, {
|
184 | key: 'getProfile',
|
185 | value: function getProfile(cb) {
|
186 | return this._request('GET', this.__getScopedUrl(''), null, cb);
|
187 | }
|
188 |
|
189 | /**
|
190 | * Gets the list of starred repositories for the user
|
191 | * @see https://developer.github.com/v3/activity/starring/#list-repositories-being-starred
|
192 | * @param {Requestable.callback} [cb] - will receive the list of starred repositories
|
193 | * @return {Promise} - the promise for the http request
|
194 | */
|
195 |
|
196 | }, {
|
197 | key: 'listStarredRepos',
|
198 | value: function listStarredRepos(cb) {
|
199 | var requestOptions = this._getOptionsWithDefaults();
|
200 | return this._requestAllPages(this.__getScopedUrl('starred'), requestOptions, cb);
|
201 | }
|
202 |
|
203 | /**
|
204 | * Gets the list of starred gists for the user
|
205 | * @see https://developer.github.com/v3/gists/#list-starred-gists
|
206 | * @param {Object} [options={}] - any options to refine the search
|
207 | * @param {Requestable.callback} [cb] - will receive the list of gists
|
208 | * @return {Promise} - the promise for the http request
|
209 | */
|
210 |
|
211 | }, {
|
212 | key: 'listStarredGists',
|
213 | value: function listStarredGists(options, cb) {
|
214 | options = options || {};
|
215 | if (typeof options === 'function') {
|
216 | cb = options;
|
217 | options = {};
|
218 | }
|
219 | options.since = this._dateToISO(options.since);
|
220 | return this._request('GET', '/gists/starred', options, cb);
|
221 | }
|
222 |
|
223 | /**
|
224 | * List email addresses for a user
|
225 | * @see https://developer.github.com/v3/users/emails/#list-email-addresses-for-a-user
|
226 | * @param {Requestable.callback} [cb] - will receive the list of emails
|
227 | * @return {Promise} - the promise for the http request
|
228 | */
|
229 |
|
230 | }, {
|
231 | key: 'getEmails',
|
232 | value: function getEmails(cb) {
|
233 | return this._request('GET', '/user/emails', null, cb);
|
234 | }
|
235 |
|
236 | /**
|
237 | * Have the authenticated user follow this user
|
238 | * @see https://developer.github.com/v3/users/followers/#follow-a-user
|
239 | * @param {string} username - the user to follow
|
240 | * @param {Requestable.callback} [cb] - will receive true if the request succeeds
|
241 | * @return {Promise} - the promise for the http request
|
242 | */
|
243 |
|
244 | }, {
|
245 | key: 'follow',
|
246 | value: function follow(username, cb) {
|
247 | return this._request('PUT', '/user/following/' + username, null, cb);
|
248 | }
|
249 |
|
250 | /**
|
251 | * Have the currently authenticated user unfollow this user
|
252 | * @see https://developer.github.com/v3/users/followers/#follow-a-user
|
253 | * @param {string} username - the user to unfollow
|
254 | * @param {Requestable.callback} [cb] - receives true if the request succeeds
|
255 | * @return {Promise} - the promise for the http request
|
256 | */
|
257 |
|
258 | }, {
|
259 | key: 'unfollow',
|
260 | value: function unfollow(username, cb) {
|
261 | return this._request('DELETE', '/user/following/' + username, null, cb);
|
262 | }
|
263 |
|
264 | /**
|
265 | * Create a new repository for the currently authenticated user
|
266 | * @see https://developer.github.com/v3/repos/#create
|
267 | * @param {object} options - the repository definition
|
268 | * @param {Requestable.callback} [cb] - will receive the API response
|
269 | * @return {Promise} - the promise for the http request
|
270 | */
|
271 |
|
272 | }, {
|
273 | key: 'createRepo',
|
274 | value: function createRepo(options, cb) {
|
275 | return this._request('POST', '/user/repos', options, cb);
|
276 | }
|
277 | }]);
|
278 |
|
279 | return User;
|
280 | }(_Requestable3.default);
|
281 |
|
282 | module.exports = User;
|
283 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["User.js"],"names":["log","User","username","auth","apiBase","__user","endpoint","options","cb","_getOptionsWithDefaults","JSON","stringify","_requestAllPages","__getScopedUrl","_request","since","_dateToISO","before","requestOptions","Requestable","module","exports"],"mappings":"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","file":"User.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';\nimport debug from 'debug';\nconst log = debug('github:user');\n\n/**\n * A User allows scoping of API requests to a particular Github user.\n */\nclass User extends Requestable {\n   /**\n    * Create a User.\n    * @param {string} [username] - the user to use for user-scoped queries\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(username, auth, apiBase) {\n      super(auth, apiBase);\n      this.__user = username;\n   }\n\n   /**\n    * Get the url for the request. (dependent on if we're requesting for the authenticated user or not)\n    * @private\n    * @param {string} endpoint - the endpoint being requested\n    * @return {string} - the resolved endpoint\n    */\n   __getScopedUrl(endpoint) {\n      if (this.__user) {\n         return endpoint ?\n            `/users/${this.__user}/${endpoint}` :\n            `/users/${this.__user}`\n            ;\n\n      } else { // eslint-disable-line\n         switch (endpoint) {\n            case '':\n               return '/user';\n\n            case 'notifications':\n            case 'gists':\n               return `/${endpoint}`;\n\n            default:\n               return `/user/${endpoint}`;\n         }\n      }\n   }\n\n   /**\n    * List the user's repositories\n    * @see https://developer.github.com/v3/repos/#list-user-repositories\n    * @param {Object} [options={}] - any options to refine the search\n    * @param {Requestable.callback} [cb] - will receive the list of repositories\n    * @return {Promise} - the promise for the http request\n    */\n   listRepos(options, cb) {\n      if (typeof options === 'function') {\n         cb = options;\n         options = {};\n      }\n\n      options = this._getOptionsWithDefaults(options);\n\n      log(`Fetching repositories with options: ${JSON.stringify(options)}`);\n      return this._requestAllPages(this.__getScopedUrl('repos'), options, cb);\n   }\n\n   /**\n    * List the orgs that the user belongs to\n    * @see https://developer.github.com/v3/orgs/#list-user-organizations\n    * @param {Requestable.callback} [cb] - will receive the list of organizations\n    * @return {Promise} - the promise for the http request\n    */\n   listOrgs(cb) {\n      return this._request('GET', this.__getScopedUrl('orgs'), null, cb);\n   }\n\n   /**\n    * List followers of a user\n    * @see https://developer.github.com/v3/users/followers/#list-followers-of-a-user\n    * @param {Requestable.callback} [cb] - will receive the list of followers\n    * @return {Promise} - the promise for the http request\n    */\n   listFollowers(cb) {\n      return this._request('GET', this.__getScopedUrl('followers'), null, cb);\n   }\n\n   /**\n    * List users followed by another user\n    * @see https://developer.github.com/v3/users/followers/#list-users-followed-by-another-user\n    * @param {Requestable.callback} [cb] - will receive the list of who a user is following\n    * @return {Promise} - the promise for the http request\n    */\n   listFollowing(cb) {\n      return this._request('GET', this.__getScopedUrl('following'), null, cb);\n   }\n\n   /**\n    * List the user's gists\n    * @see https://developer.github.com/v3/gists/#list-a-users-gists\n    * @param {Requestable.callback} [cb] - will receive the list of gists\n    * @return {Promise} - the promise for the http request\n    */\n   listGists(cb) {\n      return this._request('GET', this.__getScopedUrl('gists'), null, cb);\n   }\n\n   /**\n    * List the user's notifications\n    * @see https://developer.github.com/v3/activity/notifications/#list-your-notifications\n    * @param {Object} [options={}] - any options to refine the search\n    * @param {Requestable.callback} [cb] - will receive the list of repositories\n    * @return {Promise} - the promise for the http request\n    */\n   listNotifications(options, cb) {\n      options = options || {};\n      if (typeof options === 'function') {\n         cb = options;\n         options = {};\n      }\n\n      options.since = this._dateToISO(options.since);\n      options.before = this._dateToISO(options.before);\n\n      return this._request('GET', this.__getScopedUrl('notifications'), options, cb);\n   }\n\n   /**\n    * Show the user's profile\n    * @see https://developer.github.com/v3/users/#get-a-single-user\n    * @param {Requestable.callback} [cb] - will receive the user's information\n    * @return {Promise} - the promise for the http request\n    */\n   getProfile(cb) {\n      return this._request('GET', this.__getScopedUrl(''), null, cb);\n   }\n\n   /**\n    * Gets the list of starred repositories for the user\n    * @see https://developer.github.com/v3/activity/starring/#list-repositories-being-starred\n    * @param {Requestable.callback} [cb] - will receive the list of starred repositories\n    * @return {Promise} - the promise for the http request\n    */\n   listStarredRepos(cb) {\n      let requestOptions = this._getOptionsWithDefaults();\n      return this._requestAllPages(this.__getScopedUrl('starred'), requestOptions, cb);\n   }\n\n   /**\n    * Gets the list of starred gists for the user\n    * @see https://developer.github.com/v3/gists/#list-starred-gists\n    * @param {Object} [options={}] - any options to refine the search\n    * @param {Requestable.callback} [cb] - will receive the list of gists\n    * @return {Promise} - the promise for the http request\n    */\n   listStarredGists(options, cb) {\n      options = options || {};\n      if (typeof options === 'function') {\n         cb = options;\n         options = {};\n      }\n      options.since = this._dateToISO(options.since);\n      return this._request('GET', '/gists/starred', options, cb);\n   }\n\n   /**\n    * List email addresses for a user\n    * @see https://developer.github.com/v3/users/emails/#list-email-addresses-for-a-user\n    * @param {Requestable.callback} [cb] - will receive the list of emails\n    * @return {Promise} - the promise for the http request\n    */\n   getEmails(cb) {\n      return this._request('GET', '/user/emails', null, cb);\n   }\n\n   /**\n    * Have the authenticated user follow this user\n    * @see https://developer.github.com/v3/users/followers/#follow-a-user\n    * @param {string} username - the user to follow\n    * @param {Requestable.callback} [cb] - will receive true if the request succeeds\n    * @return {Promise} - the promise for the http request\n    */\n   follow(username, cb) {\n      return this._request('PUT', `/user/following/${username}`, null, cb);\n   }\n\n   /**\n    * Have the currently authenticated user unfollow this user\n    * @see https://developer.github.com/v3/users/followers/#follow-a-user\n    * @param {string} username - the user to unfollow\n    * @param {Requestable.callback} [cb] - receives true if the request succeeds\n    * @return {Promise} - the promise for the http request\n    */\n   unfollow(username, cb) {\n      return this._request('DELETE', `/user/following/${username}`, null, cb);\n   }\n\n   /**\n    * Create a new repository for the currently authenticated user\n    * @see https://developer.github.com/v3/repos/#create\n    * @param {object} options - the repository definition\n    * @param {Requestable.callback} [cb] - will receive the API response\n    * @return {Promise} - the promise for the http request\n    */\n   createRepo(options, cb) {\n      return this._request('POST', '/user/repos', options, cb);\n   }\n}\n\nmodule.exports = User;\n"]}
|
284 | //# sourceMappingURL=User.js.map
|