Add File->List to GitHub node (#2752)

* 🐛 Don't extract binary from Github directory

*  Add file list operation
This commit is contained in:
pemontto 2022-02-04 19:18:30 +00:00 committed by GitHub
parent fc550ecbcb
commit c7e73d757a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -193,7 +193,12 @@ export class Github implements INodeType {
{ {
name: 'Get', name: 'Get',
value: 'get', value: 'get',
description: 'Get the data of a single issue.', description: 'Get the data of a single file.',
},
{
name: 'List',
value: 'list',
description: 'List contents of a folder.',
}, },
], ],
default: 'create', default: 'create',
@ -413,11 +418,39 @@ export class Github implements INodeType {
'file', 'file',
], ],
}, },
hide: {
operation: [
'list',
],
},
}, },
placeholder: 'docs/README.md', placeholder: 'docs/README.md',
description: 'The file path of the file. Has to contain the full path.', description: 'The file path of the file. Has to contain the full path.',
}, },
// ----------------------------------
// file:list
// ----------------------------------
{
displayName: 'Path',
name: 'filePath',
type: 'string',
default: '',
required: false,
displayOptions: {
show: {
resource: [
'file',
],
operation: [
'list',
],
},
},
placeholder: 'docs/',
description: 'The path of the folder to list.',
},
// ---------------------------------- // ----------------------------------
// file:create/edit // file:create/edit
// ---------------------------------- // ----------------------------------
@ -1774,6 +1807,7 @@ export class Github implements INodeType {
// Operations which overwrite the returned data and return arrays // Operations which overwrite the returned data and return arrays
// and has so to be merged with the data of other items // and has so to be merged with the data of other items
const overwriteDataOperationsArray = [ const overwriteDataOperationsArray = [
'file:list',
'repository:getIssues', 'repository:getIssues',
'repository:listPopularPaths', 'repository:listPopularPaths',
'repository:listReferrers', 'repository:listReferrers',
@ -1891,7 +1925,7 @@ export class Github implements INodeType {
body.sha = await getFileSha.call(this, owner, repository, filePath, body.branch as string | undefined); body.sha = await getFileSha.call(this, owner, repository, filePath, body.branch as string | undefined);
endpoint = `/repos/${owner}/${repository}/contents/${encodeURI(filePath)}`; endpoint = `/repos/${owner}/${repository}/contents/${encodeURI(filePath)}`;
} else if (operation === 'get') { } else if (operation === 'get' || operation === 'list') {
requestMethod = 'GET'; requestMethod = 'GET';
const filePath = this.getNodeParameter('filePath', i) as string; const filePath = this.getNodeParameter('filePath', i) as string;
@ -2182,6 +2216,9 @@ export class Github implements INodeType {
const asBinaryProperty = this.getNodeParameter('asBinaryProperty', i); const asBinaryProperty = this.getNodeParameter('asBinaryProperty', i);
if (asBinaryProperty === true) { if (asBinaryProperty === true) {
if (Array.isArray(responseData)) {
throw new NodeOperationError(this.getNode(), 'File Path is a folder, not a file.');
}
// Add the returned data to the item as binary property // Add the returned data to the item as binary property
const binaryPropertyName = this.getNodeParameter('binaryPropertyName', i) as string; const binaryPropertyName = this.getNodeParameter('binaryPropertyName', i) as string;