From e37b89df4ff6c6a3e7a3b57861ac0fb4851d01c0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Iv=C3=A1n=20Ovejero?= Date: Sat, 20 Mar 2021 21:18:47 +0100 Subject: [PATCH] :zap: Fix pagination for retrieving user repos in GitHub node (#1554) * :zap: Fix pagination on user:getRepositories * :zap: Fix pagination on repository:getIssues * :pencil2: Fix typos and periods in descriptions * :zap: Minor improvement Co-authored-by: Jan Oberhauser --- .../nodes-base/nodes/Github/Github.node.ts | 175 ++++++++++++++---- 1 file changed, 136 insertions(+), 39 deletions(-) diff --git a/packages/nodes-base/nodes/Github/Github.node.ts b/packages/nodes-base/nodes/Github/Github.node.ts index e3f38a40f3..39aae86ee6 100644 --- a/packages/nodes-base/nodes/Github/Github.node.ts +++ b/packages/nodes-base/nodes/Github/Github.node.ts @@ -130,27 +130,27 @@ export class Github implements INodeType { { name: 'Create', value: 'create', - description: 'Create a new issue', + description: 'Create a new issue.', }, { name: 'Create Comment', value: 'createComment', - description: 'Create a new comment on an issue', + description: 'Create a new comment on an issue.', }, { name: 'Edit', value: 'edit', - description: 'Edit an issue', + description: 'Edit an issue.', }, { name: 'Get', value: 'get', - description: 'Get the data of a single issues', + description: 'Get the data of a single issue.', }, { name: 'Lock', value: 'lock', - description: 'Lock an issue', + description: 'Lock an issue.', }, ], default: 'create', @@ -172,22 +172,22 @@ export class Github implements INodeType { { name: 'Create', value: 'create', - description: 'Create a new file in repository', + description: 'Create a new file in repository.', }, { name: 'Delete', value: 'delete', - description: 'Delete a file in repository', + description: 'Delete a file in repository.', }, { name: 'Edit', value: 'edit', - description: 'Edit a file in repository', + description: 'Edit a file in repository.', }, { name: 'Get', value: 'get', - description: 'Get the data of a single issue', + description: 'Get the data of a single issue.', }, ], default: 'create', @@ -209,22 +209,22 @@ export class Github implements INodeType { { name: 'Get', value: 'get', - description: 'Get the data of a single repository', + description: 'Get the data of a single repository.', }, { name: 'Get License', value: 'getLicense', - description: 'Returns the contents of the repository\'s license file, if one is detected', + description: 'Returns the contents of the repository\'s license file, if one is detected.', }, { name: 'Get Issues', value: 'getIssues', - description: 'Returns issues of a repository', + description: 'Returns issues of a repository.', }, { name: 'Get Profile', value: 'getProfile', - description: 'Get the community profile of a repository with metrics, health score, description, license, ...', + description: 'Get the community profile of a repository with metrics, health score, description, license, etc.', }, { name: 'List Popular Paths', @@ -234,7 +234,7 @@ export class Github implements INodeType { { name: 'List Referrers', value: 'listReferrers', - description: 'Get the top 10 referrering domains over the last 14 days', + description: 'Get the top 10 referrering domains over the last 14 days.', }, ], default: 'getIssues', @@ -256,7 +256,7 @@ export class Github implements INodeType { { name: 'Get Repositories', value: 'getRepositories', - description: 'Returns the repositories of a user', + description: 'Returns the repositories of a user.', }, { name: 'Invite', @@ -283,7 +283,7 @@ export class Github implements INodeType { { name: 'Create', value: 'create', - description: 'Creates a new release', + description: 'Creates a new release.', }, ], default: 'create', @@ -305,22 +305,22 @@ export class Github implements INodeType { { name: 'Create', value: 'create', - description: 'Creates a new review', + description: 'Creates a new review.', }, { name: 'Get', value: 'get', - description: 'Get a review for a pull request', + description: 'Get a review for a pull request.', }, { name: 'Get All', value: 'getAll', - description: 'Get all reviews for a pull request', + description: 'Get all reviews for a pull request.', }, { name: 'Update', value: 'update', - description: 'Update a review', + description: 'Update a review.', }, ], default: 'create', @@ -815,12 +815,12 @@ export class Github implements INodeType { { name: 'Closed', value: 'closed', - description: 'Set the state to "closed"', + description: 'Set the state to "closed".', }, { name: 'Open', value: 'open', - description: 'Set the state to "open"', + description: 'Set the state to "open".', }, ], default: 'open', @@ -860,7 +860,7 @@ export class Github implements INodeType { name: 'assignee', type: 'string', default: '', - description: 'User to assign issue too.', + description: 'User to assign issue to.', }, ], }, @@ -1046,6 +1046,47 @@ export class Github implements INodeType { // ---------------------------------- // repository:getIssues // ---------------------------------- + { + displayName: 'Return All', + name: 'returnAll', + type: 'boolean', + displayOptions: { + show: { + resource: [ + 'repository', + ], + operation: [ + 'getIssues', + ], + }, + }, + default: false, + description: 'If all results should be returned or only up to a given limit.', + }, + { + displayName: 'Limit', + name: 'limit', + type: 'number', + displayOptions: { + show: { + resource: [ + 'repository', + ], + operation: [ + 'getIssues', + ], + returnAll: [ + false, + ], + }, + }, + typeOptions: { + minValue: 1, + maxValue: 100, + }, + default: 50, + description: 'How many results to return.', + }, { displayName: 'Filters', name: 'getRepositoryIssuesFilters', @@ -1108,17 +1149,17 @@ export class Github implements INodeType { { name: 'All', value: 'all', - description: 'Returns issues with any state', + description: 'Returns issues with any state.', }, { name: 'Closed', value: 'closed', - description: 'Return issues with "closed" state', + description: 'Return issues with "closed" state.', }, { name: 'Open', value: 'open', - description: 'Return issues with "open" state', + description: 'Return issues with "open" state.', }, ], default: 'open', @@ -1132,17 +1173,17 @@ export class Github implements INodeType { { name: 'Created', value: 'created', - description: 'Sort by created date', + description: 'Sort by created date.', }, { name: 'Updated', value: 'updated', - description: 'Sort by updated date', + description: 'Sort by updated date.', }, { name: 'Comments', value: 'comments', - description: 'Sort by comments', + description: 'Sort by comments.', }, ], default: 'created', @@ -1156,12 +1197,12 @@ export class Github implements INodeType { { name: 'Ascending', value: 'asc', - description: 'Sort in ascending order', + description: 'Sort in ascending order.', }, { name: 'Descending', value: 'desc', - description: 'Sort in descending order', + description: 'Sort in descending order.', }, ], default: 'desc', @@ -1214,7 +1255,7 @@ export class Github implements INodeType { ], }, }, - description: 'ID of the review', + description: 'ID of the review.', }, // ---------------------------------- @@ -1318,17 +1359,17 @@ export class Github implements INodeType { { name: 'Approve', value: 'approve', - description: 'Approve the pull request', + description: 'Approve the pull request.', }, { name: 'Request Change', value: 'requestChanges', - description: 'Request code changes', + description: 'Request code changes.', }, { name: 'Comment', value: 'comment', - description: 'Add a comment without approval or change requests', + description: 'Add a comment without approval or change requests.', }, { name: 'Pending', @@ -1386,7 +1427,7 @@ export class Github implements INodeType { name: 'commitId', type: 'string', default: '', - description: 'The SHA of the commit that needs a review, if different from the latest', + description: 'The SHA of the commit that needs a review, if different from the latest.', }, ], }, @@ -1414,6 +1455,50 @@ export class Github implements INodeType { description: 'The body of the review', }, // ---------------------------------- + // user:getRepositories + // ---------------------------------- + { + displayName: 'Return All', + name: 'returnAll', + type: 'boolean', + displayOptions: { + show: { + resource: [ + 'user', + ], + operation: [ + 'getRepositories', + ], + }, + }, + default: false, + description: 'If all results should be returned or only up to a given limit.', + }, + { + displayName: 'Limit', + name: 'limit', + type: 'number', + displayOptions: { + show: { + resource: [ + 'user', + ], + operation: [ + 'getRepositories', + ], + returnAll: [ + false, + ], + }, + }, + typeOptions: { + minValue: 1, + maxValue: 100, + }, + default: 50, + description: 'How many results to return.', + }, + // ---------------------------------- // user:invite // ---------------------------------- { @@ -1736,6 +1821,12 @@ export class Github implements INodeType { qs = this.getNodeParameter('getRepositoryIssuesFilters', i) as IDataObject; endpoint = `/repos/${owner}/${repository}/issues`; + + returnAll = this.getNodeParameter('returnAll', 0) as boolean; + + if (returnAll === false) { + qs.per_page = this.getNodeParameter('limit', 0) as number; + } } } else if (resource === 'review') { if (operation === 'get') { @@ -1791,7 +1882,7 @@ export class Github implements INodeType { const reviewId = this.getNodeParameter('reviewId', i) as string; body.body = this.getNodeParameter('body', i) as string; - + endpoint = `/repos/${owner}/${repository}/pulls/${pullRequestNumber}/reviews/${reviewId}`; } } else if (resource === 'user') { @@ -1804,13 +1895,19 @@ export class Github implements INodeType { endpoint = `/users/${owner}/repos`; - } else if (operation === 'invite') { + returnAll = this.getNodeParameter('returnAll', 0) as boolean; + + if (returnAll === false) { + qs.per_page = this.getNodeParameter('limit', 0) as number; + } + + } else if (operation === 'invite') { // ---------------------------------- // invite // ---------------------------------- requestMethod = 'POST'; - const org = this.getNodeParameter('organization', i) as string; + const org = this.getNodeParameter('organization', i) as string; endpoint = `/orgs/${org}/invitations`; body.email = this.getNodeParameter('email', i) as string;