1 | ;
|
2 |
|
3 | var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
|
4 |
|
5 | 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; }; }();
|
6 |
|
7 | var _Requestable2 = require('./Requestable');
|
8 |
|
9 | var _Requestable3 = _interopRequireDefault(_Requestable2);
|
10 |
|
11 | var _utf = require('utf8');
|
12 |
|
13 | var _utf2 = _interopRequireDefault(_utf);
|
14 |
|
15 | var _jsBase = require('js-base64');
|
16 |
|
17 | var _debug = require('debug');
|
18 |
|
19 | var _debug2 = _interopRequireDefault(_debug);
|
20 |
|
21 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
22 |
|
23 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
24 |
|
25 | 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; }
|
26 |
|
27 | 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; } /**
|
28 | * @file
|
29 | * @copyright 2013 Michael Aufreiter (Development Seed) and 2016 Yahoo Inc.
|
30 | * @license Licensed under {@link https://spdx.org/licenses/BSD-3-Clause-Clear.html BSD-3-Clause-Clear}.
|
31 | * Github.js is freely distributable.
|
32 | */
|
33 |
|
34 | var log = (0, _debug2.default)('github:repository');
|
35 |
|
36 | /**
|
37 | * Repository encapsulates the functionality to create, query, and modify files.
|
38 | */
|
39 |
|
40 | var Repository = function (_Requestable) {
|
41 | _inherits(Repository, _Requestable);
|
42 |
|
43 | /**
|
44 | * Create a Repository.
|
45 | * @param {string} fullname - the full name of the repository
|
46 | * @param {Requestable.auth} [auth] - information required to authenticate to Github
|
47 | * @param {string} [apiBase=https://api.github.com] - the base Github API URL
|
48 | */
|
49 | function Repository(fullname, auth, apiBase) {
|
50 | _classCallCheck(this, Repository);
|
51 |
|
52 | var _this = _possibleConstructorReturn(this, (Repository.__proto__ || Object.getPrototypeOf(Repository)).call(this, auth, apiBase));
|
53 |
|
54 | _this.__fullname = fullname;
|
55 | _this.__currentTree = {
|
56 | branch: null,
|
57 | sha: null
|
58 | };
|
59 | return _this;
|
60 | }
|
61 |
|
62 | /**
|
63 | * Get a reference
|
64 | * @see https://developer.github.com/v3/git/refs/#get-a-reference
|
65 | * @param {string} ref - the reference to get
|
66 | * @param {Requestable.callback} [cb] - will receive the reference's refSpec or a list of refSpecs that match `ref`
|
67 | * @return {Promise} - the promise for the http request
|
68 | */
|
69 |
|
70 |
|
71 | _createClass(Repository, [{
|
72 | key: 'getRef',
|
73 | value: function getRef(ref, cb) {
|
74 | return this._request('GET', '/repos/' + this.__fullname + '/git/refs/' + ref, null, cb);
|
75 | }
|
76 |
|
77 | /**
|
78 | * Create a reference
|
79 | * @see https://developer.github.com/v3/git/refs/#create-a-reference
|
80 | * @param {Object} options - the object describing the ref
|
81 | * @param {Requestable.callback} [cb] - will receive the ref
|
82 | * @return {Promise} - the promise for the http request
|
83 | */
|
84 |
|
85 | }, {
|
86 | key: 'createRef',
|
87 | value: function createRef(options, cb) {
|
88 | return this._request('POST', '/repos/' + this.__fullname + '/git/refs', options, cb);
|
89 | }
|
90 |
|
91 | /**
|
92 | * Delete a reference
|
93 | * @see https://developer.github.com/v3/git/refs/#delete-a-reference
|
94 | * @param {string} ref - the name of the ref to delte
|
95 | * @param {Requestable.callback} [cb] - will receive true if the request is successful
|
96 | * @return {Promise} - the promise for the http request
|
97 | */
|
98 |
|
99 | }, {
|
100 | key: 'deleteRef',
|
101 | value: function deleteRef(ref, cb) {
|
102 | return this._request('DELETE', '/repos/' + this.__fullname + '/git/refs/' + ref, null, cb);
|
103 | }
|
104 |
|
105 | /**
|
106 | * Delete a repository
|
107 | * @see https://developer.github.com/v3/repos/#delete-a-repository
|
108 | * @param {Requestable.callback} [cb] - will receive true if the request is successful
|
109 | * @return {Promise} - the promise for the http request
|
110 | */
|
111 |
|
112 | }, {
|
113 | key: 'deleteRepo',
|
114 | value: function deleteRepo(cb) {
|
115 | return this._request('DELETE', '/repos/' + this.__fullname, null, cb);
|
116 | }
|
117 |
|
118 | /**
|
119 | * List the tags on a repository
|
120 | * @see https://developer.github.com/v3/repos/#list-tags
|
121 | * @param {Requestable.callback} [cb] - will receive the tag data
|
122 | * @return {Promise} - the promise for the http request
|
123 | */
|
124 |
|
125 | }, {
|
126 | key: 'listTags',
|
127 | value: function listTags(cb) {
|
128 | return this._request('GET', '/repos/' + this.__fullname + '/tags', null, cb);
|
129 | }
|
130 |
|
131 | /**
|
132 | * List the open pull requests on the repository
|
133 | * @see https://developer.github.com/v3/pulls/#list-pull-requests
|
134 | * @param {Object} options - options to filter the search
|
135 | * @param {Requestable.callback} [cb] - will receive the list of PRs
|
136 | * @return {Promise} - the promise for the http request
|
137 | */
|
138 |
|
139 | }, {
|
140 | key: 'listPullRequests',
|
141 | value: function listPullRequests(options, cb) {
|
142 | options = options || {};
|
143 | return this._request('GET', '/repos/' + this.__fullname + '/pulls', options, cb);
|
144 | }
|
145 |
|
146 | /**
|
147 | * Get information about a specific pull request
|
148 | * @see https://developer.github.com/v3/pulls/#get-a-single-pull-request
|
149 | * @param {number} number - the PR you wish to fetch
|
150 | * @param {Requestable.callback} [cb] - will receive the PR from the API
|
151 | * @return {Promise} - the promise for the http request
|
152 | */
|
153 |
|
154 | }, {
|
155 | key: 'getPullRequest',
|
156 | value: function getPullRequest(number, cb) {
|
157 | return this._request('GET', '/repos/' + this.__fullname + '/pulls/' + number, null, cb);
|
158 | }
|
159 |
|
160 | /**
|
161 | * List the files of a specific pull request
|
162 | * @see https://developer.github.com/v3/pulls/#list-pull-requests-files
|
163 | * @param {number|string} number - the PR you wish to fetch
|
164 | * @param {Requestable.callback} [cb] - will receive the list of files from the API
|
165 | * @return {Promise} - the promise for the http request
|
166 | */
|
167 |
|
168 | }, {
|
169 | key: 'listPullRequestFiles',
|
170 | value: function listPullRequestFiles(number, cb) {
|
171 | return this._request('GET', '/repos/' + this.__fullname + '/pulls/' + number + '/files', null, cb);
|
172 | }
|
173 |
|
174 | /**
|
175 | * Compare two branches/commits/repositories
|
176 | * @see https://developer.github.com/v3/repos/commits/#compare-two-commits
|
177 | * @param {string} base - the base commit
|
178 | * @param {string} head - the head commit
|
179 | * @param {Requestable.callback} cb - will receive the comparison
|
180 | * @return {Promise} - the promise for the http request
|
181 | */
|
182 |
|
183 | }, {
|
184 | key: 'compareBranches',
|
185 | value: function compareBranches(base, head, cb) {
|
186 | return this._request('GET', '/repos/' + this.__fullname + '/compare/' + base + '...' + head, null, cb);
|
187 | }
|
188 |
|
189 | /**
|
190 | * List all the branches for the repository
|
191 | * @see https://developer.github.com/v3/repos/#list-branches
|
192 | * @param {Requestable.callback} cb - will receive the list of branches
|
193 | * @return {Promise} - the promise for the http request
|
194 | */
|
195 |
|
196 | }, {
|
197 | key: 'listBranches',
|
198 | value: function listBranches(cb) {
|
199 | return this._request('GET', '/repos/' + this.__fullname + '/branches', null, cb);
|
200 | }
|
201 |
|
202 | /**
|
203 | * Get a raw blob from the repository
|
204 | * @see https://developer.github.com/v3/git/blobs/#get-a-blob
|
205 | * @param {string} sha - the sha of the blob to fetch
|
206 | * @param {Requestable.callback} cb - will receive the blob from the API
|
207 | * @return {Promise} - the promise for the http request
|
208 | */
|
209 |
|
210 | }, {
|
211 | key: 'getBlob',
|
212 | value: function getBlob(sha, cb) {
|
213 | return this._request('GET', '/repos/' + this.__fullname + '/git/blobs/' + sha, null, cb, 'raw');
|
214 | }
|
215 |
|
216 | /**
|
217 | * Get a single branch
|
218 | * @see https://developer.github.com/v3/repos/branches/#get-branch
|
219 | * @param {string} branch - the name of the branch to fetch
|
220 | * @param {Requestable.callback} cb - will receive the branch from the API
|
221 | * @returns {Promise} - the promise for the http request
|
222 | */
|
223 |
|
224 | }, {
|
225 | key: 'getBranch',
|
226 | value: function getBranch(branch, cb) {
|
227 | return this._request('GET', '/repos/' + this.__fullname + '/branches/' + branch, null, cb);
|
228 | }
|
229 |
|
230 | /**
|
231 | * Get a commit from the repository
|
232 | * @see https://developer.github.com/v3/repos/commits/#get-a-single-commit
|
233 | * @param {string} sha - the sha for the commit to fetch
|
234 | * @param {Requestable.callback} cb - will receive the commit data
|
235 | * @return {Promise} - the promise for the http request
|
236 | */
|
237 |
|
238 | }, {
|
239 | key: 'getCommit',
|
240 | value: function getCommit(sha, cb) {
|
241 | return this._request('GET', '/repos/' + this.__fullname + '/git/commits/' + sha, null, cb);
|
242 | }
|
243 |
|
244 | /**
|
245 | * List the commits on a repository, optionally filtering by path, author or time range
|
246 | * @see https://developer.github.com/v3/repos/commits/#list-commits-on-a-repository
|
247 | * @param {Object} [options] - the filtering options for commits
|
248 | * @param {string} [options.sha] - the SHA or branch to start from
|
249 | * @param {string} [options.path] - the path to search on
|
250 | * @param {string} [options.author] - the commit author
|
251 | * @param {(Date|string)} [options.since] - only commits after this date will be returned
|
252 | * @param {(Date|string)} [options.until] - only commits before this date will be returned
|
253 | * @param {Requestable.callback} cb - will receive the list of commits found matching the criteria
|
254 | * @return {Promise} - the promise for the http request
|
255 | */
|
256 |
|
257 | }, {
|
258 | key: 'listCommits',
|
259 | value: function listCommits(options, cb) {
|
260 | options = options || {};
|
261 | if (typeof options === 'function') {
|
262 | cb = options;
|
263 | options = {};
|
264 | }
|
265 | options.since = this._dateToISO(options.since);
|
266 | options.until = this._dateToISO(options.until);
|
267 |
|
268 | return this._request('GET', '/repos/' + this.__fullname + '/commits', options, cb);
|
269 | }
|
270 |
|
271 | /**
|
272 | * List the commits on a pull request
|
273 | * @see https://developer.github.com/v3/repos/commits/#list-commits-on-a-repository
|
274 | * @param {number|string} number - the number of the pull request to list the commits
|
275 | * @param {Object} [options] - the filtering options for commits
|
276 | * @param {Requestable.callback} [cb] - will receive the commits information
|
277 | * @return {Promise} - the promise for the http request
|
278 | */
|
279 |
|
280 | }, {
|
281 | key: 'listCommitsOnPR',
|
282 | value: function listCommitsOnPR(number, options, cb) {
|
283 | options = options || {};
|
284 | if (typeof options === 'function') {
|
285 | cb = options;
|
286 | options = {};
|
287 | }
|
288 | return this._request('GET', '/repos/' + this.__fullname + '/pulls/' + number + '/commits', options, cb);
|
289 | }
|
290 |
|
291 | /**
|
292 | * Gets a single commit information for a repository
|
293 | * @see https://developer.github.com/v3/repos/commits/#get-a-single-commit
|
294 | * @param {string} ref - the reference for the commit-ish
|
295 | * @param {Requestable.callback} cb - will receive the commit information
|
296 | * @return {Promise} - the promise for the http request
|
297 | */
|
298 |
|
299 | }, {
|
300 | key: 'getSingleCommit',
|
301 | value: function getSingleCommit(ref, cb) {
|
302 | ref = ref || '';
|
303 | return this._request('GET', '/repos/' + this.__fullname + '/commits/' + ref, null, cb);
|
304 | }
|
305 |
|
306 | /**
|
307 | * Get tha sha for a particular object in the repository. This is a convenience function
|
308 | * @see https://developer.github.com/v3/repos/contents/#get-contents
|
309 | * @param {string} [branch] - the branch to look in, or the repository's default branch if omitted
|
310 | * @param {string} path - the path of the file or directory
|
311 | * @param {Requestable.callback} cb - will receive a description of the requested object, including a `SHA` property
|
312 | * @return {Promise} - the promise for the http request
|
313 | */
|
314 |
|
315 | }, {
|
316 | key: 'getSha',
|
317 | value: function getSha(branch, path, cb) {
|
318 | branch = branch ? '?ref=' + branch : '';
|
319 | return this._request('GET', '/repos/' + this.__fullname + '/contents/' + path + branch, null, cb);
|
320 | }
|
321 |
|
322 | /**
|
323 | * List the commit statuses for a particular sha, branch, or tag
|
324 | * @see https://developer.github.com/v3/repos/statuses/#list-statuses-for-a-specific-ref
|
325 | * @param {string} sha - the sha, branch, or tag to get statuses for
|
326 | * @param {Requestable.callback} cb - will receive the list of statuses
|
327 | * @return {Promise} - the promise for the http request
|
328 | */
|
329 |
|
330 | }, {
|
331 | key: 'listStatuses',
|
332 | value: function listStatuses(sha, cb) {
|
333 | return this._request('GET', '/repos/' + this.__fullname + '/commits/' + sha + '/statuses', null, cb);
|
334 | }
|
335 |
|
336 | /**
|
337 | * Get the combined view of commit statuses for a particular sha, branch, or tag
|
338 | * @see https://developer.github.com/v3/repos/statuses/#get-the-combined-status-for-a-specific-ref
|
339 | * @param {string} sha - the sha, branch, or tag to get the combined status for
|
340 | * @param {Requestable.callback} cb - will receive the combined status
|
341 | * @returns {Promise} - the promise for the http request
|
342 | */
|
343 |
|
344 | }, {
|
345 | key: 'getCombinedStatus',
|
346 | value: function getCombinedStatus(sha, cb) {
|
347 | return this._request('GET', '/repos/' + this.__fullname + '/commits/' + sha + '/status', null, cb);
|
348 | }
|
349 |
|
350 | /**
|
351 | * Get a description of a git tree
|
352 | * @see https://developer.github.com/v3/git/trees/#get-a-tree
|
353 | * @param {string} treeSHA - the SHA of the tree to fetch
|
354 | * @param {Requestable.callback} cb - will receive the callback data
|
355 | * @return {Promise} - the promise for the http request
|
356 | */
|
357 |
|
358 | }, {
|
359 | key: 'getTree',
|
360 | value: function getTree(treeSHA, cb) {
|
361 | return this._request('GET', '/repos/' + this.__fullname + '/git/trees/' + treeSHA, null, cb);
|
362 | }
|
363 |
|
364 | /**
|
365 | * Create a blob
|
366 | * @see https://developer.github.com/v3/git/blobs/#create-a-blob
|
367 | * @param {(string|Buffer|Blob)} content - the content to add to the repository
|
368 | * @param {Requestable.callback} cb - will receive the details of the created blob
|
369 | * @return {Promise} - the promise for the http request
|
370 | */
|
371 |
|
372 | }, {
|
373 | key: 'createBlob',
|
374 | value: function createBlob(content, cb) {
|
375 | var postBody = this._getContentObject(content);
|
376 |
|
377 | log('sending content', postBody);
|
378 | return this._request('POST', '/repos/' + this.__fullname + '/git/blobs', postBody, cb);
|
379 | }
|
380 |
|
381 | /**
|
382 | * Get the object that represents the provided content
|
383 | * @param {string|Buffer|Blob} content - the content to send to the server
|
384 | * @return {Object} the representation of `content` for the GitHub API
|
385 | */
|
386 |
|
387 | }, {
|
388 | key: '_getContentObject',
|
389 | value: function _getContentObject(content) {
|
390 | if (typeof content === 'string') {
|
391 | log('contet is a string');
|
392 | return {
|
393 | content: _utf2.default.encode(content),
|
394 | encoding: 'utf-8'
|
395 | };
|
396 | } else if (typeof Buffer !== 'undefined' && content instanceof Buffer) {
|
397 | log('We appear to be in Node');
|
398 | return {
|
399 | content: content.toString('base64'),
|
400 | encoding: 'base64'
|
401 | };
|
402 | } else if (typeof Blob !== 'undefined' && content instanceof Blob) {
|
403 | log('We appear to be in the browser');
|
404 | return {
|
405 | content: _jsBase.Base64.encode(content),
|
406 | encoding: 'base64'
|
407 | };
|
408 | } else {
|
409 | // eslint-disable-line
|
410 | log('Not sure what this content is: ' + (typeof content === 'undefined' ? 'undefined' : _typeof(content)) + ', ' + JSON.stringify(content));
|
411 | throw new Error('Unknown content passed to postBlob. Must be string or Buffer (node) or Blob (web)');
|
412 | }
|
413 | }
|
414 |
|
415 | /**
|
416 | * Update a tree in Git
|
417 | * @see https://developer.github.com/v3/git/trees/#create-a-tree
|
418 | * @param {string} baseTreeSHA - the SHA of the tree to update
|
419 | * @param {string} path - the path for the new file
|
420 | * @param {string} blobSHA - the SHA for the blob to put at `path`
|
421 | * @param {Requestable.callback} cb - will receive the new tree that is created
|
422 | * @return {Promise} - the promise for the http request
|
423 | * @deprecated use {@link Repository#createTree} instead
|
424 | */
|
425 |
|
426 | }, {
|
427 | key: 'updateTree',
|
428 | value: function updateTree(baseTreeSHA, path, blobSHA, cb) {
|
429 | var newTree = {
|
430 | base_tree: baseTreeSHA, // eslint-disable-line
|
431 | tree: [{
|
432 | path: path,
|
433 | sha: blobSHA,
|
434 | mode: '100644',
|
435 | type: 'blob'
|
436 | }]
|
437 | };
|
438 |
|
439 | return this._request('POST', '/repos/' + this.__fullname + '/git/trees', newTree, cb);
|
440 | }
|
441 |
|
442 | /**
|
443 | * Create a new tree in git
|
444 | * @see https://developer.github.com/v3/git/trees/#create-a-tree
|
445 | * @param {Object} tree - the tree to create
|
446 | * @param {string} baseSHA - the root sha of the tree
|
447 | * @param {Requestable.callback} cb - will receive the new tree that is created
|
448 | * @return {Promise} - the promise for the http request
|
449 | */
|
450 |
|
451 | }, {
|
452 | key: 'createTree',
|
453 | value: function createTree(tree, baseSHA, cb) {
|
454 | return this._request('POST', '/repos/' + this.__fullname + '/git/trees', {
|
455 | tree: tree,
|
456 | base_tree: baseSHA // eslint-disable-line camelcase
|
457 | }, cb);
|
458 | }
|
459 |
|
460 | /**
|
461 | * Add a commit to the repository
|
462 | * @see https://developer.github.com/v3/git/commits/#create-a-commit
|
463 | * @param {string} parent - the SHA of the parent commit
|
464 | * @param {string} tree - the SHA of the tree for this commit
|
465 | * @param {string} message - the commit message
|
466 | * @param {Object} [options] - commit options
|
467 | * @param {Object} [options.author] - the author of the commit
|
468 | * @param {Object} [options.commiter] - the committer
|
469 | * @param {Requestable.callback} cb - will receive the commit that is created
|
470 | * @return {Promise} - the promise for the http request
|
471 | */
|
472 |
|
473 | }, {
|
474 | key: 'commit',
|
475 | value: function commit(parent, tree, message, options, cb) {
|
476 | var _this2 = this;
|
477 |
|
478 | if (typeof options === 'function') {
|
479 | cb = options;
|
480 | options = {};
|
481 | }
|
482 |
|
483 | var data = {
|
484 | message: message,
|
485 | tree: tree,
|
486 | parents: [parent]
|
487 | };
|
488 |
|
489 | data = Object.assign({}, options, data);
|
490 |
|
491 | return this._request('POST', '/repos/' + this.__fullname + '/git/commits', data, cb).then(function (response) {
|
492 | _this2.__currentTree.sha = response.data.sha; // Update latest commit
|
493 | return response;
|
494 | });
|
495 | }
|
496 |
|
497 | /**
|
498 | * Update a ref
|
499 | * @see https://developer.github.com/v3/git/refs/#update-a-reference
|
500 | * @param {string} ref - the ref to update
|
501 | * @param {string} commitSHA - the SHA to point the reference to
|
502 | * @param {boolean} force - indicates whether to force or ensure a fast-forward update
|
503 | * @param {Requestable.callback} cb - will receive the updated ref back
|
504 | * @return {Promise} - the promise for the http request
|
505 | */
|
506 |
|
507 | }, {
|
508 | key: 'updateHead',
|
509 | value: function updateHead(ref, commitSHA, force, cb) {
|
510 | return this._request('PATCH', '/repos/' + this.__fullname + '/git/refs/' + ref, {
|
511 | sha: commitSHA,
|
512 | force: force
|
513 | }, cb);
|
514 | }
|
515 |
|
516 | /**
|
517 | * Update commit status
|
518 | * @see https://developer.github.com/v3/repos/statuses/
|
519 | * @param {string} commitSHA - the SHA of the commit that should be updated
|
520 | * @param {object} options - Commit status parameters
|
521 | * @param {string} options.state - The state of the status. Can be one of: pending, success, error, or failure.
|
522 | * @param {string} [options.target_url] - The target URL to associate with this status.
|
523 | * @param {string} [options.description] - A short description of the status.
|
524 | * @param {string} [options.context] - A string label to differentiate this status among CI systems.
|
525 | * @param {Requestable.callback} cb - will receive the updated commit back
|
526 | * @return {Promise} - the promise for the http request
|
527 | */
|
528 |
|
529 | }, {
|
530 | key: 'updateStatus',
|
531 | value: function updateStatus(commitSHA, options, cb) {
|
532 | return this._request('POST', '/repos/' + this.__fullname + '/statuses/' + commitSHA, options, cb);
|
533 | }
|
534 |
|
535 | /**
|
536 | * Update repository information
|
537 | * @see https://developer.github.com/v3/repos/#edit
|
538 | * @param {object} options - New parameters that will be set to the repository
|
539 | * @param {string} options.name - Name of the repository
|
540 | * @param {string} [options.description] - A short description of the repository
|
541 | * @param {string} [options.homepage] - A URL with more information about the repository
|
542 | * @param {boolean} [options.private] - Either true to make the repository private, or false to make it public.
|
543 | * @param {boolean} [options.has_issues] - Either true to enable issues for this repository, false to disable them.
|
544 | * @param {boolean} [options.has_wiki] - Either true to enable the wiki for this repository, false to disable it.
|
545 | * @param {boolean} [options.has_downloads] - Either true to enable downloads, false to disable them.
|
546 | * @param {string} [options.default_branch] - Updates the default branch for this repository.
|
547 | * @param {Requestable.callback} cb - will receive the updated repository back
|
548 | * @return {Promise} - the promise for the http request
|
549 | */
|
550 |
|
551 | }, {
|
552 | key: 'updateRepository',
|
553 | value: function updateRepository(options, cb) {
|
554 | return this._request('PATCH', '/repos/' + this.__fullname, options, cb);
|
555 | }
|
556 |
|
557 | /**
|
558 | * Get information about the repository
|
559 | * @see https://developer.github.com/v3/repos/#get
|
560 | * @param {Requestable.callback} cb - will receive the information about the repository
|
561 | * @return {Promise} - the promise for the http request
|
562 | */
|
563 |
|
564 | }, {
|
565 | key: 'getDetails',
|
566 | value: function getDetails(cb) {
|
567 | return this._request('GET', '/repos/' + this.__fullname, null, cb);
|
568 | }
|
569 |
|
570 | /**
|
571 | * List the contributors to the repository
|
572 | * @see https://developer.github.com/v3/repos/#list-contributors
|
573 | * @param {Requestable.callback} cb - will receive the list of contributors
|
574 | * @return {Promise} - the promise for the http request
|
575 | */
|
576 |
|
577 | }, {
|
578 | key: 'getContributors',
|
579 | value: function getContributors(cb) {
|
580 | return this._request('GET', '/repos/' + this.__fullname + '/contributors', null, cb);
|
581 | }
|
582 |
|
583 | /**
|
584 | * List the contributor stats to the repository
|
585 | * @see https://developer.github.com/v3/repos/#list-contributors
|
586 | * @param {Requestable.callback} cb - will receive the list of contributors
|
587 | * @return {Promise} - the promise for the http request
|
588 | */
|
589 |
|
590 | }, {
|
591 | key: 'getContributorStats',
|
592 | value: function getContributorStats(cb) {
|
593 | return this._request('GET', '/repos/' + this.__fullname + '/stats/contributors', null, cb);
|
594 | }
|
595 |
|
596 | /**
|
597 | * List the users who are collaborators on the repository. The currently authenticated user must have
|
598 | * push access to use this method
|
599 | * @see https://developer.github.com/v3/repos/collaborators/#list-collaborators
|
600 | * @param {Requestable.callback} cb - will receive the list of collaborators
|
601 | * @return {Promise} - the promise for the http request
|
602 | */
|
603 |
|
604 | }, {
|
605 | key: 'getCollaborators',
|
606 | value: function getCollaborators(cb) {
|
607 | return this._request('GET', '/repos/' + this.__fullname + '/collaborators', null, cb);
|
608 | }
|
609 |
|
610 | /**
|
611 | * Check if a user is a collaborator on the repository
|
612 | * @see https://developer.github.com/v3/repos/collaborators/#check-if-a-user-is-a-collaborator
|
613 | * @param {string} username - the user to check
|
614 | * @param {Requestable.callback} cb - will receive true if the user is a collaborator and false if they are not
|
615 | * @return {Promise} - the promise for the http request {Boolean} [description]
|
616 | */
|
617 |
|
618 | }, {
|
619 | key: 'isCollaborator',
|
620 | value: function isCollaborator(username, cb) {
|
621 | return this._request('GET', '/repos/' + this.__fullname + '/collaborators/' + username, null, cb);
|
622 | }
|
623 |
|
624 | /**
|
625 | * Get the contents of a repository
|
626 | * @see https://developer.github.com/v3/repos/contents/#get-contents
|
627 | * @param {string} ref - the ref to check
|
628 | * @param {string} path - the path containing the content to fetch
|
629 | * @param {boolean} raw - `true` if the results should be returned raw instead of GitHub's normalized format
|
630 | * @param {Requestable.callback} cb - will receive the fetched data
|
631 | * @return {Promise} - the promise for the http request
|
632 | */
|
633 |
|
634 | }, {
|
635 | key: 'getContents',
|
636 | value: function getContents(ref, path, raw, cb) {
|
637 | path = path ? '' + encodeURI(path) : '';
|
638 | return this._request('GET', '/repos/' + this.__fullname + '/contents/' + path, {
|
639 | ref: ref
|
640 | }, cb, raw);
|
641 | }
|
642 |
|
643 | /**
|
644 | * Get the README of a repository
|
645 | * @see https://developer.github.com/v3/repos/contents/#get-the-readme
|
646 | * @param {string} ref - the ref to check
|
647 | * @param {boolean} raw - `true` if the results should be returned raw instead of GitHub's normalized format
|
648 | * @param {Requestable.callback} cb - will receive the fetched data
|
649 | * @return {Promise} - the promise for the http request
|
650 | */
|
651 |
|
652 | }, {
|
653 | key: 'getReadme',
|
654 | value: function getReadme(ref, raw, cb) {
|
655 | return this._request('GET', '/repos/' + this.__fullname + '/readme', {
|
656 | ref: ref
|
657 | }, cb, raw);
|
658 | }
|
659 |
|
660 | /**
|
661 | * Fork a repository
|
662 | * @see https://developer.github.com/v3/repos/forks/#create-a-fork
|
663 | * @param {Requestable.callback} cb - will receive the information about the newly created fork
|
664 | * @return {Promise} - the promise for the http request
|
665 | */
|
666 |
|
667 | }, {
|
668 | key: 'fork',
|
669 | value: function fork(cb) {
|
670 | return this._request('POST', '/repos/' + this.__fullname + '/forks', null, cb);
|
671 | }
|
672 |
|
673 | /**
|
674 | * Fork a repository to an organization
|
675 | * @see https://developer.github.com/v3/repos/forks/#create-a-fork
|
676 | * @param {String} org - organization where you'd like to create the fork.
|
677 | * @param {Requestable.callback} cb - will receive the information about the newly created fork
|
678 | * @return {Promise} - the promise for the http request
|
679 | *
|
680 | */
|
681 |
|
682 | }, {
|
683 | key: 'forkToOrg',
|
684 | value: function forkToOrg(org, cb) {
|
685 | return this._request('POST', '/repos/' + this.__fullname + '/forks?organization=' + org, null, cb);
|
686 | }
|
687 |
|
688 | /**
|
689 | * List a repository's forks
|
690 | * @see https://developer.github.com/v3/repos/forks/#list-forks
|
691 | * @param {Requestable.callback} cb - will receive the list of repositories forked from this one
|
692 | * @return {Promise} - the promise for the http request
|
693 | */
|
694 |
|
695 | }, {
|
696 | key: 'listForks',
|
697 | value: function listForks(cb) {
|
698 | return this._request('GET', '/repos/' + this.__fullname + '/forks', null, cb);
|
699 | }
|
700 |
|
701 | /**
|
702 | * Create a new branch from an existing branch.
|
703 | * @param {string} [oldBranch=master] - the name of the existing branch
|
704 | * @param {string} newBranch - the name of the new branch
|
705 | * @param {Requestable.callback} cb - will receive the commit data for the head of the new branch
|
706 | * @return {Promise} - the promise for the http request
|
707 | */
|
708 |
|
709 | }, {
|
710 | key: 'createBranch',
|
711 | value: function createBranch(oldBranch, newBranch, cb) {
|
712 | var _this3 = this;
|
713 |
|
714 | if (typeof newBranch === 'function') {
|
715 | cb = newBranch;
|
716 | newBranch = oldBranch;
|
717 | oldBranch = 'master';
|
718 | }
|
719 |
|
720 | return this.getRef('heads/' + oldBranch).then(function (response) {
|
721 | var sha = response.data.object.sha;
|
722 | return _this3.createRef({
|
723 | sha: sha,
|
724 | ref: 'refs/heads/' + newBranch
|
725 | }, cb);
|
726 | });
|
727 | }
|
728 |
|
729 | /**
|
730 | * Create a new pull request
|
731 | * @see https://developer.github.com/v3/pulls/#create-a-pull-request
|
732 | * @param {Object} options - the pull request description
|
733 | * @param {Requestable.callback} cb - will receive the new pull request
|
734 | * @return {Promise} - the promise for the http request
|
735 | */
|
736 |
|
737 | }, {
|
738 | key: 'createPullRequest',
|
739 | value: function createPullRequest(options, cb) {
|
740 | return this._request('POST', '/repos/' + this.__fullname + '/pulls', options, cb);
|
741 | }
|
742 |
|
743 | /**
|
744 | * Update a pull request
|
745 | * @see https://developer.github.com/v3/pulls/#update-a-pull-request
|
746 | * @param {number|string} number - the number of the pull request to update
|
747 | * @param {Object} options - the pull request description
|
748 | * @param {Requestable.callback} [cb] - will receive the pull request information
|
749 | * @return {Promise} - the promise for the http request
|
750 | */
|
751 |
|
752 | }, {
|
753 | key: 'updatePullRequest',
|
754 | value: function updatePullRequest(number, options, cb) {
|
755 | return this._request('PATCH', '/repos/' + this.__fullname + '/pulls/' + number, options, cb);
|
756 | }
|
757 |
|
758 | /**
|
759 | * List the hooks for the repository
|
760 | * @see https://developer.github.com/v3/repos/hooks/#list-hooks
|
761 | * @param {Requestable.callback} cb - will receive the list of hooks
|
762 | * @return {Promise} - the promise for the http request
|
763 | */
|
764 |
|
765 | }, {
|
766 | key: 'listHooks',
|
767 | value: function listHooks(cb) {
|
768 | return this._request('GET', '/repos/' + this.__fullname + '/hooks', null, cb);
|
769 | }
|
770 |
|
771 | /**
|
772 | * Get a hook for the repository
|
773 | * @see https://developer.github.com/v3/repos/hooks/#get-single-hook
|
774 | * @param {number} id - the id of the webook
|
775 | * @param {Requestable.callback} cb - will receive the details of the webook
|
776 | * @return {Promise} - the promise for the http request
|
777 | */
|
778 |
|
779 | }, {
|
780 | key: 'getHook',
|
781 | value: function getHook(id, cb) {
|
782 | return this._request('GET', '/repos/' + this.__fullname + '/hooks/' + id, null, cb);
|
783 | }
|
784 |
|
785 | /**
|
786 | * Add a new hook to the repository
|
787 | * @see https://developer.github.com/v3/repos/hooks/#create-a-hook
|
788 | * @param {Object} options - the configuration describing the new hook
|
789 | * @param {Requestable.callback} cb - will receive the new webhook
|
790 | * @return {Promise} - the promise for the http request
|
791 | */
|
792 |
|
793 | }, {
|
794 | key: 'createHook',
|
795 | value: function createHook(options, cb) {
|
796 | return this._request('POST', '/repos/' + this.__fullname + '/hooks', options, cb);
|
797 | }
|
798 |
|
799 | /**
|
800 | * Edit an existing webhook
|
801 | * @see https://developer.github.com/v3/repos/hooks/#edit-a-hook
|
802 | * @param {number} id - the id of the webhook
|
803 | * @param {Object} options - the new description of the webhook
|
804 | * @param {Requestable.callback} cb - will receive the updated webhook
|
805 | * @return {Promise} - the promise for the http request
|
806 | */
|
807 |
|
808 | }, {
|
809 | key: 'updateHook',
|
810 | value: function updateHook(id, options, cb) {
|
811 | return this._request('PATCH', '/repos/' + this.__fullname + '/hooks/' + id, options, cb);
|
812 | }
|
813 |
|
814 | /**
|
815 | * Delete a webhook
|
816 | * @see https://developer.github.com/v3/repos/hooks/#delete-a-hook
|
817 | * @param {number} id - the id of the webhook to be deleted
|
818 | * @param {Requestable.callback} cb - will receive true if the call is successful
|
819 | * @return {Promise} - the promise for the http request
|
820 | */
|
821 |
|
822 | }, {
|
823 | key: 'deleteHook',
|
824 | value: function deleteHook(id, cb) {
|
825 | return this._request('DELETE', '/repos/' + this.__fullname + '/hooks/' + id, null, cb);
|
826 | }
|
827 |
|
828 | /**
|
829 | * List the deploy keys for the repository
|
830 | * @see https://developer.github.com/v3/repos/keys/#list-deploy-keys
|
831 | * @param {Requestable.callback} cb - will receive the list of deploy keys
|
832 | * @return {Promise} - the promise for the http request
|
833 | */
|
834 |
|
835 | }, {
|
836 | key: 'listKeys',
|
837 | value: function listKeys(cb) {
|
838 | return this._request('GET', '/repos/' + this.__fullname + '/keys', null, cb);
|
839 | }
|
840 |
|
841 | /**
|
842 | * Get a deploy key for the repository
|
843 | * @see https://developer.github.com/v3/repos/keys/#get-a-deploy-key
|
844 | * @param {number} id - the id of the deploy key
|
845 | * @param {Requestable.callback} cb - will receive the details of the deploy key
|
846 | * @return {Promise} - the promise for the http request
|
847 | */
|
848 |
|
849 | }, {
|
850 | key: 'getKey',
|
851 | value: function getKey(id, cb) {
|
852 | return this._request('GET', '/repos/' + this.__fullname + '/keys/' + id, null, cb);
|
853 | }
|
854 |
|
855 | /**
|
856 | * Add a new deploy key to the repository
|
857 | * @see https://developer.github.com/v3/repos/keys/#add-a-new-deploy-key
|
858 | * @param {Object} options - the configuration describing the new deploy key
|
859 | * @param {Requestable.callback} cb - will receive the new deploy key
|
860 | * @return {Promise} - the promise for the http request
|
861 | */
|
862 |
|
863 | }, {
|
864 | key: 'createKey',
|
865 | value: function createKey(options, cb) {
|
866 | return this._request('POST', '/repos/' + this.__fullname + '/keys', options, cb);
|
867 | }
|
868 |
|
869 | /**
|
870 | * Delete a deploy key
|
871 | * @see https://developer.github.com/v3/repos/keys/#remove-a-deploy-key
|
872 | * @param {number} id - the id of the deploy key to be deleted
|
873 | * @param {Requestable.callback} cb - will receive true if the call is successful
|
874 | * @return {Promise} - the promise for the http request
|
875 | */
|
876 |
|
877 | }, {
|
878 | key: 'deleteKey',
|
879 | value: function deleteKey(id, cb) {
|
880 | return this._request('DELETE', '/repos/' + this.__fullname + '/keys/' + id, null, cb);
|
881 | }
|
882 |
|
883 | /**
|
884 | * Delete a file from a branch
|
885 | * @see https://developer.github.com/v3/repos/contents/#delete-a-file
|
886 | * @param {string} branch - the branch to delete from, or the default branch if not specified
|
887 | * @param {string} path - the path of the file to remove
|
888 | * @param {Requestable.callback} cb - will receive the commit in which the delete occurred
|
889 | * @return {Promise} - the promise for the http request
|
890 | */
|
891 |
|
892 | }, {
|
893 | key: 'deleteFile',
|
894 | value: function deleteFile(branch, path, cb) {
|
895 | var _this4 = this;
|
896 |
|
897 | return this.getSha(branch, path).then(function (response) {
|
898 | var deleteCommit = {
|
899 | message: 'Delete the file at \'' + path + '\'',
|
900 | sha: response.data.sha,
|
901 | branch: branch
|
902 | };
|
903 | return _this4._request('DELETE', '/repos/' + _this4.__fullname + '/contents/' + path, deleteCommit, cb);
|
904 | });
|
905 | }
|
906 |
|
907 | /**
|
908 | * Change all references in a repo from oldPath to new_path
|
909 | * @param {string} branch - the branch to carry out the reference change, or the default branch if not specified
|
910 | * @param {string} oldPath - original path
|
911 | * @param {string} newPath - new reference path
|
912 | * @param {Requestable.callback} cb - will receive the commit in which the move occurred
|
913 | * @return {Promise} - the promise for the http request
|
914 | */
|
915 |
|
916 | }, {
|
917 | key: 'move',
|
918 | value: function move(branch, oldPath, newPath, cb) {
|
919 | var _this5 = this;
|
920 |
|
921 | var oldSha = void 0;
|
922 | return this.getRef('heads/' + branch).then(function (_ref) {
|
923 | var object = _ref.data.object;
|
924 | return _this5.getTree(object.sha + '?recursive=true');
|
925 | }).then(function (_ref2) {
|
926 | var _ref2$data = _ref2.data,
|
927 | tree = _ref2$data.tree,
|
928 | sha = _ref2$data.sha;
|
929 |
|
930 | oldSha = sha;
|
931 | var newTree = tree.map(function (ref) {
|
932 | if (ref.path === oldPath) {
|
933 | ref.path = newPath;
|
934 | }
|
935 | if (ref.type === 'tree') {
|
936 | delete ref.sha;
|
937 | }
|
938 | return ref;
|
939 | });
|
940 | return _this5.createTree(newTree);
|
941 | }).then(function (_ref3) {
|
942 | var tree = _ref3.data;
|
943 | return _this5.commit(oldSha, tree.sha, 'Renamed \'' + oldPath + '\' to \'' + newPath + '\'');
|
944 | }).then(function (_ref4) {
|
945 | var commit = _ref4.data;
|
946 | return _this5.updateHead('heads/' + branch, commit.sha, true, cb);
|
947 | });
|
948 | }
|
949 |
|
950 | /**
|
951 | * Write a file to the repository
|
952 | * @see https://developer.github.com/v3/repos/contents/#update-a-file
|
953 | * @param {string} branch - the name of the branch
|
954 | * @param {string} path - the path for the file
|
955 | * @param {string} content - the contents of the file
|
956 | * @param {string} message - the commit message
|
957 | * @param {Object} [options] - commit options
|
958 | * @param {Object} [options.author] - the author of the commit
|
959 | * @param {Object} [options.commiter] - the committer
|
960 | * @param {boolean} [options.encode] - true if the content should be base64 encoded
|
961 | * @param {Requestable.callback} cb - will receive the new commit
|
962 | * @return {Promise} - the promise for the http request
|
963 | */
|
964 |
|
965 | }, {
|
966 | key: 'writeFile',
|
967 | value: function writeFile(branch, path, content, message, options, cb) {
|
968 | var _this6 = this;
|
969 |
|
970 | options = options || {};
|
971 | if (typeof options === 'function') {
|
972 | cb = options;
|
973 | options = {};
|
974 | }
|
975 | var filePath = path ? encodeURI(path) : '';
|
976 | var shouldEncode = options.encode !== false;
|
977 | var commit = {
|
978 | branch: branch,
|
979 | message: message,
|
980 | author: options.author,
|
981 | committer: options.committer,
|
982 | content: shouldEncode ? _jsBase.Base64.encode(content) : content
|
983 | };
|
984 |
|
985 | return this.getSha(branch, filePath).then(function (response) {
|
986 | commit.sha = response.data.sha;
|
987 | return _this6._request('PUT', '/repos/' + _this6.__fullname + '/contents/' + filePath, commit, cb);
|
988 | }, function () {
|
989 | return _this6._request('PUT', '/repos/' + _this6.__fullname + '/contents/' + filePath, commit, cb);
|
990 | });
|
991 | }
|
992 |
|
993 | /**
|
994 | * Check if a repository is starred by you
|
995 | * @see https://developer.github.com/v3/activity/starring/#check-if-you-are-starring-a-repository
|
996 | * @param {Requestable.callback} cb - will receive true if the repository is starred and false if the repository
|
997 | * is not starred
|
998 | * @return {Promise} - the promise for the http request {Boolean} [description]
|
999 | */
|
1000 |
|
1001 | }, {
|
1002 | key: 'isStarred',
|
1003 | value: function isStarred(cb) {
|
1004 | return this._request204or404('/user/starred/' + this.__fullname, null, cb);
|
1005 | }
|
1006 |
|
1007 | /**
|
1008 | * Star a repository
|
1009 | * @see https://developer.github.com/v3/activity/starring/#star-a-repository
|
1010 | * @param {Requestable.callback} cb - will receive true if the repository is starred
|
1011 | * @return {Promise} - the promise for the http request
|
1012 | */
|
1013 |
|
1014 | }, {
|
1015 | key: 'star',
|
1016 | value: function star(cb) {
|
1017 | return this._request('PUT', '/user/starred/' + this.__fullname, null, cb);
|
1018 | }
|
1019 |
|
1020 | /**
|
1021 | * Unstar a repository
|
1022 | * @see https://developer.github.com/v3/activity/starring/#unstar-a-repository
|
1023 | * @param {Requestable.callback} cb - will receive true if the repository is unstarred
|
1024 | * @return {Promise} - the promise for the http request
|
1025 | */
|
1026 |
|
1027 | }, {
|
1028 | key: 'unstar',
|
1029 | value: function unstar(cb) {
|
1030 | return this._request('DELETE', '/user/starred/' + this.__fullname, null, cb);
|
1031 | }
|
1032 |
|
1033 | /**
|
1034 | * Create a new release
|
1035 | * @see https://developer.github.com/v3/repos/releases/#create-a-release
|
1036 | * @param {Object} options - the description of the release
|
1037 | * @param {Requestable.callback} cb - will receive the newly created release
|
1038 | * @return {Promise} - the promise for the http request
|
1039 | */
|
1040 |
|
1041 | }, {
|
1042 | key: 'createRelease',
|
1043 | value: function createRelease(options, cb) {
|
1044 | return this._request('POST', '/repos/' + this.__fullname + '/releases', options, cb);
|
1045 | }
|
1046 |
|
1047 | /**
|
1048 | * Edit a release
|
1049 | * @see https://developer.github.com/v3/repos/releases/#edit-a-release
|
1050 | * @param {string} id - the id of the release
|
1051 | * @param {Object} options - the description of the release
|
1052 | * @param {Requestable.callback} cb - will receive the modified release
|
1053 | * @return {Promise} - the promise for the http request
|
1054 | */
|
1055 |
|
1056 | }, {
|
1057 | key: 'updateRelease',
|
1058 | value: function updateRelease(id, options, cb) {
|
1059 | return this._request('PATCH', '/repos/' + this.__fullname + '/releases/' + id, options, cb);
|
1060 | }
|
1061 |
|
1062 | /**
|
1063 | * Get information about all releases
|
1064 | * @see https://developer.github.com/v3/repos/releases/#list-releases-for-a-repository
|
1065 | * @param {Requestable.callback} cb - will receive the release information
|
1066 | * @return {Promise} - the promise for the http request
|
1067 | */
|
1068 |
|
1069 | }, {
|
1070 | key: 'listReleases',
|
1071 | value: function listReleases(cb) {
|
1072 | return this._request('GET', '/repos/' + this.__fullname + '/releases', null, cb);
|
1073 | }
|
1074 |
|
1075 | /**
|
1076 | * Get information about a release
|
1077 | * @see https://developer.github.com/v3/repos/releases/#get-a-single-release
|
1078 | * @param {string} id - the id of the release
|
1079 | * @param {Requestable.callback} cb - will receive the release information
|
1080 | * @return {Promise} - the promise for the http request
|
1081 | */
|
1082 |
|
1083 | }, {
|
1084 | key: 'getRelease',
|
1085 | value: function getRelease(id, cb) {
|
1086 | return this._request('GET', '/repos/' + this.__fullname + '/releases/' + id, null, cb);
|
1087 | }
|
1088 |
|
1089 | /**
|
1090 | * Delete a release
|
1091 | * @see https://developer.github.com/v3/repos/releases/#delete-a-release
|
1092 | * @param {string} id - the release to be deleted
|
1093 | * @param {Requestable.callback} cb - will receive true if the operation is successful
|
1094 | * @return {Promise} - the promise for the http request
|
1095 | */
|
1096 |
|
1097 | }, {
|
1098 | key: 'deleteRelease',
|
1099 | value: function deleteRelease(id, cb) {
|
1100 | return this._request('DELETE', '/repos/' + this.__fullname + '/releases/' + id, null, cb);
|
1101 | }
|
1102 |
|
1103 | /**
|
1104 | * Merge a pull request
|
1105 | * @see https://developer.github.com/v3/pulls/#merge-a-pull-request-merge-button
|
1106 | * @param {number|string} number - the number of the pull request to merge
|
1107 | * @param {Object} options - the merge options for the pull request
|
1108 | * @param {Requestable.callback} [cb] - will receive the merge information if the operation is successful
|
1109 | * @return {Promise} - the promise for the http request
|
1110 | */
|
1111 |
|
1112 | }, {
|
1113 | key: 'mergePullRequest',
|
1114 | value: function mergePullRequest(number, options, cb) {
|
1115 | return this._request('PUT', '/repos/' + this.__fullname + '/pulls/' + number + '/merge', options, cb);
|
1116 | }
|
1117 |
|
1118 | /**
|
1119 | * Get information about all projects
|
1120 | * @see https://developer.github.com/v3/projects/#list-repository-projects
|
1121 | * @param {Requestable.callback} [cb] - will receive the list of projects
|
1122 | * @return {Promise} - the promise for the http request
|
1123 | */
|
1124 |
|
1125 | }, {
|
1126 | key: 'listProjects',
|
1127 | value: function listProjects(cb) {
|
1128 | return this._requestAllPages('/repos/' + this.__fullname + '/projects', { AcceptHeader: 'inertia-preview' }, cb);
|
1129 | }
|
1130 |
|
1131 | /**
|
1132 | * Create a new project
|
1133 | * @see https://developer.github.com/v3/projects/#create-a-repository-project
|
1134 | * @param {Object} options - the description of the project
|
1135 | * @param {Requestable.callback} cb - will receive the newly created project
|
1136 | * @return {Promise} - the promise for the http request
|
1137 | */
|
1138 |
|
1139 | }, {
|
1140 | key: 'createProject',
|
1141 | value: function createProject(options, cb) {
|
1142 | options = options || {};
|
1143 | options.AcceptHeader = 'inertia-preview';
|
1144 | return this._request('POST', '/repos/' + this.__fullname + '/projects', options, cb);
|
1145 | }
|
1146 | }]);
|
1147 |
|
1148 | return Repository;
|
1149 | }(_Requestable3.default);
|
1150 |
|
1151 | module.exports = Repository;
|
1152 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Repository.js"],"names":["log","Repository","fullname","auth","apiBase","__fullname","__currentTree","branch","sha","ref","cb","_request","options","number","base","head","since","_dateToISO","until","path","treeSHA","content","postBody","_getContentObject","Utf8","encode","encoding","Buffer","toString","Blob","Base64","JSON","stringify","Error","baseTreeSHA","blobSHA","newTree","base_tree","tree","mode","type","baseSHA","parent","message","data","parents","Object","assign","then","response","commitSHA","force","username","raw","encodeURI","org","oldBranch","newBranch","getRef","object","createRef","id","getSha","deleteCommit","oldPath","newPath","oldSha","getTree","map","createTree","commit","updateHead","filePath","shouldEncode","author","committer","_request204or404","_requestAllPages","AcceptHeader","Requestable","module","exports"],"mappings":"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","file":"Repository.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 Utf8 from 'utf8';\nimport {\n   Base64,\n} from 'js-base64';\nimport debug from 'debug';\nconst log = debug('github:repository');\n\n/**\n * Repository encapsulates the functionality to create, query, and modify files.\n */\nclass Repository extends Requestable {\n   /**\n    * Create a Repository.\n    * @param {string} fullname - the full name of the repository\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(fullname, auth, apiBase) {\n      super(auth, apiBase);\n      this.__fullname = fullname;\n      this.__currentTree = {\n         branch: null,\n         sha: null,\n      };\n   }\n\n   /**\n    * Get a reference\n    * @see https://developer.github.com/v3/git/refs/#get-a-reference\n    * @param {string} ref - the reference to get\n    * @param {Requestable.callback} [cb] - will receive the reference's refSpec or a list of refSpecs that match `ref`\n    * @return {Promise} - the promise for the http request\n    */\n   getRef(ref, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/git/refs/${ref}`, null, cb);\n   }\n\n   /**\n    * Create a reference\n    * @see https://developer.github.com/v3/git/refs/#create-a-reference\n    * @param {Object} options - the object describing the ref\n    * @param {Requestable.callback} [cb] - will receive the ref\n    * @return {Promise} - the promise for the http request\n    */\n   createRef(options, cb) {\n      return this._request('POST', `/repos/${this.__fullname}/git/refs`, options, cb);\n   }\n\n   /**\n    * Delete a reference\n    * @see https://developer.github.com/v3/git/refs/#delete-a-reference\n    * @param {string} ref - the name of the ref to delte\n    * @param {Requestable.callback} [cb] - will receive true if the request is successful\n    * @return {Promise} - the promise for the http request\n    */\n   deleteRef(ref, cb) {\n      return this._request('DELETE', `/repos/${this.__fullname}/git/refs/${ref}`, null, cb);\n   }\n\n   /**\n    * Delete a repository\n    * @see https://developer.github.com/v3/repos/#delete-a-repository\n    * @param {Requestable.callback} [cb] - will receive true if the request is successful\n    * @return {Promise} - the promise for the http request\n    */\n   deleteRepo(cb) {\n      return this._request('DELETE', `/repos/${this.__fullname}`, null, cb);\n   }\n\n   /**\n    * List the tags on a repository\n    * @see https://developer.github.com/v3/repos/#list-tags\n    * @param {Requestable.callback} [cb] - will receive the tag data\n    * @return {Promise} - the promise for the http request\n    */\n   listTags(cb) {\n      return this._request('GET', `/repos/${this.__fullname}/tags`, null, cb);\n   }\n\n   /**\n    * List the open pull requests on the repository\n    * @see https://developer.github.com/v3/pulls/#list-pull-requests\n    * @param {Object} options - options to filter the search\n    * @param {Requestable.callback} [cb] - will receive the list of PRs\n    * @return {Promise} - the promise for the http request\n    */\n   listPullRequests(options, cb) {\n      options = options || {};\n      return this._request('GET', `/repos/${this.__fullname}/pulls`, options, cb);\n   }\n\n   /**\n    * Get information about a specific pull request\n    * @see https://developer.github.com/v3/pulls/#get-a-single-pull-request\n    * @param {number} number - the PR you wish to fetch\n    * @param {Requestable.callback} [cb] - will receive the PR from the API\n    * @return {Promise} - the promise for the http request\n    */\n   getPullRequest(number, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/pulls/${number}`, null, cb);\n   }\n\n   /**\n    * List the files of a specific pull request\n    * @see https://developer.github.com/v3/pulls/#list-pull-requests-files\n    * @param {number|string} number - the PR you wish to fetch\n    * @param {Requestable.callback} [cb] - will receive the list of files from the API\n    * @return {Promise} - the promise for the http request\n    */\n   listPullRequestFiles(number, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/pulls/${number}/files`, null, cb);\n   }\n\n   /**\n    * Compare two branches/commits/repositories\n    * @see https://developer.github.com/v3/repos/commits/#compare-two-commits\n    * @param {string} base - the base commit\n    * @param {string} head - the head commit\n    * @param {Requestable.callback} cb - will receive the comparison\n    * @return {Promise} - the promise for the http request\n    */\n   compareBranches(base, head, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/compare/${base}...${head}`, null, cb);\n   }\n\n   /**\n    * List all the branches for the repository\n    * @see https://developer.github.com/v3/repos/#list-branches\n    * @param {Requestable.callback} cb - will receive the list of branches\n    * @return {Promise} - the promise for the http request\n    */\n   listBranches(cb) {\n      return this._request('GET', `/repos/${this.__fullname}/branches`, null, cb);\n   }\n\n   /**\n    * Get a raw blob from the repository\n    * @see https://developer.github.com/v3/git/blobs/#get-a-blob\n    * @param {string} sha - the sha of the blob to fetch\n    * @param {Requestable.callback} cb - will receive the blob from the API\n    * @return {Promise} - the promise for the http request\n    */\n   getBlob(sha, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/git/blobs/${sha}`, null, cb, 'raw');\n   }\n\n   /**\n    * Get a single branch\n    * @see https://developer.github.com/v3/repos/branches/#get-branch\n    * @param {string} branch - the name of the branch to fetch\n    * @param {Requestable.callback} cb - will receive the branch from the API\n    * @returns {Promise} - the promise for the http request\n    */\n   getBranch(branch, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/branches/${branch}`, null, cb);\n   }\n\n   /**\n    * Get a commit from the repository\n    * @see https://developer.github.com/v3/repos/commits/#get-a-single-commit\n    * @param {string} sha - the sha for the commit to fetch\n    * @param {Requestable.callback} cb - will receive the commit data\n    * @return {Promise} - the promise for the http request\n    */\n   getCommit(sha, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/git/commits/${sha}`, null, cb);\n   }\n\n   /**\n    * List the commits on a repository, optionally filtering by path, author or time range\n    * @see https://developer.github.com/v3/repos/commits/#list-commits-on-a-repository\n    * @param {Object} [options] - the filtering options for commits\n    * @param {string} [options.sha] - the SHA or branch to start from\n    * @param {string} [options.path] - the path to search on\n    * @param {string} [options.author] - the commit author\n    * @param {(Date|string)} [options.since] - only commits after this date will be returned\n    * @param {(Date|string)} [options.until] - only commits before this date will be returned\n    * @param {Requestable.callback} cb - will receive the list of commits found matching the criteria\n    * @return {Promise} - the promise for the http request\n    */\n   listCommits(options, cb) {\n      options = options || {};\n      if (typeof options === 'function') {\n         cb = options;\n         options = {};\n      }\n      options.since = this._dateToISO(options.since);\n      options.until = this._dateToISO(options.until);\n\n      return this._request('GET', `/repos/${this.__fullname}/commits`, options, cb);\n   }\n\n   /**\n    * List the commits on a pull request\n    * @see https://developer.github.com/v3/repos/commits/#list-commits-on-a-repository\n    * @param {number|string} number - the number of the pull request to list the commits\n    * @param {Object} [options] - the filtering options for commits\n    * @param {Requestable.callback} [cb] - will receive the commits information\n    * @return {Promise} - the promise for the http request\n    */\n   listCommitsOnPR(number, options, cb) {\n      options = options || {};\n      if (typeof options === 'function') {\n         cb = options;\n         options = {};\n      }\n      return this._request('GET', `/repos/${this.__fullname}/pulls/${number}/commits`, options, cb);\n   }\n\n    /**\n     * Gets a single commit information for a repository\n     * @see https://developer.github.com/v3/repos/commits/#get-a-single-commit\n     * @param {string} ref - the reference for the commit-ish\n     * @param {Requestable.callback} cb - will receive the commit information\n     * @return {Promise} - the promise for the http request\n     */\n   getSingleCommit(ref, cb) {\n      ref = ref || '';\n      return this._request('GET', `/repos/${this.__fullname}/commits/${ref}`, null, cb);\n   }\n\n   /**\n    * Get tha sha for a particular object in the repository. This is a convenience function\n    * @see https://developer.github.com/v3/repos/contents/#get-contents\n    * @param {string} [branch] - the branch to look in, or the repository's default branch if omitted\n    * @param {string} path - the path of the file or directory\n    * @param {Requestable.callback} cb - will receive a description of the requested object, including a `SHA` property\n    * @return {Promise} - the promise for the http request\n    */\n   getSha(branch, path, cb) {\n      branch = branch ? `?ref=${branch}` : '';\n      return this._request('GET', `/repos/${this.__fullname}/contents/${path}${branch}`, null, cb);\n   }\n\n   /**\n    * List the commit statuses for a particular sha, branch, or tag\n    * @see https://developer.github.com/v3/repos/statuses/#list-statuses-for-a-specific-ref\n    * @param {string} sha - the sha, branch, or tag to get statuses for\n    * @param {Requestable.callback} cb - will receive the list of statuses\n    * @return {Promise} - the promise for the http request\n    */\n   listStatuses(sha, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/commits/${sha}/statuses`, null, cb);\n   }\n\n   /**\n    * Get the combined view of commit statuses for a particular sha, branch, or tag\n    * @see https://developer.github.com/v3/repos/statuses/#get-the-combined-status-for-a-specific-ref\n    * @param {string} sha - the sha, branch, or tag to get the combined status for\n    * @param {Requestable.callback} cb - will receive the combined status\n    * @returns {Promise} - the promise for the http request\n    */\n   getCombinedStatus(sha, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/commits/${sha}/status`, null, cb);\n   }\n\n   /**\n    * Get a description of a git tree\n    * @see https://developer.github.com/v3/git/trees/#get-a-tree\n    * @param {string} treeSHA - the SHA of the tree to fetch\n    * @param {Requestable.callback} cb - will receive the callback data\n    * @return {Promise} - the promise for the http request\n    */\n   getTree(treeSHA, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/git/trees/${treeSHA}`, null, cb);\n   }\n\n   /**\n    * Create a blob\n    * @see https://developer.github.com/v3/git/blobs/#create-a-blob\n    * @param {(string|Buffer|Blob)} content - the content to add to the repository\n    * @param {Requestable.callback} cb - will receive the details of the created blob\n    * @return {Promise} - the promise for the http request\n    */\n   createBlob(content, cb) {\n      let postBody = this._getContentObject(content);\n\n      log('sending content', postBody);\n      return this._request('POST', `/repos/${this.__fullname}/git/blobs`, postBody, cb);\n   }\n\n   /**\n    * Get the object that represents the provided content\n    * @param {string|Buffer|Blob} content - the content to send to the server\n    * @return {Object} the representation of `content` for the GitHub API\n    */\n   _getContentObject(content) {\n      if (typeof content === 'string') {\n         log('contet is a string');\n         return {\n            content: Utf8.encode(content),\n            encoding: 'utf-8',\n         };\n\n      } else if (typeof Buffer !== 'undefined' && content instanceof Buffer) {\n         log('We appear to be in Node');\n         return {\n            content: content.toString('base64'),\n            encoding: 'base64',\n         };\n\n      } else if (typeof Blob !== 'undefined' && content instanceof Blob) {\n         log('We appear to be in the browser');\n         return {\n            content: Base64.encode(content),\n            encoding: 'base64',\n         };\n\n      } else { // eslint-disable-line\n         log(`Not sure what this content is: ${typeof content}, ${JSON.stringify(content)}`);\n         throw new Error('Unknown content passed to postBlob. Must be string or Buffer (node) or Blob (web)');\n      }\n   }\n\n   /**\n    * Update a tree in Git\n    * @see https://developer.github.com/v3/git/trees/#create-a-tree\n    * @param {string} baseTreeSHA - the SHA of the tree to update\n    * @param {string} path - the path for the new file\n    * @param {string} blobSHA - the SHA for the blob to put at `path`\n    * @param {Requestable.callback} cb - will receive the new tree that is created\n    * @return {Promise} - the promise for the http request\n    * @deprecated use {@link Repository#createTree} instead\n    */\n   updateTree(baseTreeSHA, path, blobSHA, cb) {\n      let newTree = {\n         base_tree: baseTreeSHA, // eslint-disable-line\n         tree: [{\n            path: path,\n            sha: blobSHA,\n            mode: '100644',\n            type: 'blob',\n         }],\n      };\n\n      return this._request('POST', `/repos/${this.__fullname}/git/trees`, newTree, cb);\n   }\n\n   /**\n    * Create a new tree in git\n    * @see https://developer.github.com/v3/git/trees/#create-a-tree\n    * @param {Object} tree - the tree to create\n    * @param {string} baseSHA - the root sha of the tree\n    * @param {Requestable.callback} cb - will receive the new tree that is created\n    * @return {Promise} - the promise for the http request\n    */\n   createTree(tree, baseSHA, cb) {\n      return this._request('POST', `/repos/${this.__fullname}/git/trees`, {\n         tree,\n         base_tree: baseSHA, // eslint-disable-line camelcase\n      }, cb);\n   }\n\n   /**\n    * Add a commit to the repository\n    * @see https://developer.github.com/v3/git/commits/#create-a-commit\n    * @param {string} parent - the SHA of the parent commit\n    * @param {string} tree - the SHA of the tree for this commit\n    * @param {string} message - the commit message\n    * @param {Object} [options] - commit options\n    * @param {Object} [options.author] - the author of the commit\n    * @param {Object} [options.commiter] - the committer\n    * @param {Requestable.callback} cb - will receive the commit that is created\n    * @return {Promise} - the promise for the http request\n    */\n   commit(parent, tree, message, options, cb) {\n      if (typeof options === 'function') {\n         cb = options;\n         options = {};\n      }\n\n      let data = {\n         message,\n         tree,\n         parents: [parent],\n      };\n\n      data = Object.assign({}, options, data);\n\n      return this._request('POST', `/repos/${this.__fullname}/git/commits`, data, cb)\n         .then((response) => {\n            this.__currentTree.sha = response.data.sha; // Update latest commit\n            return response;\n         });\n   }\n\n   /**\n    * Update a ref\n    * @see https://developer.github.com/v3/git/refs/#update-a-reference\n    * @param {string} ref - the ref to update\n    * @param {string} commitSHA - the SHA to point the reference to\n    * @param {boolean} force - indicates whether to force or ensure a fast-forward update\n    * @param {Requestable.callback} cb - will receive the updated ref back\n    * @return {Promise} - the promise for the http request\n    */\n   updateHead(ref, commitSHA, force, cb) {\n      return this._request('PATCH', `/repos/${this.__fullname}/git/refs/${ref}`, {\n         sha: commitSHA,\n         force: force,\n      }, cb);\n   }\n\n   /**\n    * Update commit status\n    * @see https://developer.github.com/v3/repos/statuses/\n    * @param {string} commitSHA - the SHA of the commit that should be updated\n    * @param {object} options - Commit status parameters\n    * @param {string} options.state - The state of the status. Can be one of: pending, success, error, or failure.\n    * @param {string} [options.target_url] - The target URL to associate with this status.\n    * @param {string} [options.description] - A short description of the status.\n    * @param {string} [options.context] - A string label to differentiate this status among CI systems.\n    * @param {Requestable.callback} cb - will receive the updated commit back\n    * @return {Promise} - the promise for the http request\n    */\n   updateStatus(commitSHA, options, cb) {\n      return this._request('POST', `/repos/${this.__fullname}/statuses/${commitSHA}`, options, cb);\n   }\n\n   /**\n    * Update repository information\n    * @see https://developer.github.com/v3/repos/#edit\n    * @param {object} options - New parameters that will be set to the repository\n    * @param {string} options.name - Name of the repository\n    * @param {string} [options.description] - A short description of the repository\n    * @param {string} [options.homepage] - A URL with more information about the repository\n    * @param {boolean} [options.private] - Either true to make the repository private, or false to make it public.\n    * @param {boolean} [options.has_issues] - Either true to enable issues for this repository, false to disable them.\n    * @param {boolean} [options.has_wiki] - Either true to enable the wiki for this repository, false to disable it.\n    * @param {boolean} [options.has_downloads] - Either true to enable downloads, false to disable them.\n    * @param {string} [options.default_branch] - Updates the default branch for this repository.\n    * @param {Requestable.callback} cb - will receive the updated repository back\n    * @return {Promise} - the promise for the http request\n    */\n   updateRepository(options, cb) {\n      return this._request('PATCH', `/repos/${this.__fullname}`, options, cb);\n   }\n\n  /**\n    * Get information about the repository\n    * @see https://developer.github.com/v3/repos/#get\n    * @param {Requestable.callback} cb - will receive the information about the repository\n    * @return {Promise} - the promise for the http request\n    */\n   getDetails(cb) {\n      return this._request('GET', `/repos/${this.__fullname}`, null, cb);\n   }\n\n   /**\n    * List the contributors to the repository\n    * @see https://developer.github.com/v3/repos/#list-contributors\n    * @param {Requestable.callback} cb - will receive the list of contributors\n    * @return {Promise} - the promise for the http request\n    */\n   getContributors(cb) {\n      return this._request('GET', `/repos/${this.__fullname}/contributors`, null, cb);\n   }\n\n   /**\n    * List the contributor stats to the repository\n    * @see https://developer.github.com/v3/repos/#list-contributors\n    * @param {Requestable.callback} cb - will receive the list of contributors\n    * @return {Promise} - the promise for the http request\n    */\n   getContributorStats(cb) {\n      return this._request('GET', `/repos/${this.__fullname}/stats/contributors`, null, cb);\n   }\n\n   /**\n    * List the users who are collaborators on the repository. The currently authenticated user must have\n    * push access to use this method\n    * @see https://developer.github.com/v3/repos/collaborators/#list-collaborators\n    * @param {Requestable.callback} cb - will receive the list of collaborators\n    * @return {Promise} - the promise for the http request\n    */\n   getCollaborators(cb) {\n      return this._request('GET', `/repos/${this.__fullname}/collaborators`, null, cb);\n   }\n\n   /**\n    * Check if a user is a collaborator on the repository\n    * @see https://developer.github.com/v3/repos/collaborators/#check-if-a-user-is-a-collaborator\n    * @param {string} username - the user to check\n    * @param {Requestable.callback} cb - will receive true if the user is a collaborator and false if they are not\n    * @return {Promise} - the promise for the http request {Boolean} [description]\n    */\n   isCollaborator(username, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/collaborators/${username}`, null, cb);\n   }\n\n   /**\n    * Get the contents of a repository\n    * @see https://developer.github.com/v3/repos/contents/#get-contents\n    * @param {string} ref - the ref to check\n    * @param {string} path - the path containing the content to fetch\n    * @param {boolean} raw - `true` if the results should be returned raw instead of GitHub's normalized format\n    * @param {Requestable.callback} cb - will receive the fetched data\n    * @return {Promise} - the promise for the http request\n    */\n   getContents(ref, path, raw, cb) {\n      path = path ? `${encodeURI(path)}` : '';\n      return this._request('GET', `/repos/${this.__fullname}/contents/${path}`, {\n         ref,\n      }, cb, raw);\n   }\n\n   /**\n    * Get the README of a repository\n    * @see https://developer.github.com/v3/repos/contents/#get-the-readme\n    * @param {string} ref - the ref to check\n    * @param {boolean} raw - `true` if the results should be returned raw instead of GitHub's normalized format\n    * @param {Requestable.callback} cb - will receive the fetched data\n    * @return {Promise} - the promise for the http request\n    */\n   getReadme(ref, raw, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/readme`, {\n         ref,\n      }, cb, raw);\n   }\n\n   /**\n    * Fork a repository\n    * @see https://developer.github.com/v3/repos/forks/#create-a-fork\n    * @param {Requestable.callback} cb - will receive the information about the newly created fork\n    * @return {Promise} - the promise for the http request\n    */\n   fork(cb) {\n      return this._request('POST', `/repos/${this.__fullname}/forks`, null, cb);\n   }\n\n   /**\n    * Fork a repository to an organization\n    * @see https://developer.github.com/v3/repos/forks/#create-a-fork\n    * @param {String} org - organization where you'd like to create the fork.\n    * @param {Requestable.callback} cb - will receive the information about the newly created fork\n    * @return {Promise} - the promise for the http request\n    *\n    */\n   forkToOrg(org, cb) {\n      return this._request('POST', `/repos/${this.__fullname}/forks?organization=${org}`, null, cb);\n   }\n\n   /**\n    * List a repository's forks\n    * @see https://developer.github.com/v3/repos/forks/#list-forks\n    * @param {Requestable.callback} cb - will receive the list of repositories forked from this one\n    * @return {Promise} - the promise for the http request\n    */\n   listForks(cb) {\n      return this._request('GET', `/repos/${this.__fullname}/forks`, null, cb);\n   }\n\n   /**\n    * Create a new branch from an existing branch.\n    * @param {string} [oldBranch=master] - the name of the existing branch\n    * @param {string} newBranch - the name of the new branch\n    * @param {Requestable.callback} cb - will receive the commit data for the head of the new branch\n    * @return {Promise} - the promise for the http request\n    */\n   createBranch(oldBranch, newBranch, cb) {\n      if (typeof newBranch === 'function') {\n         cb = newBranch;\n         newBranch = oldBranch;\n         oldBranch = 'master';\n      }\n\n      return this.getRef(`heads/${oldBranch}`)\n         .then((response) => {\n            let sha = response.data.object.sha;\n            return this.createRef({\n               sha,\n               ref: `refs/heads/${newBranch}`,\n            }, cb);\n         });\n   }\n\n   /**\n    * Create a new pull request\n    * @see https://developer.github.com/v3/pulls/#create-a-pull-request\n    * @param {Object} options - the pull request description\n    * @param {Requestable.callback} cb - will receive the new pull request\n    * @return {Promise} - the promise for the http request\n    */\n   createPullRequest(options, cb) {\n      return this._request('POST', `/repos/${this.__fullname}/pulls`, options, cb);\n   }\n\n   /**\n    * Update a pull request\n    * @see https://developer.github.com/v3/pulls/#update-a-pull-request\n    * @param {number|string} number - the number of the pull request to update\n    * @param {Object} options - the pull request description\n    * @param {Requestable.callback} [cb] - will receive the pull request information\n    * @return {Promise} - the promise for the http request\n    */\n   updatePullRequest(number, options, cb) {\n      return this._request('PATCH', `/repos/${this.__fullname}/pulls/${number}`, options, cb);\n   }\n\n   /**\n    * List the hooks for the repository\n    * @see https://developer.github.com/v3/repos/hooks/#list-hooks\n    * @param {Requestable.callback} cb - will receive the list of hooks\n    * @return {Promise} - the promise for the http request\n    */\n   listHooks(cb) {\n      return this._request('GET', `/repos/${this.__fullname}/hooks`, null, cb);\n   }\n\n   /**\n    * Get a hook for the repository\n    * @see https://developer.github.com/v3/repos/hooks/#get-single-hook\n    * @param {number} id - the id of the webook\n    * @param {Requestable.callback} cb - will receive the details of the webook\n    * @return {Promise} - the promise for the http request\n    */\n   getHook(id, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/hooks/${id}`, null, cb);\n   }\n\n   /**\n    * Add a new hook to the repository\n    * @see https://developer.github.com/v3/repos/hooks/#create-a-hook\n    * @param {Object} options - the configuration describing the new hook\n    * @param {Requestable.callback} cb - will receive the new webhook\n    * @return {Promise} - the promise for the http request\n    */\n   createHook(options, cb) {\n      return this._request('POST', `/repos/${this.__fullname}/hooks`, options, cb);\n   }\n\n   /**\n    * Edit an existing webhook\n    * @see https://developer.github.com/v3/repos/hooks/#edit-a-hook\n    * @param {number} id - the id of the webhook\n    * @param {Object} options - the new description of the webhook\n    * @param {Requestable.callback} cb - will receive the updated webhook\n    * @return {Promise} - the promise for the http request\n    */\n   updateHook(id, options, cb) {\n      return this._request('PATCH', `/repos/${this.__fullname}/hooks/${id}`, options, cb);\n   }\n\n   /**\n    * Delete a webhook\n    * @see https://developer.github.com/v3/repos/hooks/#delete-a-hook\n    * @param {number} id - the id of the webhook to be deleted\n    * @param {Requestable.callback} cb - will receive true if the call is successful\n    * @return {Promise} - the promise for the http request\n    */\n   deleteHook(id, cb) {\n      return this._request('DELETE', `/repos/${this.__fullname}/hooks/${id}`, null, cb);\n   }\n\n   /**\n    * List the deploy keys for the repository\n    * @see https://developer.github.com/v3/repos/keys/#list-deploy-keys\n    * @param {Requestable.callback} cb - will receive the list of deploy keys\n    * @return {Promise} - the promise for the http request\n    */\n   listKeys(cb) {\n      return this._request('GET', `/repos/${this.__fullname}/keys`, null, cb);\n   }\n\n   /**\n    * Get a deploy key for the repository\n    * @see https://developer.github.com/v3/repos/keys/#get-a-deploy-key\n    * @param {number} id - the id of the deploy key\n    * @param {Requestable.callback} cb - will receive the details of the deploy key\n    * @return {Promise} - the promise for the http request\n    */\n   getKey(id, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/keys/${id}`, null, cb);\n   }\n\n   /**\n    * Add a new deploy key to the repository\n    * @see https://developer.github.com/v3/repos/keys/#add-a-new-deploy-key\n    * @param {Object} options - the configuration describing the new deploy key\n    * @param {Requestable.callback} cb - will receive the new deploy key\n    * @return {Promise} - the promise for the http request\n    */\n   createKey(options, cb) {\n      return this._request('POST', `/repos/${this.__fullname}/keys`, options, cb);\n   }\n\n   /**\n    * Delete a deploy key\n    * @see https://developer.github.com/v3/repos/keys/#remove-a-deploy-key\n    * @param {number} id - the id of the deploy key to be deleted\n    * @param {Requestable.callback} cb - will receive true if the call is successful\n    * @return {Promise} - the promise for the http request\n    */\n   deleteKey(id, cb) {\n      return this._request('DELETE', `/repos/${this.__fullname}/keys/${id}`, null, cb);\n   }\n\n   /**\n    * Delete a file from a branch\n    * @see https://developer.github.com/v3/repos/contents/#delete-a-file\n    * @param {string} branch - the branch to delete from, or the default branch if not specified\n    * @param {string} path - the path of the file to remove\n    * @param {Requestable.callback} cb - will receive the commit in which the delete occurred\n    * @return {Promise} - the promise for the http request\n    */\n   deleteFile(branch, path, cb) {\n      return this.getSha(branch, path)\n         .then((response) => {\n            const deleteCommit = {\n               message: `Delete the file at '${path}'`,\n               sha: response.data.sha,\n               branch,\n            };\n            return this._request('DELETE', `/repos/${this.__fullname}/contents/${path}`, deleteCommit, cb);\n         });\n   }\n\n   /**\n    * Change all references in a repo from oldPath to new_path\n    * @param {string} branch - the branch to carry out the reference change, or the default branch if not specified\n    * @param {string} oldPath - original path\n    * @param {string} newPath - new reference path\n    * @param {Requestable.callback} cb - will receive the commit in which the move occurred\n    * @return {Promise} - the promise for the http request\n    */\n   move(branch, oldPath, newPath, cb) {\n      let oldSha;\n      return this.getRef(`heads/${branch}`)\n         .then(({data: {object}}) => this.getTree(`${object.sha}?recursive=true`))\n         .then(({data: {tree, sha}}) => {\n            oldSha = sha;\n            let newTree = tree.map((ref) => {\n               if (ref.path === oldPath) {\n                  ref.path = newPath;\n               }\n               if (ref.type === 'tree') {\n                  delete ref.sha;\n               }\n               return ref;\n            });\n            return this.createTree(newTree);\n         })\n         .then(({data: tree}) => this.commit(oldSha, tree.sha, `Renamed '${oldPath}' to '${newPath}'`))\n         .then(({data: commit}) => this.updateHead(`heads/${branch}`, commit.sha, true, cb));\n   }\n\n   /**\n    * Write a file to the repository\n    * @see https://developer.github.com/v3/repos/contents/#update-a-file\n    * @param {string} branch - the name of the branch\n    * @param {string} path - the path for the file\n    * @param {string} content - the contents of the file\n    * @param {string} message - the commit message\n    * @param {Object} [options] - commit options\n    * @param {Object} [options.author] - the author of the commit\n    * @param {Object} [options.commiter] - the committer\n    * @param {boolean} [options.encode] - true if the content should be base64 encoded\n    * @param {Requestable.callback} cb - will receive the new commit\n    * @return {Promise} - the promise for the http request\n    */\n   writeFile(branch, path, content, message, options, cb) {\n      options = options || {};\n      if (typeof options === 'function') {\n         cb = options;\n         options = {};\n      }\n      let filePath = path ? encodeURI(path) : '';\n      let shouldEncode = options.encode !== false;\n      let commit = {\n         branch,\n         message,\n         author: options.author,\n         committer: options.committer,\n         content: shouldEncode ? Base64.encode(content) : content,\n      };\n\n      return this.getSha(branch, filePath)\n         .then((response) => {\n            commit.sha = response.data.sha;\n            return this._request('PUT', `/repos/${this.__fullname}/contents/${filePath}`, commit, cb);\n         }, () => {\n            return this._request('PUT', `/repos/${this.__fullname}/contents/${filePath}`, commit, cb);\n         });\n   }\n\n   /**\n    * Check if a repository is starred by you\n    * @see https://developer.github.com/v3/activity/starring/#check-if-you-are-starring-a-repository\n    * @param {Requestable.callback} cb - will receive true if the repository is starred and false if the repository\n    *                                  is not starred\n    * @return {Promise} - the promise for the http request {Boolean} [description]\n    */\n   isStarred(cb) {\n      return this._request204or404(`/user/starred/${this.__fullname}`, null, cb);\n   }\n\n   /**\n    * Star a repository\n    * @see https://developer.github.com/v3/activity/starring/#star-a-repository\n    * @param {Requestable.callback} cb - will receive true if the repository is starred\n    * @return {Promise} - the promise for the http request\n    */\n   star(cb) {\n      return this._request('PUT', `/user/starred/${this.__fullname}`, null, cb);\n   }\n\n   /**\n    * Unstar a repository\n    * @see https://developer.github.com/v3/activity/starring/#unstar-a-repository\n    * @param {Requestable.callback} cb - will receive true if the repository is unstarred\n    * @return {Promise} - the promise for the http request\n    */\n   unstar(cb) {\n      return this._request('DELETE', `/user/starred/${this.__fullname}`, null, cb);\n   }\n\n   /**\n    * Create a new release\n    * @see https://developer.github.com/v3/repos/releases/#create-a-release\n    * @param {Object} options - the description of the release\n    * @param {Requestable.callback} cb - will receive the newly created release\n    * @return {Promise} - the promise for the http request\n    */\n   createRelease(options, cb) {\n      return this._request('POST', `/repos/${this.__fullname}/releases`, options, cb);\n   }\n\n   /**\n    * Edit a release\n    * @see https://developer.github.com/v3/repos/releases/#edit-a-release\n    * @param {string} id - the id of the release\n    * @param {Object} options - the description of the release\n    * @param {Requestable.callback} cb - will receive the modified release\n    * @return {Promise} - the promise for the http request\n    */\n   updateRelease(id, options, cb) {\n      return this._request('PATCH', `/repos/${this.__fullname}/releases/${id}`, options, cb);\n   }\n\n   /**\n    * Get information about all releases\n    * @see https://developer.github.com/v3/repos/releases/#list-releases-for-a-repository\n    * @param {Requestable.callback} cb - will receive the release information\n    * @return {Promise} - the promise for the http request\n    */\n   listReleases(cb) {\n      return this._request('GET', `/repos/${this.__fullname}/releases`, null, cb);\n   }\n\n   /**\n    * Get information about a release\n    * @see https://developer.github.com/v3/repos/releases/#get-a-single-release\n    * @param {string} id - the id of the release\n    * @param {Requestable.callback} cb - will receive the release information\n    * @return {Promise} - the promise for the http request\n    */\n   getRelease(id, cb) {\n      return this._request('GET', `/repos/${this.__fullname}/releases/${id}`, null, cb);\n   }\n\n   /**\n    * Delete a release\n    * @see https://developer.github.com/v3/repos/releases/#delete-a-release\n    * @param {string} id - the release to be deleted\n    * @param {Requestable.callback} cb - will receive true if the operation is successful\n    * @return {Promise} - the promise for the http request\n    */\n   deleteRelease(id, cb) {\n      return this._request('DELETE', `/repos/${this.__fullname}/releases/${id}`, null, cb);\n   }\n\n   /**\n    * Merge a pull request\n    * @see https://developer.github.com/v3/pulls/#merge-a-pull-request-merge-button\n    * @param {number|string} number - the number of the pull request to merge\n    * @param {Object} options - the merge options for the pull request\n    * @param {Requestable.callback} [cb] - will receive the merge information if the operation is successful\n    * @return {Promise} - the promise for the http request\n    */\n   mergePullRequest(number, options, cb) {\n      return this._request('PUT', `/repos/${this.__fullname}/pulls/${number}/merge`, options, cb);\n   }\n\n   /**\n    * Get information about all projects\n    * @see https://developer.github.com/v3/projects/#list-repository-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(`/repos/${this.__fullname}/projects`, {AcceptHeader: 'inertia-preview'}, cb);\n   }\n\n   /**\n    * Create a new project\n    * @see https://developer.github.com/v3/projects/#create-a-repository-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', `/repos/${this.__fullname}/projects`, options, cb);\n   }\n\n}\n\nmodule.exports = Repository;\n"]}
|
1153 | //# sourceMappingURL=Repository.js.map
|