Firebase根据身份验证数据创建用户对象

时间:2015-08-05 03:12:29

标签: authentication firebase angularfire

所以我在离子应用程序中使用Angularfire并试图弄清楚如何使用Auth $ createUser调用创建与auth数据相关联的用户对象。我的第一次尝试有auth调用,并且用户已经过身份验证,然后创建了一个用户对象并将其推送到$firebaseArray,这可以正常工作,但我不知道如何在登录后抓取当前用户更新,破坏或对该用户数据执行任何操作。我已经使用它循环遍历users数组并匹配用户数组项中的uid和在用户数组对象创建中设置为相同的auth.uid项。如果有一个庞大的用户数组并且需要在多个页面上完成,那么这似乎是无效的。

我目前的尝试是使用不同的方法:

angular.module('haulya.main')
.controller('RegisterController', ['Auth', '$scope', 'User', '$ionicPlatform', '$cordovaCamera','CurrentUserService',
  function(Auth, $scope, User, $ionicPlatform, $cordovaCamera, CurrentUserService) {

  //scope variable for controller
  $scope.user = {};
  console.log(User); 

  $scope.createUser = function(isValid) {

    var userModel;
    $scope.submitted = true;

    //messages for successful or failed user creation
    $scope.user.message = null;
    $scope.user.error = null;

    //if form is filled out valid
    if(isValid) {

      //Create user with email and password firebase Auth method
      Auth.$createUser({
        email: $scope.user.email,
        password: $scope.user.password
      })
      .then(function(userData) {

        userModel = {
          uid: userData.uid,
          photo: $scope.user.photo || null,
          firstName: $scope.user.firstName,
          lastName: $scope.user.lastName,
          email: $scope.user.email,
          cell: $scope.user.cell,
          dob: $scope.user.dob.toString(),
          city: $scope.user.city,
          state: $scope.user.state,
          zip: $scope.user.zip
        }

        // add new user to profiles array
        User.create(userModel).then(function(user) {
          $scope.sharedUser = User.get(user.path.o[1]);
        });


        $scope.user.message = "User created for email: " +  $scope.user.email;
      })
      .catch(function(error) {
        //set error messages contextually
        if(error.code == 'INVALID_EMAIL') {
          $scope.user.error = "Invalid Email";
        }
        else if(error.code == 'EMAIL_TAKEN'){
          $scope.user.error = "Email already in use, if you think this is an error contact an administrator";
        }
        else {
          $scope.user.error = "Fill in all required fields";
        }
      });
    }


  };


  //Get profile pic from camera, or photo library
  $scope.getPhoto = function(type) {
    $ionicPlatform.ready(function() {
      //options for images quality/type/size/dimensions
      var options = {
        quality: 65,
        destinationType: Camera.DestinationType.DATA_URL,
        sourceType: Camera.PictureSourceType[type.toUpperCase()],
        allowEdit: true,
        encodingType: Camera.EncodingType.JPEG,
        targetWidth: 100,
        targetHeight: 100,
        popoverOptions: CameraPopoverOptions,
        saveToPhotoAlbum: false
      };

      //get image function using cordova-plugin-camera 
      $cordovaCamera.getPicture(options)
      .then(function(photo) {
        $scope.user.photo = photo;
      }, function(err) {
        console.log(err);
      });
    });

  };

}]);

这是控制器正在使用的服务:

angular
  .module('haulya.main')
  .factory('User', function($firebaseArray) {
    var ref = new Firebase('https://haulya.firebaseio.com');
    var users = $firebaseArray(ref.child('profiles'));

    var User = {
      all: users,
      create: function(user) {
        return users.$add(user);
      },
      get: function(userId) {
        return $firebaseArray(ref.child('profiles').child(userId));
      },
      delete: function(user) {
        return users.$remove(user);
      } 
    };

    return User;
});

这也有效,但我再次没有对数组中当前登录的用户对象数据的可靠引用。对象id仅存储在控制器范围内。

我查看了其他帖子,但他们都使用旧版本的firebase和弃用方法。

1 个答案:

答案 0 :(得分:1)

如果您要存储具有“自然键”的项目,最好将它们存储在该键下。对于用户,这将是uid

因此,不要将其与$add()一起存储,而应将其存储为child().set()

create: function(user) {
  var userRef = users.$ref().child(user.uid);
  userRef.set(user);
  return $firebaseObject(userRef);
}

您会注意到我使用的是非AngularFire方法child()set()。 AngularFire构建于Firebase的常规JavaScript SDK之上,因此可以很好地互操作。这样做的好处是,您可以使用Firebase JavaScript SDK的所有功能,并且只使用AngularFire来实现最佳功能:将事物绑定到Angular的$scope

Storing user data is explained in Firebase's guide for JavaScript。我们也将它们存储在uid下,而不是使用push(),这是$add()在幕后调用的内容。