UNPKG

118 kBJavaScriptView Raw
1'use strict';
2
3var _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
5var _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
7var _Requestable2 = require('./Requestable');
8
9var _Requestable3 = _interopRequireDefault(_Requestable2);
10
11var _utf = require('utf8');
12
13var _utf2 = _interopRequireDefault(_utf);
14
15var _jsBase = require('js-base64');
16
17var _debug = require('debug');
18
19var _debug2 = _interopRequireDefault(_debug);
20
21function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
22
23function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
24
25function _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
27function _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
34var log = (0, _debug2.default)('github:repository');
35
36/**
37 * Repository encapsulates the functionality to create, query, and modify files.
38 */
39
40var 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
1151module.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":";;;;;;AAOA;;;;AACA;;;;AACA;;AAGA;;;;;;;;;;+eAZA;;;;;;;AAaA,IAAMA,MAAM,qBAAM,mBAAN,CAAZ;;AAEA;;;;IAGMC,U;;;AACH;;;;;;AAMA,uBAAYC,QAAZ,EAAsBC,IAAtB,EAA4BC,OAA5B,EAAqC;AAAA;;AAAA,0HAC5BD,IAD4B,EACtBC,OADsB;;AAElC,YAAKC,UAAL,GAAkBH,QAAlB;AACA,YAAKI,aAAL,GAAqB;AAClBC,iBAAQ,IADU;AAElBC,cAAK;AAFa,OAArB;AAHkC;AAOpC;;AAED;;;;;;;;;;;6BAOOC,G,EAAKC,E,EAAI;AACb,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,kBAA2DI,GAA3D,EAAkE,IAAlE,EAAwEC,EAAxE,CAAP;AACF;;AAED;;;;;;;;;;gCAOUE,O,EAASF,E,EAAI;AACpB,gBAAO,KAAKC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,gBAA4DO,OAA5D,EAAqEF,EAArE,CAAP;AACF;;AAED;;;;;;;;;;gCAOUD,G,EAAKC,E,EAAI;AAChB,gBAAO,KAAKC,QAAL,CAAc,QAAd,cAAkC,KAAKN,UAAvC,kBAA8DI,GAA9D,EAAqE,IAArE,EAA2EC,EAA3E,CAAP;AACF;;AAED;;;;;;;;;iCAMWA,E,EAAI;AACZ,gBAAO,KAAKC,QAAL,CAAc,QAAd,cAAkC,KAAKN,UAAvC,EAAqD,IAArD,EAA2DK,EAA3D,CAAP;AACF;;AAED;;;;;;;;;+BAMSA,E,EAAI;AACV,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,YAAuD,IAAvD,EAA6DK,EAA7D,CAAP;AACF;;AAED;;;;;;;;;;uCAOiBE,O,EAASF,E,EAAI;AAC3BE,mBAAUA,WAAW,EAArB;AACA,gBAAO,KAAKD,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,aAAwDO,OAAxD,EAAiEF,EAAjE,CAAP;AACF;;AAED;;;;;;;;;;qCAOeG,M,EAAQH,E,EAAI;AACxB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,eAAwDQ,MAAxD,EAAkE,IAAlE,EAAwEH,EAAxE,CAAP;AACF;;AAED;;;;;;;;;;2CAOqBG,M,EAAQH,E,EAAI;AAC9B,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,eAAwDQ,MAAxD,aAAwE,IAAxE,EAA8EH,EAA9E,CAAP;AACF;;AAED;;;;;;;;;;;sCAQgBI,I,EAAMC,I,EAAML,E,EAAI;AAC7B,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,iBAA0DS,IAA1D,WAAoEC,IAApE,EAA4E,IAA5E,EAAkFL,EAAlF,CAAP;AACF;;AAED;;;;;;;;;mCAMaA,E,EAAI;AACd,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,gBAA2D,IAA3D,EAAiEK,EAAjE,CAAP;AACF;;AAED;;;;;;;;;;8BAOQF,G,EAAKE,E,EAAI;AACd,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,mBAA4DG,GAA5D,EAAmE,IAAnE,EAAyEE,EAAzE,EAA6E,KAA7E,CAAP;AACF;;AAED;;;;;;;;;;gCAOUH,M,EAAQG,E,EAAI;AACnB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,kBAA2DE,MAA3D,EAAqE,IAArE,EAA2EG,EAA3E,CAAP;AACF;;AAED;;;;;;;;;;gCAOUF,G,EAAKE,E,EAAI;AAChB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,qBAA8DG,GAA9D,EAAqE,IAArE,EAA2EE,EAA3E,CAAP;AACF;;AAED;;;;;;;;;;;;;;;kCAYYE,O,EAASF,E,EAAI;AACtBE,mBAAUA,WAAW,EAArB;AACA,aAAI,OAAOA,OAAP,KAAmB,UAAvB,EAAmC;AAChCF,iBAAKE,OAAL;AACAA,sBAAU,EAAV;AACF;AACDA,iBAAQI,KAAR,GAAgB,KAAKC,UAAL,CAAgBL,QAAQI,KAAxB,CAAhB;AACAJ,iBAAQM,KAAR,GAAgB,KAAKD,UAAL,CAAgBL,QAAQM,KAAxB,CAAhB;;AAEA,gBAAO,KAAKP,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,eAA0DO,OAA1D,EAAmEF,EAAnE,CAAP;AACF;;AAED;;;;;;;;;;;sCAQgBG,M,EAAQD,O,EAASF,E,EAAI;AAClCE,mBAAUA,WAAW,EAArB;AACA,aAAI,OAAOA,OAAP,KAAmB,UAAvB,EAAmC;AAChCF,iBAAKE,OAAL;AACAA,sBAAU,EAAV;AACF;AACD,gBAAO,KAAKD,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,eAAwDQ,MAAxD,eAA0ED,OAA1E,EAAmFF,EAAnF,CAAP;AACF;;AAEA;;;;;;;;;;sCAOeD,G,EAAKC,E,EAAI;AACtBD,eAAMA,OAAO,EAAb;AACA,gBAAO,KAAKE,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,iBAA0DI,GAA1D,EAAiE,IAAjE,EAAuEC,EAAvE,CAAP;AACF;;AAED;;;;;;;;;;;6BAQOH,M,EAAQY,I,EAAMT,E,EAAI;AACtBH,kBAASA,mBAAiBA,MAAjB,GAA4B,EAArC;AACA,gBAAO,KAAKI,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,kBAA2Dc,IAA3D,GAAkEZ,MAAlE,EAA4E,IAA5E,EAAkFG,EAAlF,CAAP;AACF;;AAED;;;;;;;;;;mCAOaF,G,EAAKE,E,EAAI;AACnB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,iBAA0DG,GAA1D,gBAA0E,IAA1E,EAAgFE,EAAhF,CAAP;AACF;;AAED;;;;;;;;;;wCAOkBF,G,EAAKE,E,EAAI;AACxB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,iBAA0DG,GAA1D,cAAwE,IAAxE,EAA8EE,EAA9E,CAAP;AACF;;AAED;;;;;;;;;;8BAOQU,O,EAASV,E,EAAI;AAClB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,mBAA4De,OAA5D,EAAuE,IAAvE,EAA6EV,EAA7E,CAAP;AACF;;AAED;;;;;;;;;;iCAOWW,O,EAASX,E,EAAI;AACrB,aAAIY,WAAW,KAAKC,iBAAL,CAAuBF,OAAvB,CAAf;;AAEArB,aAAI,iBAAJ,EAAuBsB,QAAvB;AACA,gBAAO,KAAKX,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,iBAA6DiB,QAA7D,EAAuEZ,EAAvE,CAAP;AACF;;AAED;;;;;;;;wCAKkBW,O,EAAS;AACxB,aAAI,OAAOA,OAAP,KAAmB,QAAvB,EAAiC;AAC9BrB,gBAAI,oBAAJ;AACA,mBAAO;AACJqB,wBAASG,cAAKC,MAAL,CAAYJ,OAAZ,CADL;AAEJK,yBAAU;AAFN,aAAP;AAKF,UAPD,MAOO,IAAI,OAAOC,MAAP,KAAkB,WAAlB,IAAiCN,mBAAmBM,MAAxD,EAAgE;AACpE3B,gBAAI,yBAAJ;AACA,mBAAO;AACJqB,wBAASA,QAAQO,QAAR,CAAiB,QAAjB,CADL;AAEJF,yBAAU;AAFN,aAAP;AAKF,UAPM,MAOA,IAAI,OAAOG,IAAP,KAAgB,WAAhB,IAA+BR,mBAAmBQ,IAAtD,EAA4D;AAChE7B,gBAAI,gCAAJ;AACA,mBAAO;AACJqB,wBAASS,eAAOL,MAAP,CAAcJ,OAAd,CADL;AAEJK,yBAAU;AAFN,aAAP;AAKF,UAPM,MAOA;AAAE;AACN1B,4DAA6CqB,OAA7C,yCAA6CA,OAA7C,YAAyDU,KAAKC,SAAL,CAAeX,OAAf,CAAzD;AACA,kBAAM,IAAIY,KAAJ,CAAU,mFAAV,CAAN;AACF;AACH;;AAED;;;;;;;;;;;;;iCAUWC,W,EAAaf,I,EAAMgB,O,EAASzB,E,EAAI;AACxC,aAAI0B,UAAU;AACXC,uBAAWH,WADA,EACa;AACxBI,kBAAM,CAAC;AACJnB,qBAAMA,IADF;AAEJX,oBAAK2B,OAFD;AAGJI,qBAAM,QAHF;AAIJC,qBAAM;AAJF,aAAD;AAFK,UAAd;;AAUA,gBAAO,KAAK7B,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,iBAA6D+B,OAA7D,EAAsE1B,EAAtE,CAAP;AACF;;AAED;;;;;;;;;;;iCAQW4B,I,EAAMG,O,EAAS/B,E,EAAI;AAC3B,gBAAO,KAAKC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,iBAA6D;AACjEiC,sBADiE;AAEjED,uBAAWI,OAFsD,CAE7C;AAF6C,UAA7D,EAGJ/B,EAHI,CAAP;AAIF;;AAED;;;;;;;;;;;;;;;6BAYOgC,M,EAAQJ,I,EAAMK,O,EAAS/B,O,EAASF,E,EAAI;AAAA;;AACxC,aAAI,OAAOE,OAAP,KAAmB,UAAvB,EAAmC;AAChCF,iBAAKE,OAAL;AACAA,sBAAU,EAAV;AACF;;AAED,aAAIgC,OAAO;AACRD,4BADQ;AAERL,sBAFQ;AAGRO,qBAAS,CAACH,MAAD;AAHD,UAAX;;AAMAE,gBAAOE,OAAOC,MAAP,CAAc,EAAd,EAAkBnC,OAAlB,EAA2BgC,IAA3B,CAAP;;AAEA,gBAAO,KAAKjC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,mBAA+DuC,IAA/D,EAAqElC,EAArE,EACHsC,IADG,CACE,UAACC,QAAD,EAAc;AACjB,mBAAK3C,aAAL,CAAmBE,GAAnB,GAAyByC,SAASL,IAAT,CAAcpC,GAAvC,CADiB,CAC2B;AAC5C,mBAAOyC,QAAP;AACF,UAJG,CAAP;AAKF;;AAED;;;;;;;;;;;;iCASWxC,G,EAAKyC,S,EAAWC,K,EAAOzC,E,EAAI;AACnC,gBAAO,KAAKC,QAAL,CAAc,OAAd,cAAiC,KAAKN,UAAtC,kBAA6DI,GAA7D,EAAoE;AACxED,iBAAK0C,SADmE;AAExEC,mBAAOA;AAFiE,UAApE,EAGJzC,EAHI,CAAP;AAIF;;AAED;;;;;;;;;;;;;;;mCAYawC,S,EAAWtC,O,EAASF,E,EAAI;AAClC,gBAAO,KAAKC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,kBAA4D6C,SAA5D,EAAyEtC,OAAzE,EAAkFF,EAAlF,CAAP;AACF;;AAED;;;;;;;;;;;;;;;;;;uCAeiBE,O,EAASF,E,EAAI;AAC3B,gBAAO,KAAKC,QAAL,CAAc,OAAd,cAAiC,KAAKN,UAAtC,EAAoDO,OAApD,EAA6DF,EAA7D,CAAP;AACF;;AAEF;;;;;;;;;iCAMYA,E,EAAI;AACZ,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,EAAkD,IAAlD,EAAwDK,EAAxD,CAAP;AACF;;AAED;;;;;;;;;sCAMgBA,E,EAAI;AACjB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,oBAA+D,IAA/D,EAAqEK,EAArE,CAAP;AACF;;AAED;;;;;;;;;0CAMoBA,E,EAAI;AACrB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,0BAAqE,IAArE,EAA2EK,EAA3E,CAAP;AACF;;AAED;;;;;;;;;;uCAOiBA,E,EAAI;AAClB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,qBAAgE,IAAhE,EAAsEK,EAAtE,CAAP;AACF;;AAED;;;;;;;;;;qCAOe0C,Q,EAAU1C,E,EAAI;AAC1B,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,uBAAgE+C,QAAhE,EAA4E,IAA5E,EAAkF1C,EAAlF,CAAP;AACF;;AAED;;;;;;;;;;;;kCASYD,G,EAAKU,I,EAAMkC,G,EAAK3C,E,EAAI;AAC7BS,gBAAOA,YAAUmC,UAAUnC,IAAV,CAAV,GAA8B,EAArC;AACA,gBAAO,KAAKR,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,kBAA2Dc,IAA3D,EAAmE;AACvEV;AADuE,UAAnE,EAEJC,EAFI,EAEA2C,GAFA,CAAP;AAGF;;AAED;;;;;;;;;;;gCAQU5C,G,EAAK4C,G,EAAK3C,E,EAAI;AACrB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,cAAyD;AAC7DI;AAD6D,UAAzD,EAEJC,EAFI,EAEA2C,GAFA,CAAP;AAGF;;AAED;;;;;;;;;2BAMK3C,E,EAAI;AACN,gBAAO,KAAKC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,aAAyD,IAAzD,EAA+DK,EAA/D,CAAP;AACF;;AAED;;;;;;;;;;;gCAQU6C,G,EAAK7C,E,EAAI;AAChB,gBAAO,KAAKC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,4BAAsEkD,GAAtE,EAA6E,IAA7E,EAAmF7C,EAAnF,CAAP;AACF;;AAED;;;;;;;;;gCAMUA,E,EAAI;AACX,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,aAAwD,IAAxD,EAA8DK,EAA9D,CAAP;AACF;;AAED;;;;;;;;;;mCAOa8C,S,EAAWC,S,EAAW/C,E,EAAI;AAAA;;AACpC,aAAI,OAAO+C,SAAP,KAAqB,UAAzB,EAAqC;AAClC/C,iBAAK+C,SAAL;AACAA,wBAAYD,SAAZ;AACAA,wBAAY,QAAZ;AACF;;AAED,gBAAO,KAAKE,MAAL,YAAqBF,SAArB,EACHR,IADG,CACE,UAACC,QAAD,EAAc;AACjB,gBAAIzC,MAAMyC,SAASL,IAAT,CAAce,MAAd,CAAqBnD,GAA/B;AACA,mBAAO,OAAKoD,SAAL,CAAe;AACnBpD,uBADmB;AAEnBC,oCAAmBgD;AAFA,aAAf,EAGJ/C,EAHI,CAAP;AAIF,UAPG,CAAP;AAQF;;AAED;;;;;;;;;;wCAOkBE,O,EAASF,E,EAAI;AAC5B,gBAAO,KAAKC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,aAAyDO,OAAzD,EAAkEF,EAAlE,CAAP;AACF;;AAED;;;;;;;;;;;wCAQkBG,M,EAAQD,O,EAASF,E,EAAI;AACpC,gBAAO,KAAKC,QAAL,CAAc,OAAd,cAAiC,KAAKN,UAAtC,eAA0DQ,MAA1D,EAAoED,OAApE,EAA6EF,EAA7E,CAAP;AACF;;AAED;;;;;;;;;gCAMUA,E,EAAI;AACX,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,aAAwD,IAAxD,EAA8DK,EAA9D,CAAP;AACF;;AAED;;;;;;;;;;8BAOQmD,E,EAAInD,E,EAAI;AACb,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,eAAwDwD,EAAxD,EAA8D,IAA9D,EAAoEnD,EAApE,CAAP;AACF;;AAED;;;;;;;;;;iCAOWE,O,EAASF,E,EAAI;AACrB,gBAAO,KAAKC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,aAAyDO,OAAzD,EAAkEF,EAAlE,CAAP;AACF;;AAED;;;;;;;;;;;iCAQWmD,E,EAAIjD,O,EAASF,E,EAAI;AACzB,gBAAO,KAAKC,QAAL,CAAc,OAAd,cAAiC,KAAKN,UAAtC,eAA0DwD,EAA1D,EAAgEjD,OAAhE,EAAyEF,EAAzE,CAAP;AACF;;AAED;;;;;;;;;;iCAOWmD,E,EAAInD,E,EAAI;AAChB,gBAAO,KAAKC,QAAL,CAAc,QAAd,cAAkC,KAAKN,UAAvC,eAA2DwD,EAA3D,EAAiE,IAAjE,EAAuEnD,EAAvE,CAAP;AACF;;AAED;;;;;;;;;+BAMSA,E,EAAI;AACV,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,YAAuD,IAAvD,EAA6DK,EAA7D,CAAP;AACF;;AAED;;;;;;;;;;6BAOOmD,E,EAAInD,E,EAAI;AACZ,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,cAAuDwD,EAAvD,EAA6D,IAA7D,EAAmEnD,EAAnE,CAAP;AACF;;AAED;;;;;;;;;;gCAOUE,O,EAASF,E,EAAI;AACpB,gBAAO,KAAKC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,YAAwDO,OAAxD,EAAiEF,EAAjE,CAAP;AACF;;AAED;;;;;;;;;;gCAOUmD,E,EAAInD,E,EAAI;AACf,gBAAO,KAAKC,QAAL,CAAc,QAAd,cAAkC,KAAKN,UAAvC,cAA0DwD,EAA1D,EAAgE,IAAhE,EAAsEnD,EAAtE,CAAP;AACF;;AAED;;;;;;;;;;;iCAQWH,M,EAAQY,I,EAAMT,E,EAAI;AAAA;;AAC1B,gBAAO,KAAKoD,MAAL,CAAYvD,MAAZ,EAAoBY,IAApB,EACH6B,IADG,CACE,UAACC,QAAD,EAAc;AACjB,gBAAMc,eAAe;AAClBpB,kDAAgCxB,IAAhC,OADkB;AAElBX,oBAAKyC,SAASL,IAAT,CAAcpC,GAFD;AAGlBD;AAHkB,aAArB;AAKA,mBAAO,OAAKI,QAAL,CAAc,QAAd,cAAkC,OAAKN,UAAvC,kBAA8Dc,IAA9D,EAAsE4C,YAAtE,EAAoFrD,EAApF,CAAP;AACF,UARG,CAAP;AASF;;AAED;;;;;;;;;;;2BAQKH,M,EAAQyD,O,EAASC,O,EAASvD,E,EAAI;AAAA;;AAChC,aAAIwD,eAAJ;AACA,gBAAO,KAAKR,MAAL,YAAqBnD,MAArB,EACHyC,IADG,CACE;AAAA,gBAASW,MAAT,QAAEf,IAAF,CAASe,MAAT;AAAA,mBAAsB,OAAKQ,OAAL,CAAgBR,OAAOnD,GAAvB,qBAAtB;AAAA,UADF,EAEHwC,IAFG,CAEE,iBAAyB;AAAA,mCAAvBJ,IAAuB;AAAA,gBAAhBN,IAAgB,cAAhBA,IAAgB;AAAA,gBAAV9B,GAAU,cAAVA,GAAU;;AAC5B0D,qBAAS1D,GAAT;AACA,gBAAI4B,UAAUE,KAAK8B,GAAL,CAAS,UAAC3D,GAAD,EAAS;AAC7B,mBAAIA,IAAIU,IAAJ,KAAa6C,OAAjB,EAA0B;AACvBvD,sBAAIU,IAAJ,GAAW8C,OAAX;AACF;AACD,mBAAIxD,IAAI+B,IAAJ,KAAa,MAAjB,EAAyB;AACtB,yBAAO/B,IAAID,GAAX;AACF;AACD,sBAAOC,GAAP;AACF,aARa,CAAd;AASA,mBAAO,OAAK4D,UAAL,CAAgBjC,OAAhB,CAAP;AACF,UAdG,EAeHY,IAfG,CAeE;AAAA,gBAAQV,IAAR,SAAEM,IAAF;AAAA,mBAAkB,OAAK0B,MAAL,CAAYJ,MAAZ,EAAoB5B,KAAK9B,GAAzB,iBAA0CwD,OAA1C,gBAA0DC,OAA1D,QAAlB;AAAA,UAfF,EAgBHjB,IAhBG,CAgBE;AAAA,gBAAQsB,MAAR,SAAE1B,IAAF;AAAA,mBAAoB,OAAK2B,UAAL,YAAyBhE,MAAzB,EAAmC+D,OAAO9D,GAA1C,EAA+C,IAA/C,EAAqDE,EAArD,CAApB;AAAA,UAhBF,CAAP;AAiBF;;AAED;;;;;;;;;;;;;;;;;gCAcUH,M,EAAQY,I,EAAME,O,EAASsB,O,EAAS/B,O,EAASF,E,EAAI;AAAA;;AACpDE,mBAAUA,WAAW,EAArB;AACA,aAAI,OAAOA,OAAP,KAAmB,UAAvB,EAAmC;AAChCF,iBAAKE,OAAL;AACAA,sBAAU,EAAV;AACF;AACD,aAAI4D,WAAWrD,OAAOmC,UAAUnC,IAAV,CAAP,GAAyB,EAAxC;AACA,aAAIsD,eAAe7D,QAAQa,MAAR,KAAmB,KAAtC;AACA,aAAI6C,SAAS;AACV/D,0BADU;AAEVoC,4BAFU;AAGV+B,oBAAQ9D,QAAQ8D,MAHN;AAIVC,uBAAW/D,QAAQ+D,SAJT;AAKVtD,qBAASoD,eAAe3C,eAAOL,MAAP,CAAcJ,OAAd,CAAf,GAAwCA;AALvC,UAAb;;AAQA,gBAAO,KAAKyC,MAAL,CAAYvD,MAAZ,EAAoBiE,QAApB,EACHxB,IADG,CACE,UAACC,QAAD,EAAc;AACjBqB,mBAAO9D,GAAP,GAAayC,SAASL,IAAT,CAAcpC,GAA3B;AACA,mBAAO,OAAKG,QAAL,CAAc,KAAd,cAA+B,OAAKN,UAApC,kBAA2DmE,QAA3D,EAAuEF,MAAvE,EAA+E5D,EAA/E,CAAP;AACF,UAJG,EAID,YAAM;AACN,mBAAO,OAAKC,QAAL,CAAc,KAAd,cAA+B,OAAKN,UAApC,kBAA2DmE,QAA3D,EAAuEF,MAAvE,EAA+E5D,EAA/E,CAAP;AACF,UANG,CAAP;AAOF;;AAED;;;;;;;;;;gCAOUA,E,EAAI;AACX,gBAAO,KAAKkE,gBAAL,oBAAuC,KAAKvE,UAA5C,EAA0D,IAA1D,EAAgEK,EAAhE,CAAP;AACF;;AAED;;;;;;;;;2BAMKA,E,EAAI;AACN,gBAAO,KAAKC,QAAL,CAAc,KAAd,qBAAsC,KAAKN,UAA3C,EAAyD,IAAzD,EAA+DK,EAA/D,CAAP;AACF;;AAED;;;;;;;;;6BAMOA,E,EAAI;AACR,gBAAO,KAAKC,QAAL,CAAc,QAAd,qBAAyC,KAAKN,UAA9C,EAA4D,IAA5D,EAAkEK,EAAlE,CAAP;AACF;;AAED;;;;;;;;;;oCAOcE,O,EAASF,E,EAAI;AACxB,gBAAO,KAAKC,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,gBAA4DO,OAA5D,EAAqEF,EAArE,CAAP;AACF;;AAED;;;;;;;;;;;oCAQcmD,E,EAAIjD,O,EAASF,E,EAAI;AAC5B,gBAAO,KAAKC,QAAL,CAAc,OAAd,cAAiC,KAAKN,UAAtC,kBAA6DwD,EAA7D,EAAmEjD,OAAnE,EAA4EF,EAA5E,CAAP;AACF;;AAED;;;;;;;;;mCAMaA,E,EAAI;AACd,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,gBAA2D,IAA3D,EAAiEK,EAAjE,CAAP;AACF;;AAED;;;;;;;;;;iCAOWmD,E,EAAInD,E,EAAI;AAChB,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,kBAA2DwD,EAA3D,EAAiE,IAAjE,EAAuEnD,EAAvE,CAAP;AACF;;AAED;;;;;;;;;;oCAOcmD,E,EAAInD,E,EAAI;AACnB,gBAAO,KAAKC,QAAL,CAAc,QAAd,cAAkC,KAAKN,UAAvC,kBAA8DwD,EAA9D,EAAoE,IAApE,EAA0EnD,EAA1E,CAAP;AACF;;AAED;;;;;;;;;;;uCAQiBG,M,EAAQD,O,EAASF,E,EAAI;AACnC,gBAAO,KAAKC,QAAL,CAAc,KAAd,cAA+B,KAAKN,UAApC,eAAwDQ,MAAxD,aAAwED,OAAxE,EAAiFF,EAAjF,CAAP;AACF;;AAED;;;;;;;;;mCAMaA,E,EAAI;AACd,gBAAO,KAAKmE,gBAAL,aAAgC,KAAKxE,UAArC,gBAA4D,EAACyE,cAAc,iBAAf,EAA5D,EAA+FpE,EAA/F,CAAP;AACF;;AAED;;;;;;;;;;oCAOcE,O,EAASF,E,EAAI;AACxBE,mBAAUA,WAAW,EAArB;AACAA,iBAAQkE,YAAR,GAAuB,iBAAvB;AACA,gBAAO,KAAKnE,QAAL,CAAc,MAAd,cAAgC,KAAKN,UAArC,gBAA4DO,OAA5D,EAAqEF,EAArE,CAAP;AACF;;;;EA73BqBqE,qB;;AAi4BzBC,OAAOC,OAAP,GAAiBhF,UAAjB","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