There's not much on the firebase documentation explaining how to upload files with a path when using the firebase admin sdk for google cloud storage.
I've looked at firebase's documentation and it specifies that I can create a bucket and that I should refer to google clouds documentation for further help.
Then they also show how to create another storage bucket plus links leading to API Reference Documentation, which again shows you how to create another storage bucket, but at least this time there is a table of code examples to refer from. The files link at the table shows a repo example that has
// Uploads a local file to the bucket
  storage
    .bucket(bucketName)
    .upload(filename)
    .then(() => {
      console.log(`${filename} uploaded to ${bucketName}.`);
    })
    .catch(err => {
      console.error('ERROR:', err);
    });
which was helpful as I was able to upload a file with admin using it.
var admin = require("firebase-admin");
var serviceAccount = require("path/to/serviceAccountKey.json");
admin.initializeApp({
    credential: admin.credential.cert(serviceAccount),
    storageBucket: "<BUCKET_NAME>.appspot.com"
});
const bucket = admin.storage().bucket();
bucket.upload('local/file/path').then(data => {
    console.log('upload success');
}).catch(err => {
    console.log('error uploading to storage', err);
});
Although I'm still at a loss with how to specify a path as this just puts it at the top level of my firebase storage bucket. Anyone know how I can specify a path to nest my files deeper with the api?
The Admin SDK is a set of server libraries that lets you interact with Firebase from privileged environments to perform actions like: Read and write Realtime Database data with full admin privileges.
To upload a file to Cloud Storage, you first create a reference to the full path of the file, including the file name. Once you've created an appropriate reference, you then call the putBytes() , putFile() , or putStream() method to upload the file to Cloud Storage.
In the Firebase console, open Settings > Service Accounts. Click Generate New Private Key, then confirm by clicking Generate Key. Securely store the JSON file containing the key.
Please refer to the API documentation for the upload() method.  You can see that upload takes a second parameter called "options" to describe the upload.  The options object may have a property called destination to describe where the file should be uploaded.
(string or File)
The place to save your file. If given a string, the file will be uploaded to the bucket using the string as a filename. When given a File object, your local file will be uploaded to the File object's bucket and under the File object's name. Lastly, when this argument is omitted, the file is uploaded to your bucket using the name of the local file or the path of the url relative to it's domain.
So, you can use it like this:
bucket.upload('local/file/path', { destination: 'location/in/bucket' })
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With