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}});
|
||||
})
|
||||
|
||||
The cloud-storage reference is also made available under the global context variable 'cloud-storage'.
|
||||
|
||||
# Realtime Database (rtdb) Nodes
|
||||
|
||||
## 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.
|
||||
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.
|
||||
|
||||
@ -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
|
||||
|
||||
|
||||
@ -38,6 +38,8 @@ module.exports = function(RED) {
|
||||
credentials: this.credentials
|
||||
})
|
||||
|
||||
global.set('cloud-storage', s)
|
||||
|
||||
//s = new Storage()
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
{
|
||||
"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.",
|
||||
"main": "index.js",
|
||||
"scripts": {
|
||||
@ -33,7 +33,8 @@
|
||||
"flow-to-rtdb": "rtdb/flow-to-rtdb.js",
|
||||
"rtdb-to-flow": "rtdb/rtdb-to-flow.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": {
|
||||
|
||||
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){
|
||||
let path = msg.payload.path || this.path
|
||||
let bucket = msg.payload.bucket || this.bucket
|
||||
console.log('storage-read reading from bucket "'+bucket+'" path "'+path+'"')
|
||||
this.storage
|
||||
.bucket(bucket)
|
||||
.file(path).download().then((file)=>{
|
||||
console.log('storage-read got file')
|
||||
//console.dir(file)
|
||||
node.send({payload:file})
|
||||
console.log('------------------------------ storage-read reading from bucket "'+bucket+'" path "'+path+'"')
|
||||
if(msg.payload.files && msg.payload.files.length > 0){
|
||||
console.log('--reading from files')
|
||||
let count = msg.payload.files.length
|
||||
let rv = {}
|
||||
msg.payload.files.forEach((_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));
|
||||
|
||||
|
||||
@ -26,8 +26,8 @@ module.exports = function(RED) {
|
||||
private: msg.payload.private || true,
|
||||
public: msg.payload.public || true,
|
||||
}
|
||||
console.log('storage-write writing file to bucket "'+bucket+'" path "'+path+'"')
|
||||
console.dir(msg.payload)
|
||||
console.log('storage-write writing file to bucket "'+bucket+'" path "'+path+'" contents is of type '+(typeof contents))
|
||||
console.dir(contents)
|
||||
const myBucket = this.storage.bucket(bucket);
|
||||
const file = myBucket.file(path);
|
||||
file.save(contents, options, function(err) {
|
||||
|
||||
Reference in New Issue
Block a user