簡體   English   中英

MeteorJS useraccounts:核心和流星角色

[英]MeteorJS useraccounts:core and meteor-roles

我正在使用MeteorJS開發簡單的Web應用程序。 我是MeteorJs的新人。 我使用useraccounts:核心包和alanning的meteor-roles。 在注冊新用戶時為用戶分配角色是否可行?

編輯1

我嘗試過使用onCreateUser鈎子,但是有些東西不起作用。

Accounts.onCreateUser(function(options, user){
  var role = ['unselected'];
  Roles.addUsersToRoles(user, role);
  return user;
});

以下方法只能在服務器端運行。 線索是,您需要首先創建用戶,從創建中獲取ID,然后將角色附加到其中。

Meteor.methods({
rolesCreateUser: function (user) {

    if (_.isObject(user)) {

        if (user.username) {
            var id = Accounts.createUser({
                username: user.username,
                email: user.email,
                password: user.password
            });
            //We add roles to the user
            if (user.roles.length > 0) {                   
                Roles.addUsersToRoles(id, user.roles);
            }
            _.extend(user, {id: id});

            return user;
        }
    }
}   
});

然后在客戶端使用用戶的數據調用該方法:

    Meteor.call('rolesCreateUser', newUserData, function (error, newCreatedUser) {

        if (error) {
            //The error code
        } else {
           //Do something with newCreatedUser
       }

    });

我有這種方式來創建用戶(如果我低調你的例子你alredy有一些用戶,只需要一些角色,所以當前用戶只是創建這個),也使用一些定制的登錄按鈕或類似的東西

Server.js

Meteor.methods({
     createUsers: function(email,password,roles,name){
       var users = [{name:name,email:email,roles:[roles]},
                   ];
.each(users, function (user) {
   var id;
id = Accounts.createUser({
     email: user.email,
     password: password,
     profile: { name: user.name }
     });
 if (user.roles.length > 0) {
          Roles.addUsersToRoles(id, user.roles);
         }
        });
},
       deleteUser : function(id){       ///Some Delete Method (ignore if dont needed)
      return Meteor.users.remove(id);
      },
    });

發布方法

//publish roles
      Meteor.publish(null, function (){ 
       return Meteor.roles.find({})
       })
Meteor.publish("Super-Admin", function () {
        var user = Meteor.users.findOne({_id:this.userId});

         if (Roles.userIsInRole(user, ["Super-Admin"])) {
        return Meteor.users.find({}, {fields: {emails: 1, profile: 1, roles: 1}});
         } 
   this.stop();
          return;
       });

          Meteor.publish("Admin", function () {
       var user = Meteor.users.findOne({_id:this.userId});

        if (Roles.userIsInRole(user, ["Admin"])) {
        return Meteor.users.find({}, {fields: {emails: 1, profile: 1, roles: 1}});
       } 
this.stop();
     return;
      });
      Meteor.publish(null, function (){ 
     return Meteor.roles.find({})
     })

所以在客戶端client / register.html上

<template name="register">
      <form id="register-form" action="action" >
        <input type="email" id="register-email" placeholder="Nombre Nuevo Usuario">
        <input type="password" id="register-password" placeholder="Password">        
          <select id="register-rol" class="form-control">
             <option value="Admin" selected>Admin</option>
            <option value="Super-Admin" selected>Super Admin</option>
            <option value="Normal" selected>Normal</option>
         </select>
       <input type="submit" value="Register">
      </form>
    </tempalate>

並在register.js上調用服務器方法

 Template.registrar.events({
  'submit #register-form' : function(e, t) {
    e.preventDefault();    
     var email = t.find('#register-email').value,
     password = t.find('#register-password').value,
      roles = $( "#register-rol" ).val();
    Meteor.call("createUsers", email, password,roles);
     return false;
      },
    'click #deleteUser' : function(event,template){
     var idUsuario= this._id;
     Meteor.call('deleteUser',{_id:idUsuario})
     }
    });

刪除部分(html)這是可選的,只是查看帳戶是否正確創建

{{#each users}}
      <li id="user"><h6>{{email}}</h6><h6>{{roles}}</h6></li>
        <button id="deleteUser" class="btn btn-danger btn-xs" > Borrar Usuario        {{email}}       </button>
     {{/each}}

客戶機/ registerList.js

   Template.registrar.helpers({
         users: function () {
         return Meteor.users.find();
       },
        email: function () {
        return this.emails[0].address;
        },
       roles: function () {
       if (!this.roles) return '<none>';
    return this.roles.join(',');
      }
      });

記得訂閱

  Meteor.subscribe('Admin');
  Meteor.subscribe('Super-Admin');

希望這有助於對凌亂的代碼感到遺憾

您可能想要使用OnCreateUser鈎子: http//docs.meteor.com/#/full/accounts_oncreateuser

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM