https://www.devexpress.com/Support/Center/Question/Details/S32444/core-provide-an-easy-way-to-store-administrator-and-user-model-differences-in-a-custom      

E968: How to handle distribution of new Model.xafml file?

See the proposed solution.

Proposed Solution:

I desire that we introduce an option in the XafApplication class that would provide at least three predefined methods of storing the model user differences:

1. in the file system for Win and Web applications (this is the Model.User.xafml file in a Windows Forms application, or a folder with the ID of the current user on the server in a Web Forms application)

2. in the database ( How to: Store Model Differences in Database ) for both platforms

3. in a custom store (as in the browser cookies for a Web application)

 
  • In the meantime, I suggest you take less than 1 minute to watch a video about the DatabaseUserSettings module I recently developed.

    The DatabaseUserSettings module provides the capability to store user settings in the database instead of the file system by default. Note that this module is security system type insensitive.
    If security system is on, you also get the capability to manage all users settings via a service Configurator user and a special UI. 
    You can export user settings into a file system, reset them or even import user setting from one user to others. You can also edit required user settings via standard XAF CRUD forms.

    Further details are available in the A reusable XAF module for storing model settings in the database (security system type insensitive!) forum thread.
    Join this discussion and share your feedback and suggestions on this module!

    Thanks,
    Dennis

  • Matteo Lazzari4 years ago
     

    I'm using the DatabaseUserSettings and I've got a question. Before the adoption of this module, the presence of the Model.xafml file was not mandatory. Now I receive this error "Cannot load user settings from the Model.xafml file". Moreover, the application use a custom ModelDifferenceFilePath, but this property is not taken into account and the DatabaseUserSettingsModule looks at the file in the root. Is there a way to avoid this behavior? I see that the exception is raised in the GetConfiguratorUserSettings function. I haven't implemented the configurator account and don't want to deal with it in the next future. Thank you very much.

  • @Matteo: Sure, you are free to modify this example code as your business needs dictate.

  • Matteo Lazzari4 years ago
     

    Which part of the function can I comment out without risk to introduce a misbehavior? Thank you.

  • @Matteo: I am afraid it is not a "comment one line" solution and I do not have ready guidelines specially for your particular scenario. I suggest you research and understand the code of this example if you are going to base your own solution on it. The code that reads settings from the Model.XAFML file is placed in the GetConfiguratorUserSettings method. Drop me a line if you experience any further questions. 
    Probably, it will be easier to implement your task from scratch by handling the CreateCustomUserModelDifferenceStore and CreateDatabaseModelDifferenceStore events of the XafApplication class. If you wish to discuss this further, it is better to create a separate ticket in the Support Center. Thanks.

1 Solution

1

DevExpress Support Team3 years ago
 
 

Implemented:

Additional information:

End-user UI settings (model differences) can now be stored in the application’s database (both WinForms and ASP.NET). This allows you to synch settings for users across multiple devices, share settings modified by administrators and prohibit unauthorized changes. This functionality is implemented in the system module and it is activated automatically when you enable the Security System in the Solution Wizard.

You can allow application administrators to manage user settings across user accounts - create, copy, export and reset model differences. For this purpose, run the Model Editor and create a new Navigation Item for the ModelDifference_ListView List View.

Online documentation: 
eXpressApp Framework > Task-Based Help > How to: Store the Application Model Differences in the Database
How to: Enable the Administrative UI for managing Users' Model Differences
eXpressApp Framework > Concepts > Application Model > Model Difference Storages

Blog: User Settings Stored in the Application Database

Video: Saving UI Settings in a Database

Hide comments
  • Carlitos3 years ago
     

    Nice! What about sharing models via roles?

  • Thanks for your interest, Carlitos. I've just answered the same question to Martin in my blog post.
  • Dennis - on the blog i asked if i can edit those diffs at runtime, and you said:

    @Noxe: Yes, you can do this using the CRUD interface of the XAF app (see the screenshot) - currently, the simplest and the official way to edit these settings;-)

    I meant i can select an model diff - and edit those diffs via the model editor? as far i can see i can only edit the plain XML content. The pro Version of this would be that i select for example the "Shared Model Difference", and then edit this part in the model Editor (as xpand does ;) )

  • Thanks for your clarification, Noxe! This option is not currently implemented and we will take your feedback into account.
  • Carlitos3 years ago
     

    Hopefully we will have Role Diffs one day! :)

  • Mario Blatarić3 years ago
     

    Are there new tickets where we can vote for role diffs and editing models using Model Editor?

  • @Mario: No, for now this feedback is logged via our internal feature cards.
  • Nate Laff3 years ago
     

    Can we get a run through of using the new tools from an end user perspective? It seems like they should NOT modify the "Shared Model Difference" object that gets created, that comes from Model.xafml it seems and if you copy current user's diffs to that it erases any changes in your highest level model. If changes are made to Model.xafml do we need to update that "Shared Model Difference" manually? Delete it and let it get recreated?

    The first thing I did (from the seat of an end user) was copy the Administrator model to the "Shared Model Difference" object. I wanted all users to get the changes made.

    The biggest issue with that is the My Details item, which is generated there. Any attempt to move it to another nav group eventually has that change erased and it ends up back in the default group. I try not to make changes to my Model.xafml but that's the only one that is necessary, and always ends up right back when it started.

    Also, can we (easily) override the behavior of "Create Model Differences" action? I have built-in users (Workflow Service), inactive users, etc.. that I do not want to appear during this process. I would like them to be filtered out.

  • Nate Laff3 years ago
     

    Also, do all users need read/write access to ModelDifference and ModelDifferenceAspect in order to store their user settings? It all seems to be working without it, but wondering how it circumvents security.

  • Konstantin B (DevExpress)3 years ago
     
    > If changes are made to Model.xafml do we need to update that "Shared Model Difference" manually? Delete it and let it get recreated?
    Yes. If you delete the "Shared Model Differenceobject , it will be recreated on restart and initialized using the content of the Model.xafml file (and its aspects if any). Alternatively, you can manually update xml code in the ModelDifferenceAspect detail view.

    > The biggest issue with that is the My Details item, which is generated there. Any attempt to move it to another nav group eventually has that change erased and it ends up back in the default group.
    I have just tested this scenario. The navigation group change is correctly applied after I delete the "Shared Model Differenceobject and restart.

    > Also, can we (easily) override the behavior of "Create Model Differences" action?
    Yes, you can inherit the ModelDifferenceViewController and override its CreateModelDifferences method.

    > Also, do all users need read/write access to ModelDifference and ModelDifferenceAspect in order to store their user settings?
    Yes.

    > It all seems to be working without it, but wondering how it circumvents security.
    It works while you use UI-level security. If you switch to the Integrated mode (i.e, use SecuredObjectSpaceProvider) or use the Middle Tier server, user differences will not be loaded/saved unless you grant read/write permissions to ModelDifference and ModelDifferenceAspect.

  • Nate Laff3 years ago
     

    The Shared Model Difference is nice, but still not user friendly because any changes you make to it wipe out the Model.xafml (My Details). It's almost like there needs to be a hidden "Application Model Differences" where the model.xafml contents always reside, and shared model diffs can look at it, too to pull in those changes.

  • @Nate: I appreciate your feedback. I have devoted a separate thread to this usability problem: ModelDifferenceDbStore - Always take into account the latest changes made to the Model.XAFML file at design time. Thanks.
  • Nate Laff3 years ago
     

    Thanks Dennis.

    Can we also get some property to customize the name of "Shared Model Difference" object  to something more appropriate for end users? That would be helpful :)

  • Yes, it is already possible by changing the Localization | Texts | SharedModelDifferenceName node value via the Model Editor. We are also discussing the capability to pass any string identifier into the ModelDifferenceDbStore constructor.

    P.S.
    Please create separate tickets in the Support Center if you have any questions or suggestions on this feature, not to mix everything within a single thread. Thanks for your understanding.

  • Willem de Vries3 years ago
     

    Please remove the solution and refer to the knowledge base article https://documentation.devexpress.com/#Xaf/CustomDocument3698 instead.

    Willem

  • Carlitos3 years ago
     

    This is not functional: "Currently, the simultaneous use of the database model differences storage in both a WinForms and ASP.NET application by the same user account is not recommended. In general, model differences of WinForms and ASP.NET applications are incompatible. As a workaround, you can create two separate accounts for a user who works in both WinForms and ASP.NET applications."

  • @Willem: I have updated the ticket description, thanks.
    @Carlos: Thanks for your feedback, we have registered Application Model - Make it easier to store user settings in the database for WinForms and Web applications separately to simplify this process.
    @All: Please create separate tickets in the Support Center if you have any questions or suggestions on this feature, not to mix everything within a single thread. Thanks for your understanding.
  • Brian L3 years ago
     

    Should this view be auto-generated if you upgrade and use the project converter on an existing project?

  • @Brian: No, it should not. Please follow the eXpressApp Framework > Task-Based Help > How to: Store the Application Model Differences in the Database article to learn more on how to add it.

Core - Provide an easy way to store administrator and user model differences in a custom store (e.g., in a database)的更多相关文章

  1. CoreData修改了数据模型报错 The model used to open the store is incompatible with the one used to create the store

    在iOS 6 – Core Data 应用程序的开发过程中, App启动时出现如下异常信息: reason = “The model used to open the store is incompa ...

  2. iOS/Xcode异常:reason = “The model used to open the store is incompatible with the one used to create the store”

    reason=The model used to open the store is incompatible with the one used to create the store 出现上述异常 ...

  3. The model used to open the store is incompatible with the one used to create the store

    说什么数据不兼容,,,,这时删除模拟器的应用,,,重新启动测试.

  4. Ext JS 6学习文档–第1章–ExtJS入门指南

    Ext JS 入门指南 前言 本来我是打算自己写一个系列的 ExtJS 6 学习笔记的,因为 ExtJS 6 目前的中文学习资料还很少.google 搜索资料时找到了一本国外牛人写的关于 ExtJS ...

  5. Ext Js v6.2.0.103 Sencha Cmd 命令

    Sencha Cmd v6.2.0.103 Sencha Cmd 提供几种全局开关命令. 在大多数案例中, 第一步是在Sencha SDK基础上创建应用 例如 Ext JS 或 Sencha Touc ...

  6. the core of Git is a simple key-value data store The objects directory stores all the content for your database

    w https://git-scm.com/book/en/v1/Git-Internals-Plumbing-and-Porcelain Git is a content-addressable f ...

  7. External Configuration Store Pattern 外部配置存储模式

    Move configuration information out of the application deployment package to a centralized location. ...

  8. Oracle 12.1.0.2 New Feature翻译学习【In-Memory column store内存列存储】【原创】

    翻译没有追求信达雅,不是为了学英语翻译,是为了快速了解新特性,如有语义理解错误可以指正.欢迎加微信12735770或QQ12735770探讨oracle技术问题:) In-Memory Column ...

  9. ExtJS笔记 Store

    The Store class encapsulates a client side cache of Model objects. Stores load data via a Proxy, and ...

随机推荐

  1. windows下PyCharm安装及使用

    一.首先安装pycharm,可以参考这篇文章:http://www.jianshu.com/p/042324342bf4 1.win10_X64,其他Win版本也可以. 2.PyCharm版本:Pro ...

  2. December 04th 2016 Week 50th Sunday

    Learn wisdom by the follies of others. 前车之鉴,后人之师. Maybe my personal state is that others can learn w ...

  3. 自定义input[type="checkbox"]的样式

    对复选框自定义样式,我们以前一直用的脚本来实现,不过现在可以使用新的伪类 :checkbox 来实现. 如果直接对复选框设置样式,那么这个伪类并不实用,因为没有多少样式能够对复选框起作用.不过,倒是可 ...

  4. vue部署到tomcat

    # vue打包到tomcat部署步骤a.进入项目目录运行npm run devb.将dist目录复制到远程服务器下的tomcat/webapps下c.重启tomcatd.浏览器中访问 http:本机i ...

  5. [Violet]天使玩偶/SJY摆棋子

    题目 \(KD-tree\)做最近点对的复杂度好像是假的吧,怎么看也看不出来是\(O(\sqrt{n})\)啊 首先\(KD-tree\)长得和平衡树还是很像的,每个节点都存储了一个\(k\)维空间上 ...

  6. [SDOI2014]LIS

    这道题还是非常好的 首先第一问可以让我们联想到某网络流二十四题里的一道题,发现建图方式应该和这道题差不多啊 所以首先跑一遍\(dp\),求出\(dp[i]\)表示\(i\)位置结束的\(LIS\)长度 ...

  7. Docker存储方式选型建议

    转自:https://segmentfault.com/a/1190000007168476 第一部分 问题诊断 事情从一次实施项目说起,我们需要帮助客户将他们的应用容器化并在数人云平台上发布此应用. ...

  8. zoc 下载服务器上数据出现的问题

    zoc上有一个download的按钮能够将服务器上的数据下载下来,但是在下载过程中出现了错误 但是点击会出现下面的问题: 这个配置默认是采用ZMODEM文件传输协议 但是可以看出来,这个传输协议有点问 ...

  9. nodejs实现mysql数据库的简单例子

    在MySQLWorkbench中创建table存储用户的tokenId信息: use token; SET FOREIGN_KEY_CHECKS = ; DROP TABLE IF EXISTS `a ...

  10. django用户验证机制

    django的验证机制 from django.contrib.auth.decorators import login_required 需要在要验证的界面添加`@login_required` 登 ...