UNPKG

34.2 kBJavaScriptView Raw
1'use strict';
2
3var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
4
5var _Requestable2 = require('./Requestable');
6
7var _Requestable3 = _interopRequireDefault(_Requestable2);
8
9function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
10
11function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
12
13function _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; }
14
15function _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; } /**
16 * @file
17 * @copyright 2013 Michael Aufreiter (Development Seed) and 2016 Yahoo Inc.
18 * @license Licensed under {@link https://spdx.org/licenses/BSD-3-Clause-Clear.html BSD-3-Clause-Clear}.
19 * Github.js is freely distributable.
20 */
21
22/**
23 * Issue wraps the functionality to get issues for repositories
24 */
25var Issue = function (_Requestable) {
26 _inherits(Issue, _Requestable);
27
28 /**
29 * Create a new Issue
30 * @param {string} repository - the full name of the repository (`:user/:repo`) to get issues for
31 * @param {Requestable.auth} [auth] - information required to authenticate to Github
32 * @param {string} [apiBase=https://api.github.com] - the base Github API URL
33 */
34 function Issue(repository, auth, apiBase) {
35 _classCallCheck(this, Issue);
36
37 var _this = _possibleConstructorReturn(this, (Issue.__proto__ || Object.getPrototypeOf(Issue)).call(this, auth, apiBase));
38
39 _this.__repository = repository;
40 return _this;
41 }
42
43 /**
44 * Create a new issue
45 * @see https://developer.github.com/v3/issues/#create-an-issue
46 * @param {Object} issueData - the issue to create
47 * @param {Requestable.callback} [cb] - will receive the created issue
48 * @return {Promise} - the promise for the http request
49 */
50
51
52 _createClass(Issue, [{
53 key: 'createIssue',
54 value: function createIssue(issueData, cb) {
55 return this._request('POST', '/repos/' + this.__repository + '/issues', issueData, cb);
56 }
57
58 /**
59 * List the issues for the repository
60 * @see https://developer.github.com/v3/issues/#list-issues-for-a-repository
61 * @param {Object} options - filtering options
62 * @param {Requestable.callback} [cb] - will receive the array of issues
63 * @return {Promise} - the promise for the http request
64 */
65
66 }, {
67 key: 'listIssues',
68 value: function listIssues(options, cb) {
69 return this._requestAllPages('/repos/' + this.__repository + '/issues', options, cb);
70 }
71
72 /**
73 * List the events for an issue
74 * @see https://developer.github.com/v3/issues/events/#list-events-for-an-issue
75 * @param {number} issue - the issue to get events for
76 * @param {Requestable.callback} [cb] - will receive the list of events
77 * @return {Promise} - the promise for the http request
78 */
79
80 }, {
81 key: 'listIssueEvents',
82 value: function listIssueEvents(issue, cb) {
83 return this._request('GET', '/repos/' + this.__repository + '/issues/' + issue + '/events', null, cb);
84 }
85
86 /**
87 * List comments on an issue
88 * @see https://developer.github.com/v3/issues/comments/#list-comments-on-an-issue
89 * @param {number} issue - the id of the issue to get comments from
90 * @param {Requestable.callback} [cb] - will receive the comments
91 * @return {Promise} - the promise for the http request
92 */
93
94 }, {
95 key: 'listIssueComments',
96 value: function listIssueComments(issue, cb) {
97 return this._request('GET', '/repos/' + this.__repository + '/issues/' + issue + '/comments', null, cb);
98 }
99
100 /**
101 * Get a single comment on an issue
102 * @see https://developer.github.com/v3/issues/comments/#get-a-single-comment
103 * @param {number} id - the comment id to get
104 * @param {Requestable.callback} [cb] - will receive the comment
105 * @return {Promise} - the promise for the http request
106 */
107
108 }, {
109 key: 'getIssueComment',
110 value: function getIssueComment(id, cb) {
111 return this._request('GET', '/repos/' + this.__repository + '/issues/comments/' + id, null, cb);
112 }
113
114 /**
115 * Comment on an issue
116 * @see https://developer.github.com/v3/issues/comments/#create-a-comment
117 * @param {number} issue - the id of the issue to comment on
118 * @param {string} comment - the comment to add
119 * @param {Requestable.callback} [cb] - will receive the created comment
120 * @return {Promise} - the promise for the http request
121 */
122
123 }, {
124 key: 'createIssueComment',
125 value: function createIssueComment(issue, comment, cb) {
126 return this._request('POST', '/repos/' + this.__repository + '/issues/' + issue + '/comments', { body: comment }, cb);
127 }
128
129 /**
130 * Edit a comment on an issue
131 * @see https://developer.github.com/v3/issues/comments/#edit-a-comment
132 * @param {number} id - the comment id to edit
133 * @param {string} comment - the comment to edit
134 * @param {Requestable.callback} [cb] - will receive the edited comment
135 * @return {Promise} - the promise for the http request
136 */
137
138 }, {
139 key: 'editIssueComment',
140 value: function editIssueComment(id, comment, cb) {
141 return this._request('PATCH', '/repos/' + this.__repository + '/issues/comments/' + id, { body: comment }, cb);
142 }
143
144 /**
145 * Delete a comment on an issue
146 * @see https://developer.github.com/v3/issues/comments/#delete-a-comment
147 * @param {number} id - the comment id to delete
148 * @param {Requestable.callback} [cb] - will receive true if the request is successful
149 * @return {Promise} - the promise for the http request
150 */
151
152 }, {
153 key: 'deleteIssueComment',
154 value: function deleteIssueComment(id, cb) {
155 return this._request('DELETE', '/repos/' + this.__repository + '/issues/comments/' + id, null, cb);
156 }
157
158 /**
159 * Edit an issue
160 * @see https://developer.github.com/v3/issues/#edit-an-issue
161 * @param {number} issue - the issue number to edit
162 * @param {Object} issueData - the new issue data
163 * @param {Requestable.callback} [cb] - will receive the modified issue
164 * @return {Promise} - the promise for the http request
165 */
166
167 }, {
168 key: 'editIssue',
169 value: function editIssue(issue, issueData, cb) {
170 return this._request('PATCH', '/repos/' + this.__repository + '/issues/' + issue, issueData, cb);
171 }
172
173 /**
174 * Get a particular issue
175 * @see https://developer.github.com/v3/issues/#get-a-single-issue
176 * @param {number} issue - the issue number to fetch
177 * @param {Requestable.callback} [cb] - will receive the issue
178 * @return {Promise} - the promise for the http request
179 */
180
181 }, {
182 key: 'getIssue',
183 value: function getIssue(issue, cb) {
184 return this._request('GET', '/repos/' + this.__repository + '/issues/' + issue, null, cb);
185 }
186
187 /**
188 * List the milestones for the repository
189 * @see https://developer.github.com/v3/issues/milestones/#list-milestones-for-a-repository
190 * @param {Object} options - filtering options
191 * @param {Requestable.callback} [cb] - will receive the array of milestones
192 * @return {Promise} - the promise for the http request
193 */
194
195 }, {
196 key: 'listMilestones',
197 value: function listMilestones(options, cb) {
198 return this._request('GET', '/repos/' + this.__repository + '/milestones', options, cb);
199 }
200
201 /**
202 * Get a milestone
203 * @see https://developer.github.com/v3/issues/milestones/#get-a-single-milestone
204 * @param {string} milestone - the id of the milestone to fetch
205 * @param {Requestable.callback} [cb] - will receive the milestone
206 * @return {Promise} - the promise for the http request
207 */
208
209 }, {
210 key: 'getMilestone',
211 value: function getMilestone(milestone, cb) {
212 return this._request('GET', '/repos/' + this.__repository + '/milestones/' + milestone, null, cb);
213 }
214
215 /**
216 * Create a new milestone
217 * @see https://developer.github.com/v3/issues/milestones/#create-a-milestone
218 * @param {Object} milestoneData - the milestone definition
219 * @param {Requestable.callback} [cb] - will receive the milestone
220 * @return {Promise} - the promise for the http request
221 */
222
223 }, {
224 key: 'createMilestone',
225 value: function createMilestone(milestoneData, cb) {
226 return this._request('POST', '/repos/' + this.__repository + '/milestones', milestoneData, cb);
227 }
228
229 /**
230 * Edit a milestone
231 * @see https://developer.github.com/v3/issues/milestones/#update-a-milestone
232 * @param {string} milestone - the id of the milestone to edit
233 * @param {Object} milestoneData - the updates to make to the milestone
234 * @param {Requestable.callback} [cb] - will receive the updated milestone
235 * @return {Promise} - the promise for the http request
236 */
237
238 }, {
239 key: 'editMilestone',
240 value: function editMilestone(milestone, milestoneData, cb) {
241 return this._request('PATCH', '/repos/' + this.__repository + '/milestones/' + milestone, milestoneData, cb);
242 }
243
244 /**
245 * Delete a milestone (this is distinct from closing a milestone)
246 * @see https://developer.github.com/v3/issues/milestones/#delete-a-milestone
247 * @param {string} milestone - the id of the milestone to delete
248 * @param {Requestable.callback} [cb] - will receive the status
249 * @return {Promise} - the promise for the http request
250 */
251
252 }, {
253 key: 'deleteMilestone',
254 value: function deleteMilestone(milestone, cb) {
255 return this._request('DELETE', '/repos/' + this.__repository + '/milestones/' + milestone, null, cb);
256 }
257
258 /**
259 * Create a new label
260 * @see https://developer.github.com/v3/issues/labels/#create-a-label
261 * @param {Object} labelData - the label definition
262 * @param {Requestable.callback} [cb] - will receive the object representing the label
263 * @return {Promise} - the promise for the http request
264 */
265
266 }, {
267 key: 'createLabel',
268 value: function createLabel(labelData, cb) {
269 return this._request('POST', '/repos/' + this.__repository + '/labels', labelData, cb);
270 }
271
272 /**
273 * List the labels for the repository
274 * @see https://developer.github.com/v3/issues/labels/#list-all-labels-for-this-repository
275 * @param {Object} options - filtering options
276 * @param {Requestable.callback} [cb] - will receive the array of labels
277 * @return {Promise} - the promise for the http request
278 */
279
280 }, {
281 key: 'listLabels',
282 value: function listLabels(options, cb) {
283 return this._request('GET', '/repos/' + this.__repository + '/labels', options, cb);
284 }
285
286 /**
287 * Get a label
288 * @see https://developer.github.com/v3/issues/labels/#get-a-single-label
289 * @param {string} label - the name of the label to fetch
290 * @param {Requestable.callback} [cb] - will receive the label
291 * @return {Promise} - the promise for the http request
292 */
293
294 }, {
295 key: 'getLabel',
296 value: function getLabel(label, cb) {
297 return this._request('GET', '/repos/' + this.__repository + '/labels/' + label, null, cb);
298 }
299
300 /**
301 * Edit a label
302 * @see https://developer.github.com/v3/issues/labels/#update-a-label
303 * @param {string} label - the name of the label to edit
304 * @param {Object} labelData - the updates to make to the label
305 * @param {Requestable.callback} [cb] - will receive the updated label
306 * @return {Promise} - the promise for the http request
307 */
308
309 }, {
310 key: 'editLabel',
311 value: function editLabel(label, labelData, cb) {
312 return this._request('PATCH', '/repos/' + this.__repository + '/labels/' + label, labelData, cb);
313 }
314
315 /**
316 * Delete a label
317 * @see https://developer.github.com/v3/issues/labels/#delete-a-label
318 * @param {string} label - the name of the label to delete
319 * @param {Requestable.callback} [cb] - will receive the status
320 * @return {Promise} - the promise for the http request
321 */
322
323 }, {
324 key: 'deleteLabel',
325 value: function deleteLabel(label, cb) {
326 return this._request('DELETE', '/repos/' + this.__repository + '/labels/' + label, null, cb);
327 }
328 }]);
329
330 return Issue;
331}(_Requestable3.default);
332
333module.exports = Issue;
334//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Issue.js"],"names":["Issue","repository","auth","apiBase","__repository","issueData","cb","_request","options","_requestAllPages","issue","id","comment","body","milestone","milestoneData","labelData","label","Requestable","module","exports"],"mappings":"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","file":"Issue.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';\n\n/**\n * Issue wraps the functionality to get issues for repositories\n */\nclass Issue extends Requestable {\n   /**\n    * Create a new Issue\n    * @param {string} repository - the full name of the repository (`:user/:repo`) to get issues for\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(repository, auth, apiBase) {\n      super(auth, apiBase);\n      this.__repository = repository;\n   }\n\n   /**\n    * Create a new issue\n    * @see https://developer.github.com/v3/issues/#create-an-issue\n    * @param {Object} issueData - the issue to create\n    * @param {Requestable.callback} [cb] - will receive the created issue\n    * @return {Promise} - the promise for the http request\n    */\n   createIssue(issueData, cb) {\n      return this._request('POST', `/repos/${this.__repository}/issues`, issueData, cb);\n   }\n\n   /**\n    * List the issues for the repository\n    * @see https://developer.github.com/v3/issues/#list-issues-for-a-repository\n    * @param {Object} options - filtering options\n    * @param {Requestable.callback} [cb] - will receive the array of issues\n    * @return {Promise} - the promise for the http request\n    */\n   listIssues(options, cb) {\n      return this._requestAllPages(`/repos/${this.__repository}/issues`, options, cb);\n   }\n\n   /**\n    * List the events for an issue\n    * @see https://developer.github.com/v3/issues/events/#list-events-for-an-issue\n    * @param {number} issue - the issue to get events for\n    * @param {Requestable.callback} [cb] - will receive the list of events\n    * @return {Promise} - the promise for the http request\n    */\n   listIssueEvents(issue, cb) {\n      return this._request('GET', `/repos/${this.__repository}/issues/${issue}/events`, null, cb);\n   }\n\n   /**\n    * List comments on an issue\n    * @see https://developer.github.com/v3/issues/comments/#list-comments-on-an-issue\n    * @param {number} issue - the id of the issue to get comments from\n    * @param {Requestable.callback} [cb] - will receive the comments\n    * @return {Promise} - the promise for the http request\n    */\n   listIssueComments(issue, cb) {\n      return this._request('GET', `/repos/${this.__repository}/issues/${issue}/comments`, null, cb);\n   }\n\n   /**\n    * Get a single comment on an issue\n    * @see https://developer.github.com/v3/issues/comments/#get-a-single-comment\n    * @param {number} id - the comment id to get\n    * @param {Requestable.callback} [cb] - will receive the comment\n    * @return {Promise} - the promise for the http request\n    */\n   getIssueComment(id, cb) {\n      return this._request('GET', `/repos/${this.__repository}/issues/comments/${id}`, null, cb);\n   }\n\n   /**\n    * Comment on an issue\n    * @see https://developer.github.com/v3/issues/comments/#create-a-comment\n    * @param {number} issue - the id of the issue to comment on\n    * @param {string} comment - the comment to add\n    * @param {Requestable.callback} [cb] - will receive the created comment\n    * @return {Promise} - the promise for the http request\n    */\n   createIssueComment(issue, comment, cb) {\n      return this._request('POST', `/repos/${this.__repository}/issues/${issue}/comments`, {body: comment}, cb);\n   }\n\n   /**\n    * Edit a comment on an issue\n    * @see https://developer.github.com/v3/issues/comments/#edit-a-comment\n    * @param {number} id - the comment id to edit\n    * @param {string} comment - the comment to edit\n    * @param {Requestable.callback} [cb] - will receive the edited comment\n    * @return {Promise} - the promise for the http request\n    */\n   editIssueComment(id, comment, cb) {\n      return this._request('PATCH', `/repos/${this.__repository}/issues/comments/${id}`, {body: comment}, cb);\n   }\n\n   /**\n    * Delete a comment on an issue\n    * @see https://developer.github.com/v3/issues/comments/#delete-a-comment\n    * @param {number} id - the comment id to delete\n    * @param {Requestable.callback} [cb] - will receive true if the request is successful\n    * @return {Promise} - the promise for the http request\n    */\n   deleteIssueComment(id, cb) {\n      return this._request('DELETE', `/repos/${this.__repository}/issues/comments/${id}`, null, cb);\n   }\n\n   /**\n    * Edit an issue\n    * @see https://developer.github.com/v3/issues/#edit-an-issue\n    * @param {number} issue - the issue number to edit\n    * @param {Object} issueData - the new issue data\n    * @param {Requestable.callback} [cb] - will receive the modified issue\n    * @return {Promise} - the promise for the http request\n    */\n   editIssue(issue, issueData, cb) {\n      return this._request('PATCH', `/repos/${this.__repository}/issues/${issue}`, issueData, cb);\n   }\n\n   /**\n    * Get a particular issue\n    * @see https://developer.github.com/v3/issues/#get-a-single-issue\n    * @param {number} issue - the issue number to fetch\n    * @param {Requestable.callback} [cb] - will receive the issue\n    * @return {Promise} - the promise for the http request\n    */\n   getIssue(issue, cb) {\n      return this._request('GET', `/repos/${this.__repository}/issues/${issue}`, null, cb);\n   }\n\n   /**\n    * List the milestones for the repository\n    * @see https://developer.github.com/v3/issues/milestones/#list-milestones-for-a-repository\n    * @param {Object} options - filtering options\n    * @param {Requestable.callback} [cb] - will receive the array of milestones\n    * @return {Promise} - the promise for the http request\n    */\n   listMilestones(options, cb) {\n      return this._request('GET', `/repos/${this.__repository}/milestones`, options, cb);\n   }\n\n   /**\n    * Get a milestone\n    * @see https://developer.github.com/v3/issues/milestones/#get-a-single-milestone\n    * @param {string} milestone - the id of the milestone to fetch\n    * @param {Requestable.callback} [cb] - will receive the milestone\n    * @return {Promise} - the promise for the http request\n    */\n   getMilestone(milestone, cb) {\n      return this._request('GET', `/repos/${this.__repository}/milestones/${milestone}`, null, cb);\n   }\n\n   /**\n    * Create a new milestone\n    * @see https://developer.github.com/v3/issues/milestones/#create-a-milestone\n    * @param {Object} milestoneData - the milestone definition\n    * @param {Requestable.callback} [cb] - will receive the milestone\n    * @return {Promise} - the promise for the http request\n    */\n   createMilestone(milestoneData, cb) {\n      return this._request('POST', `/repos/${this.__repository}/milestones`, milestoneData, cb);\n   }\n\n   /**\n    * Edit a milestone\n    * @see https://developer.github.com/v3/issues/milestones/#update-a-milestone\n    * @param {string} milestone - the id of the milestone to edit\n    * @param {Object} milestoneData - the updates to make to the milestone\n    * @param {Requestable.callback} [cb] - will receive the updated milestone\n    * @return {Promise} - the promise for the http request\n    */\n   editMilestone(milestone, milestoneData, cb) {\n      return this._request('PATCH', `/repos/${this.__repository}/milestones/${milestone}`, milestoneData, cb);\n   }\n\n   /**\n    * Delete a milestone (this is distinct from closing a milestone)\n    * @see https://developer.github.com/v3/issues/milestones/#delete-a-milestone\n    * @param {string} milestone - the id of the milestone to delete\n    * @param {Requestable.callback} [cb] - will receive the status\n    * @return {Promise} - the promise for the http request\n    */\n   deleteMilestone(milestone, cb) {\n      return this._request('DELETE', `/repos/${this.__repository}/milestones/${milestone}`, null, cb);\n   }\n\n   /**\n    * Create a new label\n    * @see https://developer.github.com/v3/issues/labels/#create-a-label\n    * @param {Object} labelData - the label definition\n    * @param {Requestable.callback} [cb] - will receive the object representing the label\n    * @return {Promise} - the promise for the http request\n    */\n   createLabel(labelData, cb) {\n      return this._request('POST', `/repos/${this.__repository}/labels`, labelData, cb);\n   }\n\n  /**\n   * List the labels for the repository\n   * @see https://developer.github.com/v3/issues/labels/#list-all-labels-for-this-repository\n   * @param {Object} options - filtering options\n   * @param {Requestable.callback} [cb] - will receive the array of labels\n   * @return {Promise} - the promise for the http request\n   */\n   listLabels(options, cb) {\n      return this._request('GET', `/repos/${this.__repository}/labels`, options, cb);\n   }\n\n  /**\n   * Get a label\n   * @see https://developer.github.com/v3/issues/labels/#get-a-single-label\n   * @param {string} label - the name of the label to fetch\n   * @param {Requestable.callback} [cb] - will receive the label\n   * @return {Promise} - the promise for the http request\n   */\n   getLabel(label, cb) {\n      return this._request('GET', `/repos/${this.__repository}/labels/${label}`, null, cb);\n   }\n\n  /**\n   * Edit a label\n   * @see https://developer.github.com/v3/issues/labels/#update-a-label\n   * @param {string} label - the name of the label to edit\n   * @param {Object} labelData - the updates to make to the label\n   * @param {Requestable.callback} [cb] - will receive the updated label\n   * @return {Promise} - the promise for the http request\n   */\n   editLabel(label, labelData, cb) {\n      return this._request('PATCH', `/repos/${this.__repository}/labels/${label}`, labelData, cb);\n   }\n\n  /**\n   * Delete a label\n   * @see https://developer.github.com/v3/issues/labels/#delete-a-label\n   * @param {string} label - the name of the label to delete\n   * @param {Requestable.callback} [cb] - will receive the status\n   * @return {Promise} - the promise for the http request\n   */\n   deleteLabel(label, cb) {\n      return this._request('DELETE', `/repos/${this.__repository}/labels/${label}`, null, cb);\n   }\n}\n\nmodule.exports = Issue;\n"]}
335//# sourceMappingURL=Issue.js.map