问题描述
|
我有一个设计问题,在此我希望得到深思熟虑的答复。
假设您有一个具有用户,公司和主题模型的简单应用程序(例如)。公司“ 0”主题和“ 1”用户。
管理员(用户)可以完全管理公司,用户和主题-整个REST堆栈,此外还可以执行其他一些操作。管理员应该对所有这三种资源执行其他用户角色无法做的事情。
我们也有公司角色。该角色可以编辑自己的公司,也可以从管理员用户添加的主题中选择一个很好的默认主题,或者他们也可以制作自己的主题。
公司还可以添加/删除/删除用户,但仅限于其公司。这些页面将具有不同的视图,并且与管理员将具有不同的行为-某些重叠,但是某些内容将受到限制,而其他内容将被添加。
现在,这里有一些非平凡的设计选择,我想知道最佳实践是什么。
第1部分
在Rails中,对于管理员来说,有
resources :users,:companies,:themes
,对于公司用户来说可能有resource :company,:theme,:users
。
但是,当然,我们在这里遇到了一些命名冲突(单数和复数),因此我们可能想尝试像“ 4”之类的东西来分隔它们?还是有更好的解决方案?
此外,主题只是公司的组成部分,所以也许我们想嵌套它们?
:resource :my_company do
:resource :theme
:resources :users
end
这样做可以,但是关于我们指的是哪个UsersController,可能会造成混淆。这真的很棘手,我很想知道如何处理。您有1个控制器,还是2个?你叫他们什么名字?
因此,这将是一个示例:
http://myapp.com/my_company/theme/edit
http://myapp.com/my_company/users/1/delete
公司用户还可能希望通过ajax来获取主题列表,因此对他们进行调用是否正确:
http://myapp.com/themes.json
?
这是如何处理这种情况,还是有更好的方法?
第2部分
另外,您的目录结构应该是什么样?是否应该按用户角色分隔控制器?
/app/controllers/admin/companies_controller.rb
/app/controllers/admin/themes_controller.rb
/app/controllers/admin/users_controller.rb
/app/controllers/company/my_company_controller.rb
/app/controllers/company/theme_controller.rb
/app/controllers/company/users_controller.rb
还是有更好的方法来解决这个问题?
奇怪的是,users_controller被复制了2倍,并且Theme和Themes之间的差别很小。
对此,我将深表体会。谢谢!
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)