@vssue/api-gitlab-v4
Advanced tools
Comparing version 0.1.9 to 0.2.0
324
lib/index.js
@@ -17,3 +17,3 @@ import * as tslib_1 from "tslib"; | ||
this.repo = repo; | ||
this.labels = labels; | ||
this.labels = labels.join(','); | ||
this.clientId = clientId; | ||
@@ -31,2 +31,5 @@ this.clientSecret = clientSecret; | ||
Object.defineProperty(GitlabV4.prototype, "platform", { | ||
/** | ||
* The platform api info | ||
*/ | ||
get: function () { | ||
@@ -37,2 +40,6 @@ return { | ||
version: 'v4', | ||
meta: { | ||
reactable: true, | ||
sortable: true, | ||
}, | ||
}; | ||
@@ -43,3 +50,6 @@ }, | ||
}); | ||
GitlabV4.prototype.redirectAuthorize = function () { | ||
/** | ||
* Redirect to the authorization page of platform. | ||
*/ | ||
GitlabV4.prototype.redirectAuth = function () { | ||
window.location.href = buildURL(concatURL(this.baseURL, 'oauth/authorize'), { | ||
@@ -52,3 +62,11 @@ client_id: this.clientId, | ||
}; | ||
GitlabV4.prototype.handleAuthorize = function () { | ||
/** | ||
* Handle authorization. | ||
* | ||
* @remarks | ||
* If the `code` and `state` exist in the query, and the `state` matches, remove them from query, and try to get the access token. | ||
* | ||
* @return A string for access token, `null` for no authorization code | ||
*/ | ||
GitlabV4.prototype.handleAuth = function () { | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
@@ -78,6 +96,13 @@ var query, code, replaceURL, accessToken; | ||
}; | ||
/** | ||
* Get user access token via `code` | ||
* | ||
* @param options.code - The code from the query | ||
* | ||
* @return User access token | ||
*/ | ||
GitlabV4.prototype.getAccessToken = function (_a) { | ||
var code = _a.code; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var response, accessToken; | ||
var data; | ||
return tslib_1.__generator(this, function (_b) { | ||
@@ -93,5 +118,4 @@ switch (_b.label) { | ||
case 1: | ||
response = _b.sent(); | ||
accessToken = response.data.access_token; | ||
return [2 /*return*/, accessToken]; | ||
data = (_b.sent()).data; | ||
return [2 /*return*/, data.access_token]; | ||
} | ||
@@ -101,6 +125,13 @@ }); | ||
}; | ||
/** | ||
* Get the logined user with access token. | ||
* | ||
* @param options.accessToken - User access token | ||
* | ||
* @return The user | ||
*/ | ||
GitlabV4.prototype.getUser = function (_a) { | ||
var accessToken = _a.accessToken; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var response, user; | ||
var data; | ||
return tslib_1.__generator(this, function (_b) { | ||
@@ -112,5 +143,4 @@ switch (_b.label) { | ||
case 1: | ||
response = _b.sent(); | ||
user = response.data; | ||
return [2 /*return*/, normalizeUser(user)]; | ||
data = (_b.sent()).data; | ||
return [2 /*return*/, normalizeUser(data)]; | ||
} | ||
@@ -120,16 +150,19 @@ }); | ||
}; | ||
GitlabV4.prototype.getIssues = function (_a) { | ||
var accessToken = _a.accessToken; | ||
/** | ||
* Get issue of this page according to the issue id or the issue title | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.issueTitle - The title of issue | ||
* | ||
* @return The raw response of issue | ||
*/ | ||
GitlabV4.prototype.getIssue = function (_a) { | ||
var accessToken = _a.accessToken, issueId = _a.issueId, issueTitle = _a.issueTitle; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var options, response, issues; | ||
var options, data, e_1, data, issue; | ||
return tslib_1.__generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
options = { | ||
params: { | ||
labels: this.labels, | ||
// to avoid caching | ||
timestamp: Date.now(), | ||
}, | ||
}; | ||
options = {}; | ||
if (accessToken) { | ||
@@ -140,7 +173,33 @@ options.headers = { | ||
} | ||
if (!issueId) return [3 /*break*/, 5]; | ||
_b.label = 1; | ||
case 1: | ||
_b.trys.push([1, 3, , 4]); | ||
return [4 /*yield*/, this.$http.get("api/v4/projects/" + this._encodedRepo + "/issues/" + issueId, options)]; | ||
case 2: | ||
data = (_b.sent()).data; | ||
return [2 /*return*/, normalizeIssue(data)]; | ||
case 3: | ||
e_1 = _b.sent(); | ||
if (e_1.response && e_1.response.status === 404) { | ||
return [2 /*return*/, null]; | ||
} | ||
else { | ||
throw e_1; | ||
} | ||
return [3 /*break*/, 4]; | ||
case 4: return [3 /*break*/, 7]; | ||
case 5: | ||
options.params = { | ||
labels: this.labels, | ||
order_by: 'created_at', | ||
sort: 'asc', | ||
search: issueTitle, | ||
}; | ||
return [4 /*yield*/, this.$http.get("api/v4/projects/" + this._encodedRepo + "/issues", options)]; | ||
case 1: | ||
response = _b.sent(); | ||
issues = response.data; | ||
return [2 /*return*/, issues.map(normalizeIssue)]; | ||
case 6: | ||
data = (_b.sent()).data; | ||
issue = data.map(normalizeIssue).find(function (item) { return item.title === issueTitle; }); | ||
return [2 /*return*/, issue || null]; | ||
case 7: return [2 /*return*/]; | ||
} | ||
@@ -150,14 +209,26 @@ }); | ||
}; | ||
/** | ||
* Get comments of this page according to the issue id or the issue title | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.query - The query parameters | ||
* | ||
* @return The comments | ||
*/ | ||
GitlabV4.prototype.getComments = function (_a) { | ||
var issueId = _a.issueId, accessToken = _a.accessToken; | ||
var accessToken = _a.accessToken, issueId = _a.issueId, _b = _a.query, _c = _b === void 0 ? {} : _b, _d = _c.page, page = _d === void 0 ? 1 : _d, _e = _c.perPage, perPage = _e === void 0 ? 10 : _e, _f = _c.sort, sort = _f === void 0 ? 'desc' : _f; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var e_1, _b, options, response, comments, getCommentsMeta, _loop_1, comments_1, comments_1_1, comment; | ||
var e_2, _g, options, response, commentsRaw, getCommentsMeta, _loop_1, commentsRaw_1, commentsRaw_1_1, comment; | ||
var _this = this; | ||
return tslib_1.__generator(this, function (_c) { | ||
switch (_c.label) { | ||
return tslib_1.__generator(this, function (_h) { | ||
switch (_h.label) { | ||
case 0: | ||
options = { | ||
params: { | ||
// to avoid caching | ||
timestamp: Date.now(), | ||
// pagination | ||
'page': page, | ||
'per_page': perPage, | ||
'order_by': 'created_at', | ||
'sort': sort, | ||
}, | ||
@@ -172,4 +243,4 @@ }; | ||
case 1: | ||
response = _c.sent(); | ||
comments = response.data; | ||
response = _h.sent(); | ||
commentsRaw = response.data; | ||
getCommentsMeta = []; | ||
@@ -184,2 +255,3 @@ _loop_1 = function (comment) { | ||
return [4 /*yield*/, this.getMarkdownContent({ | ||
accessToken: accessToken, | ||
contentRaw: comment.body, | ||
@@ -200,5 +272,5 @@ })]; | ||
return [4 /*yield*/, this.getCommentReactions({ | ||
accessToken: accessToken, | ||
issueId: issueId, | ||
commentId: comment.id, | ||
accessToken: accessToken, | ||
})]; | ||
@@ -213,18 +285,23 @@ case 1: | ||
try { | ||
for (comments_1 = tslib_1.__values(comments), comments_1_1 = comments_1.next(); !comments_1_1.done; comments_1_1 = comments_1.next()) { | ||
comment = comments_1_1.value; | ||
for (commentsRaw_1 = tslib_1.__values(commentsRaw), commentsRaw_1_1 = commentsRaw_1.next(); !commentsRaw_1_1.done; commentsRaw_1_1 = commentsRaw_1.next()) { | ||
comment = commentsRaw_1_1.value; | ||
_loop_1(comment); | ||
} | ||
} | ||
catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||
catch (e_2_1) { e_2 = { error: e_2_1 }; } | ||
finally { | ||
try { | ||
if (comments_1_1 && !comments_1_1.done && (_b = comments_1.return)) _b.call(comments_1); | ||
if (commentsRaw_1_1 && !commentsRaw_1_1.done && (_g = commentsRaw_1.return)) _g.call(commentsRaw_1); | ||
} | ||
finally { if (e_1) throw e_1.error; } | ||
finally { if (e_2) throw e_2.error; } | ||
} | ||
return [4 /*yield*/, Promise.all(getCommentsMeta)]; | ||
case 2: | ||
_c.sent(); | ||
return [2 /*return*/, comments.map(normalizeComment)]; | ||
_h.sent(); | ||
return [2 /*return*/, { | ||
count: Number(response.headers['x-total']), | ||
page: Number(response.headers['x-page']), | ||
perPage: Number(response.headers['x-per-page']), | ||
data: commentsRaw.map(normalizeComment), | ||
}]; | ||
} | ||
@@ -234,16 +311,55 @@ }); | ||
}; | ||
/** | ||
* Get the parse HTML of markdown content | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.contentRaw - The id of issue | ||
* | ||
* @return `true` if succeed, `false` if failed | ||
*/ | ||
GitlabV4.prototype.getMarkdownContent = function (_a) { | ||
var accessToken = _a.accessToken, contentRaw = _a.contentRaw; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var options, data; | ||
return tslib_1.__generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
options = {}; | ||
if (accessToken) { | ||
options.headers = { | ||
'Authorization': "Bearer " + accessToken, | ||
}; | ||
} | ||
return [4 /*yield*/, this.$http.post("api/v4/markdown", { | ||
text: contentRaw, | ||
gfm: true, | ||
}, options)]; | ||
case 1: | ||
data = (_b.sent()).data; | ||
return [2 /*return*/, data.html]; | ||
} | ||
}); | ||
}); | ||
}; | ||
/** | ||
* Get reactions of a cooment | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.commentId - The id of comment | ||
* | ||
* @return The comments | ||
*/ | ||
GitlabV4.prototype.getCommentReactions = function (_a) { | ||
var issueId = _a.issueId, commentId = _a.commentId, accessToken = _a.accessToken; | ||
var accessToken = _a.accessToken, issueId = _a.issueId, commentId = _a.commentId; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var response, reactions; | ||
var data; | ||
return tslib_1.__generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: return [4 /*yield*/, this.$http.get("api/v4/projects/" + this._encodedRepo + "/issues/" + issueId + "/notes/" + commentId + "/award_emoji", { | ||
params: {}, | ||
headers: { 'Authorization': "Bearer " + accessToken }, | ||
})]; | ||
case 1: | ||
response = _b.sent(); | ||
reactions = response.data; | ||
return [2 /*return*/, normalizeReactions(reactions)]; | ||
data = (_b.sent()).data; | ||
return [2 /*return*/, normalizeReactions(data)]; | ||
} | ||
@@ -253,6 +369,15 @@ }); | ||
}; | ||
/** | ||
* Create a new issue | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.title - The title of issue | ||
* @param options.content - The content of issue | ||
* | ||
* @return The created issue | ||
*/ | ||
GitlabV4.prototype.createIssue = function (_a) { | ||
var title = _a.title, content = _a.content, accessToken = _a.accessToken; | ||
var accessToken = _a.accessToken, title = _a.title, content = _a.content; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var response, issue; | ||
var data; | ||
return tslib_1.__generator(this, function (_b) { | ||
@@ -268,5 +393,4 @@ switch (_b.label) { | ||
case 1: | ||
response = _b.sent(); | ||
issue = response.data; | ||
return [2 /*return*/, normalizeIssue(issue)]; | ||
data = (_b.sent()).data; | ||
return [2 /*return*/, normalizeIssue(data)]; | ||
} | ||
@@ -276,6 +400,15 @@ }); | ||
}; | ||
GitlabV4.prototype.createIssueComment = function (_a) { | ||
var issueId = _a.issueId, content = _a.content, accessToken = _a.accessToken; | ||
/** | ||
* Create a new comment | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.content - The content of comment | ||
* | ||
* @return The created comment | ||
*/ | ||
GitlabV4.prototype.createComment = function (_a) { | ||
var accessToken = _a.accessToken, issueId = _a.issueId, content = _a.content; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var response, comment; | ||
var data; | ||
return tslib_1.__generator(this, function (_b) { | ||
@@ -289,5 +422,4 @@ switch (_b.label) { | ||
case 1: | ||
response = _b.sent(); | ||
comment = response.data; | ||
return [2 /*return*/, normalizeComment(comment)]; | ||
data = (_b.sent()).data; | ||
return [2 /*return*/, normalizeComment(data)]; | ||
} | ||
@@ -297,6 +429,15 @@ }); | ||
}; | ||
/** | ||
* Create a new reaction of issue | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.reaction - The reaction | ||
* | ||
* @return `true` if succeed, `false` if already token | ||
*/ | ||
GitlabV4.prototype.createIssueReaction = function (_a) { | ||
var issueId = _a.issueId, reaction = _a.reaction, accessToken = _a.accessToken; | ||
var accessToken = _a.accessToken, issueId = _a.issueId, reaction = _a.reaction; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var e_2; | ||
var response, e_3; | ||
return tslib_1.__generator(this, function (_b) { | ||
@@ -312,7 +453,13 @@ switch (_b.label) { | ||
case 1: | ||
_b.sent(); | ||
return [2 /*return*/, true]; | ||
response = _b.sent(); | ||
return [2 /*return*/, response.status === 201]; | ||
case 2: | ||
e_2 = _b.sent(); | ||
return [2 /*return*/, false]; | ||
e_3 = _b.sent(); | ||
if (e_3.response && e_3.response.status === 404) { | ||
return [2 /*return*/, false]; | ||
} | ||
else { | ||
throw e_3; | ||
} | ||
return [3 /*break*/, 3]; | ||
case 3: return [2 /*return*/]; | ||
@@ -323,6 +470,16 @@ } | ||
}; | ||
/** | ||
* Create a new reaction of comment | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.commentId - The id of comment | ||
* @param options.reaction - The reaction | ||
* | ||
* @return `true` if succeed, `false` if already token | ||
*/ | ||
GitlabV4.prototype.createCommentReaction = function (_a) { | ||
var issueId = _a.issueId, commentId = _a.commentId, reaction = _a.reaction, accessToken = _a.accessToken; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var e_3; | ||
var response, e_4; | ||
return tslib_1.__generator(this, function (_b) { | ||
@@ -340,7 +497,16 @@ switch (_b.label) { | ||
case 1: | ||
_b.sent(); | ||
return [2 /*return*/, true]; | ||
response = _b.sent(); | ||
return [2 /*return*/, response.status === 201]; | ||
case 2: | ||
e_3 = _b.sent(); | ||
return [2 /*return*/, false]; | ||
e_4 = _b.sent(); | ||
// it could be a bug of gitlab | ||
// if a reaction (award emoji) has already existed, it returns a 404 response with a buggy message | ||
// have submitted a issue: https://gitlab.com/gitlab-org/gitlab-ce/issues/56147 | ||
if (e_4.response && e_4.response.status === 404) { | ||
return [2 /*return*/, false]; | ||
} | ||
else { | ||
throw e_4; | ||
} | ||
return [3 /*break*/, 3]; | ||
case 3: return [2 /*return*/]; | ||
@@ -351,23 +517,5 @@ } | ||
}; | ||
GitlabV4.prototype.getMarkdownContent = function (_a) { | ||
var contentRaw = _a.contentRaw; | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var response, content; | ||
return tslib_1.__generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: return [4 /*yield*/, this.$http.post("api/v4/markdown", { | ||
text: contentRaw, | ||
gfm: true, | ||
})]; | ||
case 1: | ||
response = _b.sent(); | ||
content = response.data.html; | ||
return [2 /*return*/, content]; | ||
} | ||
}); | ||
}); | ||
}; | ||
return GitlabV4; | ||
}()); | ||
export default GitlabV4; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Reactions,\n  VssueAPI,\n  VssueAPIOptions,\n} from 'vssue'\n\nimport axios, {\n  AxiosInstance,\n  AxiosRequestConfig,\n} from 'axios'\n\nimport {\n  buildURL,\n  concatURL,\n  getCleanURL,\n  parseQuery,\n} from '@vssue/utils'\n\nimport {\n  normalizeUser,\n  normalizeIssue,\n  normalizeComment,\n  normalizeReactions,\n  mapReactionName,\n} from './utils'\n\n/**\n * @see https://docs.gitlab.com/ce/api/oauth2.html\n * @see https://docs.gitlab.com/ce/api/issues.html\n * @see https://docs.gitlab.com/ce/api/notes.html\n * @see https://docs.gitlab.com/ce/api/award_emoji.html\n */\nexport default class GitlabV4 implements VssueAPI {\n  baseURL: string\n  owner: string\n  repo: string\n  labels: string\n  clientId: string\n  clientSecret: string\n  state: string\n  $http: AxiosInstance\n\n  private _encodedRepo: string\n\n  get platform () {\n    return {\n      name: 'GitLab',\n      link: this.baseURL,\n      version: 'v4',\n    }\n  }\n\n  constructor ({\n    baseURL = 'https://gitlab.com',\n    owner,\n    repo,\n    labels,\n    clientId,\n    clientSecret,\n    state,\n  }: VssueAPIOptions) {\n    this.baseURL = baseURL\n    this.owner = owner\n    this.repo = repo\n    this.labels = labels\n\n    this.clientId = clientId\n    this.clientSecret = clientSecret\n    this.state = state\n\n    this._encodedRepo = encodeURIComponent(`${this.owner}/${this.repo}`)\n\n    this.$http = axios.create({\n      baseURL,\n      headers: {\n        'Accept': 'application/json',\n      },\n    })\n  }\n\n  redirectAuthorize () {\n    window.location.href = buildURL(concatURL(this.baseURL, 'oauth/authorize'), {\n      client_id: this.clientId,\n      redirect_uri: window.location.href,\n      response_type: 'code',\n      state: this.state,\n    })\n  }\n\n  async handleAuthorize () {\n    const query = parseQuery(window.location.search)\n    if (query.code) {\n      if (query.state !== this.state) {\n        return null\n      }\n      const code = query.code\n      delete query.code\n      delete query.state\n      const replaceURL = buildURL(getCleanURL(window.location.href), query) + window.location.hash\n      window.history.replaceState(null, '', replaceURL)\n      const accessToken = await this.getAccessToken({ code })\n      return accessToken\n    }\n    return null\n  }\n\n  async getAccessToken ({ code }) {\n    const response = await this.$http.post(`https://cors-anywhere.herokuapp.com/${concatURL(this.baseURL, 'oauth/token')}`, {\n      client_id: this.clientId,\n      client_secret: this.clientSecret,\n      code,\n      grant_type: 'authorization_code',\n      redirect_uri: window.location.href,\n    })\n    const accessToken = response.data.access_token\n    return accessToken\n  }\n\n  async getUser ({ accessToken }) {\n    const response = await this.$http.get('api/v4/user', {\n      headers: { 'Authorization': `Bearer ${accessToken}` },\n    })\n    const user = response.data\n    return normalizeUser(user)\n  }\n\n  async getIssues ({ accessToken }) {\n    const options: AxiosRequestConfig = {\n      params: {\n        labels: this.labels,\n        // to avoid caching\n        timestamp: Date.now(),\n      },\n    }\n    if (accessToken) {\n      options.headers = {\n        'Authorization': `Bearer ${accessToken}`,\n      }\n    }\n    const response = await this.$http.get(`api/v4/projects/${this._encodedRepo}/issues`, options)\n    const issues = response.data\n    return issues.map(normalizeIssue)\n  }\n\n  async getComments ({\n    issueId,\n    accessToken,\n  }) {\n    const options: AxiosRequestConfig = {\n      params: {\n        // to avoid caching\n        timestamp: Date.now(),\n      },\n    }\n    if (accessToken) {\n      options.headers = {\n        'Authorization': `Bearer ${accessToken}`,\n      }\n    }\n    const response = await this.$http.get(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/notes`, options)\n    const comments = response.data\n\n    const getCommentsMeta: Array<Promise<void>> = []\n\n    for (const comment of comments) {\n      getCommentsMeta.push((async () => {\n        comment.body_html = await this.getMarkdownContent({\n          contentRaw: comment.body,\n        })\n      })())\n      getCommentsMeta.push((async () => {\n        comment.reactions = await this.getCommentReactions({\n          issueId: issueId,\n          commentId: comment.id,\n          accessToken: accessToken,\n        })\n      })())\n    }\n    await Promise.all(getCommentsMeta)\n    return comments.map(normalizeComment)\n  }\n\n  async getCommentReactions ({\n    issueId,\n    commentId,\n    accessToken,\n  }): Promise<Reactions> {\n    const response = await this.$http.get(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/notes/${commentId}/award_emoji`, {\n      params: {\n      },\n      headers: { 'Authorization': `Bearer ${accessToken}` },\n    })\n\n    const reactions = response.data\n    return normalizeReactions(reactions)\n  }\n\n  async createIssue ({\n    title,\n    content,\n    accessToken,\n  }) {\n    const response = await this.$http.post(`api/v4/projects/${this._encodedRepo}/issues`, {\n      title,\n      description: content,\n      labels: this.labels,\n    }, {\n      headers: { 'Authorization': `Bearer ${accessToken}` },\n    })\n    const issue = response.data\n    return normalizeIssue(issue)\n  }\n\n  async createIssueComment ({\n    issueId,\n    content,\n    accessToken,\n  }) {\n    const response = await this.$http.post(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/notes`, {\n      body: content,\n    }, {\n      headers: { 'Authorization': `Bearer ${accessToken}` },\n    })\n    const comment = response.data\n    return normalizeComment(comment)\n  }\n\n  async createIssueReaction ({\n    issueId,\n    reaction,\n    accessToken,\n  }) {\n    try {\n      await this.$http.post(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/award_emoji`, {\n        name: mapReactionName(reaction),\n      }, {\n        headers: { 'Authorization': `Bearer ${accessToken}` },\n      })\n      return true\n    } catch (e) {\n      return false\n    }\n  }\n\n  async createCommentReaction ({\n    issueId,\n    commentId,\n    reaction,\n    accessToken,\n  }) {\n    try {\n      await this.$http.post(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/notes/${commentId}/award_emoji`, {\n        name: mapReactionName(reaction),\n      }, {\n        headers: {\n          'Authorization': `Bearer ${accessToken}`,\n        },\n      })\n      return true\n    } catch (e) {\n      return false\n    }\n  }\n\n  async getMarkdownContent ({ contentRaw }): Promise<string> {\n    const response = await this.$http.post(`api/v4/markdown`, {\n      text: contentRaw,\n      gfm: true,\n    })\n    const content = response.data.html\n    return content\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  VssueAPI,\n  VssueAPIOptions,\n} from 'vssue'\n\nimport axios, {\n  AxiosInstance,\n  AxiosRequestConfig,\n} from 'axios'\n\nimport {\n  buildURL,\n  concatURL,\n  getCleanURL,\n  parseQuery,\n} from '@vssue/utils'\n\nimport {\n  normalizeUser,\n  normalizeIssue,\n  normalizeComment,\n  normalizeReactions,\n  mapReactionName,\n} from './utils'\n\n/**\n * @see https://docs.gitlab.com/ce/api/oauth2.html\n * @see https://docs.gitlab.com/ce/api/issues.html\n * @see https://docs.gitlab.com/ce/api/notes.html\n * @see https://docs.gitlab.com/ce/api/award_emoji.html\n */\nexport default class GitlabV4 implements VssueAPI.Instance {\n  baseURL: string\n  owner: string\n  repo: string\n  labels: string\n  clientId: string\n  clientSecret: string\n  state: string\n  $http: AxiosInstance\n\n  private _encodedRepo: string\n\n  constructor ({\n    baseURL = 'https://gitlab.com',\n    owner,\n    repo,\n    labels,\n    clientId,\n    clientSecret,\n    state,\n  }: VssueAPIOptions) {\n    this.baseURL = baseURL\n    this.owner = owner\n    this.repo = repo\n    this.labels = labels.join(',')\n\n    this.clientId = clientId\n    this.clientSecret = clientSecret\n    this.state = state\n\n    this._encodedRepo = encodeURIComponent(`${this.owner}/${this.repo}`)\n\n    this.$http = axios.create({\n      baseURL,\n      headers: {\n        'Accept': 'application/json',\n      },\n    })\n  }\n\n  /**\n   * The platform api info\n   */\n  get platform (): VssueAPI.Platform {\n    return {\n      name: 'GitLab',\n      link: this.baseURL,\n      version: 'v4',\n      meta: {\n        reactable: true,\n        sortable: true,\n      },\n    }\n  }\n\n  /**\n   * Redirect to the authorization page of platform.\n   */\n  redirectAuth (): void {\n    window.location.href = buildURL(concatURL(this.baseURL, 'oauth/authorize'), {\n      client_id: this.clientId,\n      redirect_uri: window.location.href,\n      response_type: 'code',\n      state: this.state,\n    })\n  }\n\n  /**\n   * Handle authorization.\n   *\n   * @remarks\n   * If the `code` and `state` exist in the query, and the `state` matches, remove them from query, and try to get the access token.\n   *\n   * @return A string for access token, `null` for no authorization code\n   */\n  async handleAuth (): Promise<string | null> {\n    const query = parseQuery(window.location.search)\n    if (query.code) {\n      if (query.state !== this.state) {\n        return null\n      }\n      const code = query.code\n      delete query.code\n      delete query.state\n      const replaceURL = buildURL(getCleanURL(window.location.href), query) + window.location.hash\n      window.history.replaceState(null, '', replaceURL)\n      const accessToken = await this.getAccessToken({ code })\n      return accessToken\n    }\n    return null\n  }\n\n  /**\n   * Get user access token via `code`\n   *\n   * @param options.code - The code from the query\n   *\n   * @return User access token\n   */\n  async getAccessToken ({ code }: { code: string }): Promise<string> {\n    const { data } = await this.$http.post(`https://cors-anywhere.herokuapp.com/${concatURL(this.baseURL, 'oauth/token')}`, {\n      client_id: this.clientId,\n      client_secret: this.clientSecret,\n      code,\n      grant_type: 'authorization_code',\n      redirect_uri: window.location.href,\n    })\n    return data.access_token\n  }\n\n  /**\n   * Get the logined user with access token.\n   *\n   * @param options.accessToken - User access token\n   *\n   * @return The user\n   */\n  async getUser ({ accessToken }): Promise<VssueAPI.User> {\n    const { data } = await this.$http.get('api/v4/user', {\n      headers: { 'Authorization': `Bearer ${accessToken}` },\n    })\n    return normalizeUser(data)\n  }\n\n  /**\n   * Get issue of this page according to the issue id or the issue title\n   *\n   * @param options.accessToken - User access token\n   * @param options.issueId - The id of issue\n   * @param options.issueTitle - The title of issue\n   *\n   * @return The raw response of issue\n   */\n\n  async getIssue ({\n    accessToken,\n    issueId,\n    issueTitle,\n  }): Promise<VssueAPI.Issue | null> {\n    const options: AxiosRequestConfig = {}\n\n    if (accessToken) {\n      options.headers = {\n        'Authorization': `Bearer ${accessToken}`,\n      }\n    }\n\n    if (issueId) {\n      try {\n        const { data } = await this.$http.get(`api/v4/projects/${this._encodedRepo}/issues/${issueId}`, options)\n        return normalizeIssue(data)\n      } catch (e) {\n        if (e.response && e.response.status === 404) {\n          return null\n        } else {\n          throw e\n        }\n      }\n    } else {\n      options.params = {\n        labels: this.labels,\n        order_by: 'created_at',\n        sort: 'asc',\n        search: issueTitle,\n      }\n      const { data } = await this.$http.get(`api/v4/projects/${this._encodedRepo}/issues`, options)\n      const issue = data.map(normalizeIssue).find(item => item.title === issueTitle)\n      return issue || null\n    }\n  }\n\n  /**\n   * Get comments of this page according to the issue id or the issue title\n   *\n   * @param options.accessToken - User access token\n   * @param options.issueId - The id of issue\n   * @param options.query - The query parameters\n   *\n   * @return The comments\n   */\n  async getComments ({\n    accessToken,\n    issueId,\n    query: {\n      page = 1,\n      perPage = 10,\n      sort = 'desc',\n    } = {},\n  }): Promise<VssueAPI.Comments> {\n    const options: AxiosRequestConfig = {\n      params: {\n        // pagination\n        'page': page,\n        'per_page': perPage,\n        'order_by': 'created_at',\n        'sort': sort,\n      },\n    }\n    if (accessToken) {\n      options.headers = {\n        'Authorization': `Bearer ${accessToken}`,\n      }\n    }\n    const response = await this.$http.get(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/notes`, options)\n    const commentsRaw = response.data\n\n    // gitlab api v4 should get parsed markdown content and reactions by other api\n    // this is potentially to cause 429 Too Many Requests\n    const getCommentsMeta: Array<Promise<void>> = []\n\n    for (const comment of commentsRaw) {\n      getCommentsMeta.push((async () => {\n        comment.body_html = await this.getMarkdownContent({\n          accessToken: accessToken,\n          contentRaw: comment.body,\n        })\n      })())\n      getCommentsMeta.push((async () => {\n        comment.reactions = await this.getCommentReactions({\n          accessToken: accessToken,\n          issueId: issueId,\n          commentId: comment.id,\n        })\n      })())\n    }\n\n    await Promise.all(getCommentsMeta)\n\n    return {\n      count: Number(response.headers['x-total']),\n      page: Number(response.headers['x-page']),\n      perPage: Number(response.headers['x-per-page']),\n      data: commentsRaw.map(normalizeComment),\n    }\n  }\n\n  /**\n   * Get the parse HTML of markdown content\n   *\n   * @param options.accessToken - User access token\n   * @param options.contentRaw - The id of issue\n   *\n   * @return `true` if succeed, `false` if failed\n   */\n  async getMarkdownContent ({\n    accessToken,\n    contentRaw,\n  }: {\n    accessToken?: string | null,\n    contentRaw: string,\n  }): Promise<string> {\n    const options: AxiosRequestConfig = {}\n    if (accessToken) {\n      options.headers = {\n        'Authorization': `Bearer ${accessToken}`,\n      }\n    }\n    const { data } = await this.$http.post(`api/v4/markdown`, {\n      text: contentRaw,\n      gfm: true,\n    }, options)\n    return data.html\n  }\n\n  /**\n   * Get reactions of a cooment\n   *\n   * @param options.accessToken - User access token\n   * @param options.issueId - The id of issue\n   * @param options.commentId - The id of comment\n   *\n   * @return The comments\n   */\n  async getCommentReactions ({\n    accessToken,\n    issueId,\n    commentId,\n  }): Promise<VssueAPI.Reactions> {\n    const { data } = await this.$http.get(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/notes/${commentId}/award_emoji`, {\n      headers: { 'Authorization': `Bearer ${accessToken}` },\n    })\n    return normalizeReactions(data)\n  }\n\n  /**\n   * Create a new issue\n   *\n   * @param options.accessToken - User access token\n   * @param options.title - The title of issue\n   * @param options.content - The content of issue\n   *\n   * @return The created issue\n   */\n  async createIssue ({\n    accessToken,\n    title,\n    content,\n  }): Promise<VssueAPI.Issue> {\n    const { data } = await this.$http.post(`api/v4/projects/${this._encodedRepo}/issues`, {\n      title,\n      description: content,\n      labels: this.labels,\n    }, {\n      headers: { 'Authorization': `Bearer ${accessToken}` },\n    })\n    return normalizeIssue(data)\n  }\n\n  /**\n   * Create a new comment\n   *\n   * @param options.accessToken - User access token\n   * @param options.issueId - The id of issue\n   * @param options.content - The content of comment\n   *\n   * @return The created comment\n   */\n  async createComment ({\n    accessToken,\n    issueId,\n    content,\n  }): Promise<VssueAPI.Comment> {\n    const { data } = await this.$http.post(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/notes`, {\n      body: content,\n    }, {\n      headers: { 'Authorization': `Bearer ${accessToken}` },\n    })\n    return normalizeComment(data)\n  }\n\n  /**\n   * Create a new reaction of issue\n   *\n   * @param options.accessToken - User access token\n   * @param options.issueId - The id of issue\n   * @param options.reaction - The reaction\n   *\n   * @return `true` if succeed, `false` if already token\n   */\n  async createIssueReaction ({\n    accessToken,\n    issueId,\n    reaction,\n  }): Promise<boolean> {\n    try {\n      const response = await this.$http.post(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/award_emoji`, {\n        name: mapReactionName(reaction),\n      }, {\n        headers: { 'Authorization': `Bearer ${accessToken}` },\n      })\n      return response.status === 201\n    } catch (e) {\n      if (e.response && e.response.status === 404) {\n        return false\n      } else {\n        throw e\n      }\n    }\n  }\n\n  /**\n   * Create a new reaction of comment\n   *\n   * @param options.accessToken - User access token\n   * @param options.issueId - The id of issue\n   * @param options.commentId - The id of comment\n   * @param options.reaction - The reaction\n   *\n   * @return `true` if succeed, `false` if already token\n   */\n  async createCommentReaction ({\n    issueId,\n    commentId,\n    reaction,\n    accessToken,\n  }): Promise<boolean> {\n    try {\n      const response = await this.$http.post(`api/v4/projects/${this._encodedRepo}/issues/${issueId}/notes/${commentId}/award_emoji`, {\n        name: mapReactionName(reaction),\n      }, {\n        headers: {\n          'Authorization': `Bearer ${accessToken}`,\n        },\n      })\n      return response.status === 201\n    } catch (e) {\n      // it could be a bug of gitlab\n      // if a reaction (award emoji) has already existed, it returns a 404 response with a buggy message\n      // have submitted a issue: https://gitlab.com/gitlab-org/gitlab-ce/issues/56147\n      if (e.response && e.response.status === 404) {\n        return false\n      } else {\n        throw e\n      }\n    }\n  }\n}\n"]} |
@@ -13,2 +13,3 @@ export function normalizeUser(user) { | ||
content: issue.description, | ||
link: issue.web_url, | ||
}; | ||
@@ -48,2 +49,2 @@ } | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsTUFBTSxVQUFVLGFBQWEsQ0FBRSxJQUFTO0lBQ3RDLE9BQU87UUFDTCxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7UUFDdkIsTUFBTSxFQUFFLElBQUksQ0FBQyxVQUFVO1FBQ3ZCLFFBQVEsRUFBRSxJQUFJLENBQUMsT0FBTztLQUN2QixDQUFBO0FBQ0gsQ0FBQztBQUVELE1BQU0sVUFBVSxjQUFjLENBQUUsS0FBVTtJQUN4QyxPQUFPO1FBQ0wsRUFBRSxFQUFFLEtBQUssQ0FBQyxHQUFHO1FBQ2IsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLO1FBQ2xCLE9BQU8sRUFBRSxLQUFLLENBQUMsV0FBVztLQUMzQixDQUFBO0FBQ0gsQ0FBQztBQUVELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBRSxPQUFZO0lBQzVDLE9BQU87UUFDTCxFQUFFLEVBQUUsT0FBTyxDQUFDLEVBQUU7UUFDZCxPQUFPLEVBQUUsT0FBTyxDQUFDLFNBQVM7UUFDMUIsVUFBVSxFQUFFLE9BQU8sQ0FBQyxJQUFJO1FBQ3hCLE1BQU0sRUFBRSxhQUFhLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztRQUNyQyxTQUFTLEVBQUUsT0FBTyxDQUFDLFVBQVU7UUFDN0IsU0FBUyxFQUFFLE9BQU8sQ0FBQyxVQUFVO1FBQzdCLFNBQVMsRUFBRSxPQUFPLENBQUMsU0FBUztLQUM3QixDQUFBO0FBQ0gsQ0FBQztBQUVELE1BQU0sVUFBVSxrQkFBa0IsQ0FBRSxTQUFjO0lBQ2hELE9BQU87UUFDTCxJQUFJLEVBQUUsU0FBUyxDQUFDLE1BQU0sQ0FBQyxVQUFBLElBQUksSUFBSSxPQUFBLElBQUksQ0FBQyxJQUFJLEtBQUssVUFBVSxFQUF4QixDQUF3QixDQUFDLENBQUMsTUFBTTtRQUMvRCxNQUFNLEVBQUUsU0FBUyxDQUFDLE1BQU0sQ0FBQyxVQUFBLElBQUksSUFBSSxPQUFBLElBQUksQ0FBQyxJQUFJLEtBQUssWUFBWSxFQUExQixDQUEwQixDQUFDLENBQUMsTUFBTTtRQUNuRSxLQUFLLEVBQUUsU0FBUyxDQUFDLE1BQU0sQ0FBQyxVQUFBLElBQUksSUFBSSxPQUFBLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTyxFQUFyQixDQUFxQixDQUFDLENBQUMsTUFBTTtLQUM5RCxDQUFBO0FBQ0gsQ0FBQztBQUVELE1BQU0sVUFBVSxlQUFlLENBQUUsUUFBYTtJQUM1QyxJQUFJLFFBQVEsS0FBSyxNQUFNO1FBQUUsT0FBTyxVQUFVLENBQUE7SUFDMUMsSUFBSSxRQUFRLEtBQUssUUFBUTtRQUFFLE9BQU8sWUFBWSxDQUFBO0lBQzlDLE9BQU8sUUFBUSxDQUFBO0FBQ2pCLENBQUM7QUFFRCxlQUFlO0lBQ2IsYUFBYSxlQUFBO0lBQ2IsY0FBYyxnQkFBQTtJQUNkLGdCQUFnQixrQkFBQTtJQUNoQixrQkFBa0Isb0JBQUE7SUFDbEIsZUFBZSxpQkFBQTtDQUNoQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgVXNlcixcbiAgSXNzdWUsXG4gIENvbW1lbnQsXG4gIFJlYWN0aW9ucyxcbn0gZnJvbSAndnNzdWUnXG5cbmV4cG9ydCBmdW5jdGlvbiBub3JtYWxpemVVc2VyICh1c2VyOiBhbnkpOiBVc2VyIHtcbiAgcmV0dXJuIHtcbiAgICB1c2VybmFtZTogdXNlci51c2VybmFtZSxcbiAgICBhdmF0YXI6IHVzZXIuYXZhdGFyX3VybCxcbiAgICBob21lcGFnZTogdXNlci53ZWJfdXJsLFxuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBub3JtYWxpemVJc3N1ZSAoaXNzdWU6IGFueSk6IElzc3VlIHtcbiAgcmV0dXJuIHtcbiAgICBpZDogaXNzdWUuaWlkLFxuICAgIHRpdGxlOiBpc3N1ZS50aXRsZSxcbiAgICBjb250ZW50OiBpc3N1ZS5kZXNjcmlwdGlvbixcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gbm9ybWFsaXplQ29tbWVudCAoY29tbWVudDogYW55KTogQ29tbWVudCB7XG4gIHJldHVybiB7XG4gICAgaWQ6IGNvbW1lbnQuaWQsXG4gICAgY29udGVudDogY29tbWVudC5ib2R5X2h0bWwsXG4gICAgY29udGVudFJhdzogY29tbWVudC5ib2R5LFxuICAgIGF1dGhvcjogbm9ybWFsaXplVXNlcihjb21tZW50LmF1dGhvciksXG4gICAgY3JlYXRlZEF0OiBjb21tZW50LmNyZWF0ZWRfYXQsXG4gICAgdXBkYXRlZEF0OiBjb21tZW50LnVwZGF0ZWRfYXQsXG4gICAgcmVhY3Rpb25zOiBjb21tZW50LnJlYWN0aW9ucyxcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gbm9ybWFsaXplUmVhY3Rpb25zIChyZWFjdGlvbnM6IGFueSk6IFJlYWN0aW9ucyB7XG4gIHJldHVybiB7XG4gICAgbGlrZTogcmVhY3Rpb25zLmZpbHRlcihpdGVtID0+IGl0ZW0ubmFtZSA9PT0gJ3RodW1ic3VwJykubGVuZ3RoLFxuICAgIHVubGlrZTogcmVhY3Rpb25zLmZpbHRlcihpdGVtID0+IGl0ZW0ubmFtZSA9PT0gJ3RodW1ic2Rvd24nKS5sZW5ndGgsXG4gICAgaGVhcnQ6IHJlYWN0aW9ucy5maWx0ZXIoaXRlbSA9PiBpdGVtLm5hbWUgPT09ICdoZWFydCcpLmxlbmd0aCxcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwUmVhY3Rpb25OYW1lIChyZWFjdGlvbjogYW55KSB7XG4gIGlmIChyZWFjdGlvbiA9PT0gJ2xpa2UnKSByZXR1cm4gJ3RodW1ic3VwJ1xuICBpZiAocmVhY3Rpb24gPT09ICd1bmxpa2UnKSByZXR1cm4gJ3RodW1ic2Rvd24nXG4gIHJldHVybiByZWFjdGlvblxufVxuXG5leHBvcnQgZGVmYXVsdCB7XG4gIG5vcm1hbGl6ZVVzZXIsXG4gIG5vcm1hbGl6ZUlzc3VlLFxuICBub3JtYWxpemVDb21tZW50LFxuICBub3JtYWxpemVSZWFjdGlvbnMsXG4gIG1hcFJlYWN0aW9uTmFtZSxcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLGFBQWEsQ0FBRSxJQUFTO0lBQ3RDLE9BQU87UUFDTCxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7UUFDdkIsTUFBTSxFQUFFLElBQUksQ0FBQyxVQUFVO1FBQ3ZCLFFBQVEsRUFBRSxJQUFJLENBQUMsT0FBTztLQUN2QixDQUFBO0FBQ0gsQ0FBQztBQUVELE1BQU0sVUFBVSxjQUFjLENBQUUsS0FBVTtJQUN4QyxPQUFPO1FBQ0wsRUFBRSxFQUFFLEtBQUssQ0FBQyxHQUFHO1FBQ2IsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLO1FBQ2xCLE9BQU8sRUFBRSxLQUFLLENBQUMsV0FBVztRQUMxQixJQUFJLEVBQUUsS0FBSyxDQUFDLE9BQU87S0FDcEIsQ0FBQTtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsZ0JBQWdCLENBQUUsT0FBWTtJQUM1QyxPQUFPO1FBQ0wsRUFBRSxFQUFFLE9BQU8sQ0FBQyxFQUFFO1FBQ2QsT0FBTyxFQUFFLE9BQU8sQ0FBQyxTQUFTO1FBQzFCLFVBQVUsRUFBRSxPQUFPLENBQUMsSUFBSTtRQUN4QixNQUFNLEVBQUUsYUFBYSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUM7UUFDckMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxVQUFVO1FBQzdCLFNBQVMsRUFBRSxPQUFPLENBQUMsVUFBVTtRQUM3QixTQUFTLEVBQUUsT0FBTyxDQUFDLFNBQVM7S0FDN0IsQ0FBQTtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsa0JBQWtCLENBQUUsU0FBYztJQUNoRCxPQUFPO1FBQ0wsSUFBSSxFQUFFLFNBQVMsQ0FBQyxNQUFNLENBQUMsVUFBQSxJQUFJLElBQUksT0FBQSxJQUFJLENBQUMsSUFBSSxLQUFLLFVBQVUsRUFBeEIsQ0FBd0IsQ0FBQyxDQUFDLE1BQU07UUFDL0QsTUFBTSxFQUFFLFNBQVMsQ0FBQyxNQUFNLENBQUMsVUFBQSxJQUFJLElBQUksT0FBQSxJQUFJLENBQUMsSUFBSSxLQUFLLFlBQVksRUFBMUIsQ0FBMEIsQ0FBQyxDQUFDLE1BQU07UUFDbkUsS0FBSyxFQUFFLFNBQVMsQ0FBQyxNQUFNLENBQUMsVUFBQSxJQUFJLElBQUksT0FBQSxJQUFJLENBQUMsSUFBSSxLQUFLLE9BQU8sRUFBckIsQ0FBcUIsQ0FBQyxDQUFDLE1BQU07S0FDOUQsQ0FBQTtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsZUFBZSxDQUFFLFFBQWtDO0lBQ2pFLElBQUksUUFBUSxLQUFLLE1BQU07UUFBRSxPQUFPLFVBQVUsQ0FBQTtJQUMxQyxJQUFJLFFBQVEsS0FBSyxRQUFRO1FBQUUsT0FBTyxZQUFZLENBQUE7SUFDOUMsT0FBTyxRQUFRLENBQUE7QUFDakIsQ0FBQztBQUVELGVBQWU7SUFDYixhQUFhLGVBQUE7SUFDYixjQUFjLGdCQUFBO0lBQ2QsZ0JBQWdCLGtCQUFBO0lBQ2hCLGtCQUFrQixvQkFBQTtJQUNsQixlQUFlLGlCQUFBO0NBQ2hCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWc3N1ZUFQSSB9IGZyb20gJ3Zzc3VlJ1xuXG5leHBvcnQgZnVuY3Rpb24gbm9ybWFsaXplVXNlciAodXNlcjogYW55KTogVnNzdWVBUEkuVXNlciB7XG4gIHJldHVybiB7XG4gICAgdXNlcm5hbWU6IHVzZXIudXNlcm5hbWUsXG4gICAgYXZhdGFyOiB1c2VyLmF2YXRhcl91cmwsXG4gICAgaG9tZXBhZ2U6IHVzZXIud2ViX3VybCxcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gbm9ybWFsaXplSXNzdWUgKGlzc3VlOiBhbnkpOiBWc3N1ZUFQSS5Jc3N1ZSB7XG4gIHJldHVybiB7XG4gICAgaWQ6IGlzc3VlLmlpZCxcbiAgICB0aXRsZTogaXNzdWUudGl0bGUsXG4gICAgY29udGVudDogaXNzdWUuZGVzY3JpcHRpb24sXG4gICAgbGluazogaXNzdWUud2ViX3VybCxcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gbm9ybWFsaXplQ29tbWVudCAoY29tbWVudDogYW55KTogVnNzdWVBUEkuQ29tbWVudCB7XG4gIHJldHVybiB7XG4gICAgaWQ6IGNvbW1lbnQuaWQsXG4gICAgY29udGVudDogY29tbWVudC5ib2R5X2h0bWwsXG4gICAgY29udGVudFJhdzogY29tbWVudC5ib2R5LFxuICAgIGF1dGhvcjogbm9ybWFsaXplVXNlcihjb21tZW50LmF1dGhvciksXG4gICAgY3JlYXRlZEF0OiBjb21tZW50LmNyZWF0ZWRfYXQsXG4gICAgdXBkYXRlZEF0OiBjb21tZW50LnVwZGF0ZWRfYXQsXG4gICAgcmVhY3Rpb25zOiBjb21tZW50LnJlYWN0aW9ucyxcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gbm9ybWFsaXplUmVhY3Rpb25zIChyZWFjdGlvbnM6IGFueSk6IFZzc3VlQVBJLlJlYWN0aW9ucyB7XG4gIHJldHVybiB7XG4gICAgbGlrZTogcmVhY3Rpb25zLmZpbHRlcihpdGVtID0+IGl0ZW0ubmFtZSA9PT0gJ3RodW1ic3VwJykubGVuZ3RoLFxuICAgIHVubGlrZTogcmVhY3Rpb25zLmZpbHRlcihpdGVtID0+IGl0ZW0ubmFtZSA9PT0gJ3RodW1ic2Rvd24nKS5sZW5ndGgsXG4gICAgaGVhcnQ6IHJlYWN0aW9ucy5maWx0ZXIoaXRlbSA9PiBpdGVtLm5hbWUgPT09ICdoZWFydCcpLmxlbmd0aCxcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwUmVhY3Rpb25OYW1lIChyZWFjdGlvbjoga2V5b2YgVnNzdWVBUEkuUmVhY3Rpb25zKTogc3RyaW5nIHtcbiAgaWYgKHJlYWN0aW9uID09PSAnbGlrZScpIHJldHVybiAndGh1bWJzdXAnXG4gIGlmIChyZWFjdGlvbiA9PT0gJ3VubGlrZScpIHJldHVybiAndGh1bWJzZG93bidcbiAgcmV0dXJuIHJlYWN0aW9uXG59XG5cbmV4cG9ydCBkZWZhdWx0IHtcbiAgbm9ybWFsaXplVXNlcixcbiAgbm9ybWFsaXplSXNzdWUsXG4gIG5vcm1hbGl6ZUNvbW1lbnQsXG4gIG5vcm1hbGl6ZVJlYWN0aW9ucyxcbiAgbWFwUmVhY3Rpb25OYW1lLFxufVxuIl19 |
{ | ||
"name": "@vssue/api-gitlab-v4", | ||
"version": "0.1.9", | ||
"version": "0.2.0", | ||
"description": "Vssue api for gitlab v4", | ||
@@ -29,3 +29,3 @@ "license": "MIT", | ||
"dependencies": { | ||
"@vssue/utils": "^0.1.2", | ||
"@vssue/utils": "^0.2.0", | ||
"axios": "^0.18.0" | ||
@@ -36,3 +36,3 @@ }, | ||
}, | ||
"gitHead": "58b1042ca58ffec75718d48fb0e4026082e39d11" | ||
"gitHead": "b766459604ded3b56082a642a88e211433c7dbc2" | ||
} |
@@ -8,1 +8,6 @@ # @vssue/api-gitlab-v4 | ||
[__Github Repo__](https://github.com/meteorlxy/vssue) | ||
## Features | ||
- Comments sortable: `true` | ||
- Comments reactions: `true` |
@@ -1,2 +0,2 @@ | ||
import { Reactions, VssueAPI, VssueAPIOptions } from 'vssue'; | ||
import { VssueAPI, VssueAPIOptions } from 'vssue'; | ||
import { AxiosInstance } from 'axios'; | ||
@@ -9,3 +9,3 @@ /** | ||
*/ | ||
export default class GitlabV4 implements VssueAPI { | ||
export default class GitlabV4 implements VssueAPI.Instance { | ||
baseURL: string; | ||
@@ -20,43 +20,150 @@ owner: string; | ||
private _encodedRepo; | ||
readonly platform: { | ||
name: string; | ||
link: string; | ||
version: string; | ||
}; | ||
constructor({ baseURL, owner, repo, labels, clientId, clientSecret, state, }: VssueAPIOptions); | ||
redirectAuthorize(): void; | ||
handleAuthorize(): Promise<any>; | ||
/** | ||
* The platform api info | ||
*/ | ||
readonly platform: VssueAPI.Platform; | ||
/** | ||
* Redirect to the authorization page of platform. | ||
*/ | ||
redirectAuth(): void; | ||
/** | ||
* Handle authorization. | ||
* | ||
* @remarks | ||
* If the `code` and `state` exist in the query, and the `state` matches, remove them from query, and try to get the access token. | ||
* | ||
* @return A string for access token, `null` for no authorization code | ||
*/ | ||
handleAuth(): Promise<string | null>; | ||
/** | ||
* Get user access token via `code` | ||
* | ||
* @param options.code - The code from the query | ||
* | ||
* @return User access token | ||
*/ | ||
getAccessToken({ code }: { | ||
code: any; | ||
}): Promise<any>; | ||
code: string; | ||
}): Promise<string>; | ||
/** | ||
* Get the logined user with access token. | ||
* | ||
* @param options.accessToken - User access token | ||
* | ||
* @return The user | ||
*/ | ||
getUser({ accessToken }: { | ||
accessToken: any; | ||
}): Promise<import("vssue").User>; | ||
getIssues({ accessToken }: { | ||
}): Promise<VssueAPI.User>; | ||
/** | ||
* Get issue of this page according to the issue id or the issue title | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.issueTitle - The title of issue | ||
* | ||
* @return The raw response of issue | ||
*/ | ||
getIssue({ accessToken, issueId, issueTitle, }: { | ||
accessToken: any; | ||
}): Promise<any>; | ||
getComments({ issueId, accessToken, }: { | ||
issueId: any; | ||
issueTitle: any; | ||
}): Promise<VssueAPI.Issue | null>; | ||
/** | ||
* Get comments of this page according to the issue id or the issue title | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.query - The query parameters | ||
* | ||
* @return The comments | ||
*/ | ||
getComments({ accessToken, issueId, query: { page, perPage, sort, }, }: { | ||
accessToken: any; | ||
}): Promise<any>; | ||
getCommentReactions({ issueId, commentId, accessToken, }: { | ||
issueId: any; | ||
query?: { | ||
page?: number | undefined; | ||
perPage?: number | undefined; | ||
sort?: string | undefined; | ||
} | undefined; | ||
}): Promise<VssueAPI.Comments>; | ||
/** | ||
* Get the parse HTML of markdown content | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.contentRaw - The id of issue | ||
* | ||
* @return `true` if succeed, `false` if failed | ||
*/ | ||
getMarkdownContent({ accessToken, contentRaw, }: { | ||
accessToken?: string | null; | ||
contentRaw: string; | ||
}): Promise<string>; | ||
/** | ||
* Get reactions of a cooment | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.commentId - The id of comment | ||
* | ||
* @return The comments | ||
*/ | ||
getCommentReactions({ accessToken, issueId, commentId, }: { | ||
accessToken: any; | ||
issueId: any; | ||
commentId: any; | ||
}): Promise<VssueAPI.Reactions>; | ||
/** | ||
* Create a new issue | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.title - The title of issue | ||
* @param options.content - The content of issue | ||
* | ||
* @return The created issue | ||
*/ | ||
createIssue({ accessToken, title, content, }: { | ||
accessToken: any; | ||
}): Promise<Reactions>; | ||
createIssue({ title, content, accessToken, }: { | ||
title: any; | ||
content: any; | ||
}): Promise<VssueAPI.Issue>; | ||
/** | ||
* Create a new comment | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.content - The content of comment | ||
* | ||
* @return The created comment | ||
*/ | ||
createComment({ accessToken, issueId, content, }: { | ||
accessToken: any; | ||
}): Promise<import("vssue").Issue>; | ||
createIssueComment({ issueId, content, accessToken, }: { | ||
issueId: any; | ||
content: any; | ||
}): Promise<VssueAPI.Comment>; | ||
/** | ||
* Create a new reaction of issue | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.reaction - The reaction | ||
* | ||
* @return `true` if succeed, `false` if already token | ||
*/ | ||
createIssueReaction({ accessToken, issueId, reaction, }: { | ||
accessToken: any; | ||
}): Promise<import("vssue").Comment>; | ||
createIssueReaction({ issueId, reaction, accessToken, }: { | ||
issueId: any; | ||
reaction: any; | ||
accessToken: any; | ||
}): Promise<boolean>; | ||
/** | ||
* Create a new reaction of comment | ||
* | ||
* @param options.accessToken - User access token | ||
* @param options.issueId - The id of issue | ||
* @param options.commentId - The id of comment | ||
* @param options.reaction - The reaction | ||
* | ||
* @return `true` if succeed, `false` if already token | ||
*/ | ||
createCommentReaction({ issueId, commentId, reaction, accessToken, }: { | ||
@@ -68,5 +175,2 @@ issueId: any; | ||
}): Promise<boolean>; | ||
getMarkdownContent({ contentRaw }: { | ||
contentRaw: any; | ||
}): Promise<string>; | ||
} |
@@ -1,7 +0,7 @@ | ||
import { User, Issue, Comment, Reactions } from 'vssue'; | ||
export declare function normalizeUser(user: any): User; | ||
export declare function normalizeIssue(issue: any): Issue; | ||
export declare function normalizeComment(comment: any): Comment; | ||
export declare function normalizeReactions(reactions: any): Reactions; | ||
export declare function mapReactionName(reaction: any): any; | ||
import { VssueAPI } from 'vssue'; | ||
export declare function normalizeUser(user: any): VssueAPI.User; | ||
export declare function normalizeIssue(issue: any): VssueAPI.Issue; | ||
export declare function normalizeComment(comment: any): VssueAPI.Comment; | ||
export declare function normalizeReactions(reactions: any): VssueAPI.Reactions; | ||
export declare function mapReactionName(reaction: keyof VssueAPI.Reactions): string; | ||
declare const _default: { | ||
@@ -8,0 +8,0 @@ normalizeUser: typeof normalizeUser; |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
60788
728
13
1
+ Added@vssue/api-gitlab-v4@0.1.9(transitive)
+ Added@vssue/utils@0.2.0(transitive)
Updated@vssue/utils@^0.2.0