AccessGroups, InterestGroups and ViewModel-Enable
m ((username removed) (log details removed): Enable is used in accessgroup for Views)
No edit summary
Line 16: Line 16:
A particular user may be interested in both Sales and Supply and as such the user should get Visible=true for both these interestGroups - and will thus show actions tagged with any of these groups.
A particular user may be interested in both Sales and Supply and as such the user should get Visible=true for both these interestGroups - and will thus show actions tagged with any of these groups.


A particular action may always be interesting to both Sales and Supply departments and as such it can be tagged with both interestGroups - or no interestGroup. Until you introduce a third group for example the Quality-department that will the same. Having no groups or all groups tagged on an action will be equivalent if all users get Visible=true from at least one InterestGroup.
A particular action may always be interesting to both Sales and Supply departments and as such it can be tagged with both interestGroups - or no interestGroup. Until you introduce a third group for example the Quality-department that will be the same. Having no groups or all groups tagged on an action will be equivalent if all users get Visible=true from at least one InterestGroup.


==== The View-Enable expression - the extreme complexity reduced to almost nothing ====
==== The View-Enable expression - considerable complexity reduced to almost nothing ====
The View-Enable expression has been available on the AccessGroups for some time - but it was a bit clumsy as it knocked out all fields on the tagged View when in evaluated to Enable=false.
The View-Enable expression has been available on the AccessGroups for some time - but it was a bit clumsy (up until now) as it knocked out all fields on the tagged View when in evaluated to Enable=false.


This was good for some use-cases, like protecting strict data entry forms - but bad in many cases since many views are not 100% data capture. Most views make use of some local variables - or maybe they change something transient - like an object of a Class marked Persistent=false. And in these cases we really want the user to be able to change the local variables - but not allowing them to change anything that will need a save to the database (anything marked being persistent=true as is default on classes, attributes and associations).
This was good for some use-cases, like protecting strict data entry forms - but bad in many cases since many views are not 100% data capture. Most views make use of some local variables - or maybe they change something transient - like an object of a Class marked Persistent=false. And in these cases we really want the user to be able to change the local variables - but not allowing them to change anything that will need a save to the database (anything marked being persistent=true as is default on classes, attributes and associations).

Revision as of 11:57, 15 January 2024

This article describe new features introduced in January 2024

The basic AccessGroups overview is found here

This article has an accompanying sample found here https://github.com/supportMDriven/Samples/tree/master/AccessGroupsInterestGroupsAndViewModelReadOnly

An AccessGroup is a collection of a Enable, Visible and View-Enable expressions. The expression are not rooted - meaning they have no particular context like a user or anything, to get the context of the current user that is very common for AccessGroups one could simply use SysSingleton.oclSingleton.CurrentUser from the SysUserAuthentication-pattern described here

The InterestGroup - the clutter reducer

What differs an InterestGroup from an AccessGroup: The InterestGroup is a softer sibling to the AccessGroup. The AccessGroup is used to control if Access is granted - and this has precedence. The InterestGroup is evaluated after AccessGroups - and controls if we should bother to show the tagged action to the user or not. In a large system the left-side menu can be filled with Class-Actions and ViewModel-Actions, and a user from the SalesDepartment my not be interested in actions leading to views or having functionality specific to the Supply department - or vice versa.

To avoid clutter and confusing options you can tag your users , or have your users tag themselves in a way that you pick up on in an interestgroup. This way users can reduce clutter of left-side menu themselves. If the action is Visible-true for any InterestGroup that tags the action - the action will be visible - but only if any AccessGroups on the action also agrees that it should be visible.

Since the whole point of an InterestGroup is to reduce clutter - the InterestGroup only offer the VisibleExpression - either tagged actions should show or not.

A particular user may be interested in both Sales and Supply and as such the user should get Visible=true for both these interestGroups - and will thus show actions tagged with any of these groups.

A particular action may always be interesting to both Sales and Supply departments and as such it can be tagged with both interestGroups - or no interestGroup. Until you introduce a third group for example the Quality-department that will be the same. Having no groups or all groups tagged on an action will be equivalent if all users get Visible=true from at least one InterestGroup.

The View-Enable expression - considerable complexity reduced to almost nothing

The View-Enable expression has been available on the AccessGroups for some time - but it was a bit clumsy (up until now) as it knocked out all fields on the tagged View when in evaluated to Enable=false.

This was good for some use-cases, like protecting strict data entry forms - but bad in many cases since many views are not 100% data capture. Most views make use of some local variables - or maybe they change something transient - like an object of a Class marked Persistent=false. And in these cases we really want the user to be able to change the local variables - but not allowing them to change anything that will need a save to the database (anything marked being persistent=true as is default on classes, attributes and associations).

A common example is a seeker. The Seeker may have a few actions on it that to things you want to restrict - maybe a CreateNew-action. At the same time you have actions that you want to allow; like search. You also want the user to be able to enter a search criteria in the search box - and maybe set some other search filters. The one separating thing between the "Dont allow this" and "Allow this" is (feel free to challenge this bold statement) that the "Allow this" group of actions and edits all are Transient (they do not change persistent data) - and the "Dont allow this"-group DO change persistent data. Please take a moment to think about this axiom. Is this true for most cases? Are there cases when it is not true? If it is true very often would you benefit from a platform that could figure this out this on its own?

How can we statically figure out if an expression will effect persistent data or not?

How can we statically figure out if an expression will effect persistent data or not - that was the question we wanted to find an answer to and that we deemed important enough - because if we can the View-Enable expression of the accessgroups would go from - "yes it works and locks or opens everything" to "YES it can read my mind and lets the user do benign things but stop the user from doing anything that risk to permanently change data".

Long story short: We solved it! For OCL-expressions we check if the resulting element is part of the model and if it is persistent - if so we lock the expression if View-Enable evaluates to false. For Action-Expressions the story is a bit more complex; we deem Action-Expressions to effect persistent data if:

  1. It uses one of these operators: Create, Delete and if so that Class is Persistent
  2. It includes a class member that is Persistent on the left side of any of these operators: ":=" , "add" , "insertat" , "clear" , "removeat", "remove"
  3. It uses a Method that is a Persistent class and it is not marked with IsQuery

The above distinction between AffectingPersistentData and not is only possible because we are in a managed environment when it comes to data management. If you would have implemented your system in most other modern object oriented languages the lack of available meta information on what is truly persistent, the lack of knowledge on what an association is and if it is persistent, the lack of knowing what properties belong to and if they are persistent would be this kind of static analysis very much harder. Luckily you have chosen wise and manage you Gist separate from your Modernity emoticon-smile.

This page was edited more than 8 months ago on 05/21/2024. What links here