我需要一些建议,以便在我的meteor-app中构建正确的角色架构和管理.

结构体

>我使用alanning:roles@1.2.13为应用程序添加角色管理功能.
>有四种不同的用户类型:管理员,编辑者,专家和用户.
>此外,有几个模块具有不同的内容,即汽车,数学和图像.每个模块都是用自己的流星包组织的.
>在每个模块中都有几个类别,可以由编辑者动态添加.

模块中的类别

模块的结构如下:

elementSchema = new SimpleSchema({ 
    element:    {type: String,optional: true}
});

Cars.attachSchema(new SimpleSchema({
    title:      { type: String },content:    { type: String },category:   { type: [elementSchema],optional: true },});

如您所见,所有可用类别都在模块的Collection中.

>管理员:完整权利
>编辑:可以编辑所选模块中的元素(即editor_1可以编辑汽车和图像中的元素,但不能编辑数学中的元素)
>专家:可以获得完整模块的权限,也可以只获得模块的某些类别(即)expert_1可以编辑图像,但只能使用汽车中“本田”和“梅赛德斯”类别中的元素;没有编辑数学)
>用户:没有编辑

这就是我在技术上进行身份验证的方式:

router.js

var filters = {
    authenticate: function () {
        var user;
        if (Meteor.loggingIn()) {
            this.layout('login');
            this.render('loading');
        } else {
            user = Meteor.user();
            if (!user) {
                this.layout('login');
                this.render('signin');
                return;
            }
            this.layout('Standard');
            this.next();
        }
    }
}
Router.route('/car/:_id',{
    name: 'car',before: filters.authenticate,data: function () {
        return { 
            cars: Cars.findOne({ _id: this.params._id }) 
        };
    }
});

模板

<template name="car">
    {{#if isInRole 'cars'}}
        Some form for editing
    {{else}}
        <h1>Restricted area</h1>
    {{/if}}
</template>

我把这个router.js放到每个包中.只有更改是使用每个包的集合(汽车,数学,图像)的数据函数.

更新:正如’Eliezer Steinbock’评论说,有必要限制对mongoDB本身的访问.但直到现在我才在路线上做到了.

permissions.js

Cars.allow({
    insert: function(userId) {
        var loggedInUser = Meteor.user()
        if (loggedInUser && Roles.userIsInRole(loggedInUser,['admin','editor'])) return true;
    },update: function(userId) {
        var loggedInUser = Meteor.user()
        if (loggedInUser && Roles.userIsInRole(loggedInUser,'editor'])) return true;
    }
});

我的问题

1)我的第一个问题是如何使用角色和组.使用群组的最佳方式是什么?第二个问题是,模块中没有固定的类别.现在我不知道有用的角色/组架构.

2)如何检查角色?因为有不同的角色可以访问:管理员,编辑和专家.此外,我遇到了这些专家的问题,他们只能访问此模块的已定义类别.

3)使permission.js更通用不是更好.我的意思是,是否可以创建一个动态函数,所以我不必在任何地方放置相同的代码?如何以有用的方式在permission.js中实现角色?

解决方法

如果权限的逻辑是相同的,您可以在permissions.js中定义一次
App = App || {}; // We are using Namespaces,so you don't have to.. but it's good
App.Permissions = {
    insert: function(userId) {
        var loggedInUser = Meteor.user()
        if (loggedInUser && Roles.userIsInRole(loggedInUser,'editor'])) return true;
    }
}

然后你可以将它用于你的收藏:

Cars.allow(App.Permissions); // Or
Cars.allow(App.Permissions.getPermissionsForGroup('cars'))

在某处定义角色..

角色

// Give user the role "editor" in "cars" group
Roles.addUsersToRoles(someUserId,['editor'],'cars');
Roles.addUsersToRoles(someOtherId,['admin'],'cars');

你可以在permissions.js中准备这样的:

权限

App = App || {}; 
App.Permissions = {
 insert: function(userId) {...},update: function(userId) {...},getPermissionsForGroup: function(group) {
    return {
       insert: function(userId,doc) {
          // Only admin can insert
          return Roles.userIsInRole(userId,"admin",group);
       },update: function(userId,doc,fields,modifier) {
          // Editor & Admin can edit
          return Roles.userIsInRole(userId,["editor","admin"],remove: function(userId,doc) {
          // Only admin can remove
          return Roles.userIsInRole(userId,group);
       }
    }    
}

在此示例中,管理员可以插入和更新..并且编辑者只能更新,但插入.

关于alanning的文档:您定义的角色和使用这样的角色:

// Super Admin deFinition..
Roles.addUsersToRoles(superAdminId,Roles.GLOBAL_GROUP);

Roles.addUsersToRoles(joesUserId,['manage-team','schedule-game'],'manchester-united.com')
Roles.addUsersToRoles(joesUserId,['player','goalie'],'real-madrid.com')

Roles.userIsInRole(joesUserId,'manage-team','manchester-united.com')  // => true
Roles.userIsInRole(joesUserId,'real-madrid.com')  // => false

是的,请确保在收集定义之前包含权限逻辑..显然:)

javascript – 带有alanning:meteorning app的meteor-app中的结构角色管理的更多相关文章

  1. 详解如何通过H5(浏览器/WebView/其他)唤起本地app

    这篇文章主要介绍了详解如何通过H5(浏览器/WebView/其他)唤起本地app的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. H5混合开发app如何升级的方法

    本篇文章主要介绍了H5混合开发app如何升级的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  3. HTML5仿微信聊天界面、微信朋友圈实例代码

    小编最近开发一个基于html5开发的一个微信聊天前端界面,功能很全面,下面小编给大家分享实例代码,需要的朋友参考下

  4. html5唤起app的方法

    这篇文章主要介绍了html5唤起app的方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  5. xcode – 上传到App Store时进行身份验证

    只需为现有安装/文件夹创建备份,这很重要,因为在(新)安装期间,Transporter将删除以前的安装:现在运行以下命令来更新Transporter:希望这有助于某人.

  6. App store拒绝应用程序在iOs 10上支持IPV6网络

    我收到苹果公司的app拒绝邮件,下面是我们在连接到IPv6网络的Wi-Fi上运行iOS10.0.2的iPad和iPhone上查看了应用中的一个或多个错误.具体来说,应用程序在启动时仍保留在启动屏根据他们的要求,我已经在我的Mac上创建了NAT64网络,并为iPhone5S设备10.0.2os版本共享了互联网,App工作正常,但苹果称其不与IPv6合作任何人都可以确认我需要检查其他什么吗?

  7. ios – 我如何从iPhone中提取IPA以从App Store下载以便我可以在IPA中查看资产?

    我最喜欢的应用程序之一已从应用程序商店中删除,我想因为它没有在太长时间内更新.我有一台旧设备,但没有下载到我的新手机上.如何获得IPA以便我可以查看应用程序包并查看应用程序中的资产?

  8. ios – – [Not A Type _cfTypeID]:发送到解除分配的实例的消息

    我正在使用代码为图像提供不同的效果,如对比度,色调,饱和度等;并使用了appleglImageProcessing代码,我从我的视图跳转到glimgeProcessing,并将结果图像保存到appDelegate文件中的uiimage属性.从Eagle视图返回后,我使用viewDidAppear函数将我的图像视图更改为更新的图像我的代码是我的日志响应是尝试将图像设置为我的imageView时出现问

  9. iOS扩展:是否需要增加其捆绑版本(CFBundleVersion)?

    我是否必须在我的扩展程序的Info.plist中增加CFBundLeversion以确保它覆盖现有的?或者,如果在主应用程序的Info.plist中这样做就足够了?

  10. ios – navigator.app undefined

    谢谢你的帮助.干杯,米格尔解决方法“navigator.app”对象仅适用于Android.幸运的是,在即将发布的PhoneGap2.3.0版本中你可以做到:做你想做的事.

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部