addes storage-list and some supporting logic in storage-read
This commit is contained in:
34
README.md
34
README.md
@ -20,6 +20,8 @@ in any function like this;
|
|||||||
node.send( {payload: {data: d}});
|
node.send( {payload: {data: d}});
|
||||||
})
|
})
|
||||||
|
|
||||||
|
The cloud-storage reference is also made available under the global context variable 'cloud-storage'.
|
||||||
|
|
||||||
# Realtime Database (rtdb) Nodes
|
# Realtime Database (rtdb) Nodes
|
||||||
|
|
||||||
## rtdb-get
|
## rtdb-get
|
||||||
@ -104,7 +106,14 @@ output: An array of the results of the query.
|
|||||||
Read file data from a file at a given path under a given cloud storage bucket. The default bucket to be used can be set in the general firebase SDK settings.
|
Read file data from a file at a given path under a given cloud storage bucket. The default bucket to be used can be set in the general firebase SDK settings.
|
||||||
If the payload defines an optional bucket property, it will override the default bucket settings.
|
If the payload defines an optional bucket property, it will override the default bucket settings.
|
||||||
|
|
||||||
input: {"payload":{"bucket": "xyzzyz123.appspot.com", "path": "myFile.txt"}}
|
input:
|
||||||
|
|
||||||
|
{
|
||||||
|
"payload": {
|
||||||
|
"bucket": "xyzzyz123.appspot.com",
|
||||||
|
"path": "myFile.txt"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
npm publish .output: Buffer object containing the binary file contents. Can easily be converted to a string by calling toString() on the Buffer.
|
npm publish .output: Buffer object containing the binary file contents. Can easily be converted to a string by calling toString() on the Buffer.
|
||||||
|
|
||||||
@ -125,6 +134,29 @@ input:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
## storage-list
|
||||||
|
Lists the contents of files in a bucket
|
||||||
|
|
||||||
|
If "path" is defined in the payload, only files beginning with that path will be returned. I fomitted, the root level of the bucket is listed.
|
||||||
|
A path can also be deep likes this; "foo/bar/baz". "delimiter" is the charatcer used to delimit directory levels, "/" by default.
|
||||||
|
|
||||||
|
input:
|
||||||
|
|
||||||
|
{
|
||||||
|
"payload": {
|
||||||
|
"bucket": "xyzzyz123.appspot.com", // optional
|
||||||
|
"path": "directory1", // optional
|
||||||
|
"delimiter": "/" // optional
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
output: An array of google cloud-storage File objects. If you take this output and send it to a function which outputs a payload like this;
|
||||||
|
|
||||||
|
{"files": array_of_File_obejcts}
|
||||||
|
|
||||||
|
The storage-read module will read all file contents and output an array of Buffer objects instead of the normal one.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Auth nodes
|
# Auth nodes
|
||||||
|
|
||||||
|
|||||||
@ -38,6 +38,8 @@ module.exports = function(RED) {
|
|||||||
credentials: this.credentials
|
credentials: this.credentials
|
||||||
})
|
})
|
||||||
|
|
||||||
|
global.set('cloud-storage', s)
|
||||||
|
|
||||||
//s = new Storage()
|
//s = new Storage()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "node-red-contrib-firebase-admin",
|
"name": "node-red-contrib-firebase-admin",
|
||||||
"version": "1.0.8",
|
"version": "1.0.9",
|
||||||
"description": "A node-red module that wraps the server-side admin SDK of firebase, firestore, et.c.",
|
"description": "A node-red module that wraps the server-side admin SDK of firebase, firestore, et.c.",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
@ -33,7 +33,8 @@
|
|||||||
"flow-to-rtdb": "rtdb/flow-to-rtdb.js",
|
"flow-to-rtdb": "rtdb/flow-to-rtdb.js",
|
||||||
"rtdb-to-flow": "rtdb/rtdb-to-flow.js",
|
"rtdb-to-flow": "rtdb/rtdb-to-flow.js",
|
||||||
"storage-read": "storage/storage-read.js",
|
"storage-read": "storage/storage-read.js",
|
||||||
"storage-write": "storage/storage-write.js"
|
"storage-write": "storage/storage-write.js",
|
||||||
|
"storage-list": "storage/storage-list.js"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
|||||||
49
storage/storage-list.html
Normal file
49
storage/storage-list.html
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
<script type="text/javascript">
|
||||||
|
RED.nodes.registerType('storage-list',{
|
||||||
|
|
||||||
|
category: 'firebase-admin',
|
||||||
|
color: '#a6bbcf',
|
||||||
|
defaults: {
|
||||||
|
name: {value:""},
|
||||||
|
path: {value:""},
|
||||||
|
bucket: {value:""},
|
||||||
|
cred: {value: "", type: 'firebase-config'},
|
||||||
|
delimiter: {value: '/'}
|
||||||
|
},
|
||||||
|
inputs:1,
|
||||||
|
outputs:1,
|
||||||
|
icon: "storage.png",
|
||||||
|
label: function() {
|
||||||
|
return this.name||"storage-list";
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<script type="text/x-red" data-template-name="storage-list">
|
||||||
|
<div class="form-row">
|
||||||
|
<label for="node-input-bucket"><i class="icon-tag"></i> Bucket Name</label>
|
||||||
|
<input type="text" id="node-input-bucket" placeholder="Bucket Name">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-row">
|
||||||
|
<label for="node-input-path"><i class="icon-tag"></i> Path</label>
|
||||||
|
<input type="text" id="node-input-path" placeholder="Path">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-row">
|
||||||
|
<label for="node-input-cred"><i class="icon-tag"></i> Credentials</label>
|
||||||
|
<input type="text" id="node-input-cred" placeholder="Cred">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-row">
|
||||||
|
<label for="node-input-delimiter"><i class="icon-tag"></i> Delimiter</label>
|
||||||
|
<input type="text" id="node-input-delimiter" placeholder="Delimiter">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<script type="text/x-red" data-help-name="storage-list">
|
||||||
|
<p>A node that list files from bucket path in google cloud storage</p>
|
||||||
|
</script>
|
||||||
48
storage/storage-list.js
Normal file
48
storage/storage-list.js
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
|
||||||
|
|
||||||
|
let oldpath
|
||||||
|
|
||||||
|
module.exports = function(RED) {
|
||||||
|
|
||||||
|
function FirebaseAdmin(config) {
|
||||||
|
RED.nodes.createNode(this, config);
|
||||||
|
var node = this;
|
||||||
|
|
||||||
|
|
||||||
|
if(config.cred){
|
||||||
|
let c = RED.nodes.getNode(config.cred)
|
||||||
|
this.admin = c.admin
|
||||||
|
this.storage = c.storage
|
||||||
|
this.bucket = config.bucket || c.bucket
|
||||||
|
this.path = config.path
|
||||||
|
}
|
||||||
|
this.delimiter = config.delimiter
|
||||||
|
|
||||||
|
//console.log('configuring storage-list to listen for messages')
|
||||||
|
node.on('input', function(msg) {
|
||||||
|
if(msg && msg.payload){
|
||||||
|
let path = msg.payload.path || this.path
|
||||||
|
let bucket = msg.payload.bucket || this.bucket
|
||||||
|
console.log('storage-list listing files from bucket "'+bucket+'" path "'+path+'"')
|
||||||
|
const options = {
|
||||||
|
prefix: path
|
||||||
|
};
|
||||||
|
|
||||||
|
if(this.delimiter){
|
||||||
|
options.delimiter = this.delimiter
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lists files in the bucket, filtered by a prefix
|
||||||
|
this.storage.bucket(bucket).getFiles(options).then((files)=>{
|
||||||
|
console.log('got file listing')
|
||||||
|
//console.dir(files[0])
|
||||||
|
let f = files[0].filter((e)=>{ return e.name[e.name.length-1] !== '/' })
|
||||||
|
node.send({payload: {files: f}})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}.bind(this));
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
RED.nodes.registerType("storage-list", FirebaseAdmin);
|
||||||
|
}
|
||||||
@ -22,15 +22,40 @@ module.exports = function(RED) {
|
|||||||
if(msg && msg.payload){
|
if(msg && msg.payload){
|
||||||
let path = msg.payload.path || this.path
|
let path = msg.payload.path || this.path
|
||||||
let bucket = msg.payload.bucket || this.bucket
|
let bucket = msg.payload.bucket || this.bucket
|
||||||
console.log('storage-read reading from bucket "'+bucket+'" path "'+path+'"')
|
console.log('------------------------------ storage-read reading from bucket "'+bucket+'" path "'+path+'"')
|
||||||
this.storage
|
if(msg.payload.files && msg.payload.files.length > 0){
|
||||||
.bucket(bucket)
|
console.log('--reading from files')
|
||||||
.file(path).download().then((file)=>{
|
let count = msg.payload.files.length
|
||||||
console.log('storage-read got file')
|
let rv = {}
|
||||||
//console.dir(file)
|
msg.payload.files.forEach((_file)=>{
|
||||||
node.send({payload:file})
|
((file)=>{
|
||||||
|
console.log('reading file '+file.name)
|
||||||
|
this.storage
|
||||||
|
.bucket(bucket)
|
||||||
|
.file(file.name).download().then((content)=>{
|
||||||
|
console.log('storage-read got file '+file.name)
|
||||||
|
rv[file.name] = content
|
||||||
|
if(--count === 0){
|
||||||
|
console.log('all files done, sending..')
|
||||||
|
for(let x in rv){
|
||||||
|
console.log(x)
|
||||||
|
}
|
||||||
|
node.send({payload:rv})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})(_file)
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
console.log('reading single file from path '+path)
|
||||||
|
this.storage
|
||||||
|
.bucket(bucket)
|
||||||
|
.file(path).download().then((file)=>{
|
||||||
|
console.log('storage-read got file')
|
||||||
|
//console.dir(file)
|
||||||
|
node.send({payload:file})
|
||||||
|
|
||||||
})
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}.bind(this));
|
}.bind(this));
|
||||||
|
|
||||||
|
|||||||
@ -26,8 +26,8 @@ module.exports = function(RED) {
|
|||||||
private: msg.payload.private || true,
|
private: msg.payload.private || true,
|
||||||
public: msg.payload.public || true,
|
public: msg.payload.public || true,
|
||||||
}
|
}
|
||||||
console.log('storage-write writing file to bucket "'+bucket+'" path "'+path+'"')
|
console.log('storage-write writing file to bucket "'+bucket+'" path "'+path+'" contents is of type '+(typeof contents))
|
||||||
console.dir(msg.payload)
|
console.dir(contents)
|
||||||
const myBucket = this.storage.bucket(bucket);
|
const myBucket = this.storage.bucket(bucket);
|
||||||
const file = myBucket.file(path);
|
const file = myBucket.file(path);
|
||||||
file.save(contents, options, function(err) {
|
file.save(contents, options, function(err) {
|
||||||
|
|||||||
Reference in New Issue
Block a user