Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@vssue/api-gitlab-v4

Package Overview
Dependencies
Maintainers
1
Versions
36
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@vssue/api-gitlab-v4 - npm Package Compare versions

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;

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc