UNPKG

28 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 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
26var log = (0, _debug2.default)('github:user');
27
28/**
29 * A User allows scoping of API requests to a particular Github user.
30 */
31
32var 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
282module.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