Skip to content

Latest commit

 

History

History
152 lines (124 loc) · 6.79 KB

uploading-downloading-binary-content.md

File metadata and controls

152 lines (124 loc) · 6.79 KB

Uploading & Downloading Binary Content | AngularFire Guide

Table of Contents

Overview

Firebase provides a hosted binary storage service which enables you to store and retrieve user-generated content like images, audio, and video directly from the Firebase client SDK.

Binary files are stored in a Cloud Storage bucket, not in the Realtime Database. The files in your bucket are stored in a hierarchical structure, just like in the Realtime Database.

To use the Cloud Storage for Firebase binding, first create a Storage reference. Then, using this reference, pass it into the $firebaseStorage service:

// define our app and dependencies (remember to include firebase!)
angular
  .module("sampleApp", [
    "firebase"
  ])
  .controller("SampleCtrl", SampleCtrl);

// inject $firebaseStorage into our controller
function SampleCtrl($firebaseStorage) {
  // create a Storage reference for the $firebaseStorage binding
  var storageRef = firebase.storage().ref("userProfiles/physicsmarie");
  var storage = $firebaseStorage(storageRef);
}
SampleCtrl.$inject = ["$firebaseStorage"];

API Summary

The Cloud Storage for Firebase service is created with several special $ methods, all of which are listed in the following table:

Method Description
$put(file, metadata) Uploads file to configured path with optional metadata. Returns an AngularFire wrapped UploadTask.
$putString(string, format, metadata) Uploads a upload a raw, base64, or base64url encoded string with optional metadata. Returns an AngularFire wrapped UploadTask.
$getDownloadURL() Returns a Promise fulfilled with the download URL for the file stored at the configured path.
$getMetadata() Returns a Promise fulfilled with the metadata of the file stored at the configured path.
$updateMetadata(metadata) Returns a Promise containing the updated metadata.
$delete() Permanently deletes the file stored at the configured path. Returns a Promise that is resolved when the delete completes.
$toString() Returns a string version of the bucket path stored as a gs:// scheme.

Uploading files

To upload files, use either the $put() or $putString() methods. These methods return an [UploadTask(https://firebase.google.com/docs/reference/js/firebase.storage#uploadtask) which is wrapped by AngularFire to handle the $digest loop.

function SampleCtrl($firebaseStorage) {
  // create a Storage reference for the $firebaseStorage binding
  var storageRef = firebase.storage().ref('userProfiles/physicsmarie');
  var storage = $firebaseStorage(storageRef);
  var file = // get a file from the template (see Retrieving files from template section below)
  var uploadTask = storage.$put(file);
  // of upload via a RAW, base64, or base64url string
  var stringUploadTask = storage.$putString('5b6p5Y+344GX44G+44GX44Gf77yB44GK44KB44Gn44Go44GG77yB', 'base64');
}
SampleCtrl.$inject = ["$firebaseStorage"];

Upload Task API Summary

Method Description
$progress(callback) Calls the provided callback function whenever there is an update in the progress of the file uploading.
$error(callback) Calls the provided callback function when there is an error uploading the file.
$complete(callback) Calls the provided callback function when the upload is complete.
$cancel() Cancels the upload.
$pause() Pauses the upload.
$snapshot() Returns the current immutable view of the task at the time the event occurred.
then(callback) An UploadTask implements a Promise like interface. This callback is called when the upload is complete.
catch(callback) An UploadTask implements a Promise like interface. This callback is called when an error occurs.

Displaying Images with the firebase-src Directive

AngularFire provides a directive that displays a file with any src-compatible element. Instead of using the tradional src attribute, use firebase-src:

<img firebase-src="userProfiles/physicsmarie" />
<!-- Works with bindings as well -->
<img firebase-src="{{ userProfileId }}" />

Retrieving Files from the Template

AngularFire does not provide a directive for retrieving an uploaded file. However, the directive below provides a baseline to work off:

angular
  .module("sampleApp", [
    "firebase"
  ])
  .directive("fileUpload", FileUploadDirective);

function FileUploadDirective() {
  return {
    restrict: "E",
    transclude: true,
    scope: {
      onChange: "="
    },
    template: '<input type="file" name="file" /><label><ng-transclude></ng-transclude></label>',
    link: function (scope, element, attrs) {
      element.bind("change", function () {
        scope.onChange(element.children()[0].files);
      });
    }
  }
}

To use this directive, create a controller to bind the onChange() method:

function UploadCtrl($firebaseStorage) {
  var ctrl = this;
  var storageRef = firebase.storage().ref("userProfiles/physicsmarie");
  var storage = $firebaseStorage(storageRef);
  ctrl.fileToUpload = null;
  ctrl.onChange = function onChange(fileList) {
    ctrl.fileToUpload = fileList[0];
  };
}

Then specify your template to use the directive:

<div ng-controller="UploadCtrl as $ctrl">
  <file-upload on-change="$ctrl.onChange">
    Upload
  </file-upload>
</div>

Head on over to the API reference for $firebaseStorage to see more details for each API method provided by the service. Now that we have a grasp of managing binary content with AngularFire, the next section of this guide moves on to a new topic: authentication.