The 1000 steps program to MDriven Chapter 11
No edit summary
No edit summary
Line 27: Line 27:


== Chapter 11: User Login, Access Groups, Default Superclass, Singleton Pattern, and Merge Model ==
== Chapter 11: User Login, Access Groups, Default Superclass, Singleton Pattern, and Merge Model ==
332. Go to the Wiki [[Model Examples]] and download the SysUserAuthentication model.  
332. Go to the Wiki, click on [[/wiki.mdriven.net/Model Examples|Model Examples]] in the top menu, and download the '''SysUserAuthentication''' model.  


333. Open and Merge in the downloaded file.
333. Open and Merge in the downloaded file.
Line 33: Line 33:
334. Verify that the SysSingleton has the property ''IsSingleton'' set in the objects inspector.
334. Verify that the SysSingleton has the property ''IsSingleton'' set in the objects inspector.


335. Make sure you understand the Singleton pattern.  
335. Make sure you understand the Singleton pattern.
* Check the Wiki and also google the concept: https://en.wikipedia.org/wiki/Singleton_pattern
 
·       Check the Wiki and also google the concept: [[/en.wikipedia.org/wiki/Singleton pattern|https://en.wikipedia.org/wiki/Singleton_pattern]]
 
336. Start the prototyper with XML persistence.
336. Start the prototyper with XML persistence.


337. Test the OCLSingleton operator in the prototyper - ensure you get an object.
337. Test the OCLSingleton operator in the prototype [SysSingleton.oclSingleton] - ensure you get an object.


338. Select the SysSingleton ''CurrentUser'' association in the class diagram. Check that Persistent is set to ''false,'' and thus, the association is transient.
338. Select the SysSingleton ''CurrentUser'' association in the class diagram. Check that Persistent is set to ''false,'' and thus, the association is transient.


339. Select the SysSuperClass in the diagram. Check the OnCreate and OnUpdate on the Wiki.
339. Select the SysSuperClass in the diagram. Check the [[/wiki.mdriven.net/OCLOperators OnCreate|OnCreate]]  and [[/wiki.mdriven.net/OCLOperators OnUpdate|OnUpdate]] on the Wiki.


340. Make sure you understand what [[OCLOperators OnCreate|OnCreate]] and [[OCLOperators OnUpdate|OnUpdate]] do. Use the debugger to verify your theory on how it works.
340. Make sure you understand what OnCreate and OnUpdate do. Follow the video on how the debugger is used to verify the theory on how it works.


341. Ensure that the SysSuperClass is the default superclass for the AuthenticationPackage.
341. Ensure that the SysSuperClass is the default superclass for the AuthenticationPackage.


342. Check the ''oclIsTypeOf'', ''oclIsKindOf,'' and ''superTypes'' operators in the debugger.  
342. Check the oclIsTypeOf, oclIsKindOf, and superTypes operators in the debugger.
 
·      SysSingleton.oclSingleton.oclIsTypeOf(SysSuperClass)
 
o   Execute (F5).
 
o   Verify you get ✅, signifying it is true
 
·      SysSingleton.oclSingleton.oclIsKindOf(SysSuperClass)SysSingleton
 
o   Execute (F5)
 
o   Verify you get ✅, showing it’s a subclass of SysSuperClass
 
·      SysSingleton.superTypes
 
o   Verify you get “SysSuperClass”


343. Set the Default superclass of Package1 to the SysSuperClass.
343. Set the Default superclass of Package1 to the SysSuperClass.


344. Start the debugger or refresh the model. Make sure Person now has the ChangeTime attribute.
344. Start the debugger or refresh the model. Make sure Person now has the ChangeTime attribute. (we have no doc for this attribute)


345. In the debugger, set the empty Guid property to a new Guid for all persons.
345. In the debugger, set the empty Guid property to a new Guid for all persons.


346. When you save the persons, ensure the ChangeTime is updated.
·      Change Person.allinstances to an Action expression
 
·      Set this expression: Person.allinstances->collect(p|p.Guid:=Guid.NewGuid)


347. Start Local Turnkey Prototyper.
·      Execute(F5). You should see a new Guid assigned to the Guid.


348. Try and login with any user.  
·      Save
 
346. When you save all persons, ensure the ChangeTime is updated.
 
347. Start the Local Turnkey Prototyper.
 
348. Try to login with any user.


349. Register a new user with email and password.
349. Register a new user with email and password.
Line 65: Line 91:
350. Go to the debugger and check that you have a new SysUser object.
350. Go to the debugger and check that you have a new SysUser object.


351. Go to CarSeeker ViewModel and set AccessGroup to IsLoggedIn. Save.
·      Input SysUser.allinstances and verify that a new SysUser has been created.
 
351. Go to the ViewModel Editor, select the CarSeeker ViewModel and click on the box to set its AccessGroups to IsLoggedIn. Save.


352. Ensure you cannot see CarSeeker when you are not logged in.
352. Try accessing CarSeeker. Ensure you cannot see CarSeeker when you are not logged in.


353. Ensure you can see CarSeeker when you are logged in.
353. Ensure you can see CarSeeker only when you are logged in.


354. Go to the AccessGroup-tool button.  
354. Go to the AccessGroup-tool button found at the top menu, next to the Actions Editor button.


355. Check the expressions that build up the IsLoggedIn access group and see that you understand them.
355. Check the expressions that build up the IsLoggedIn access group and see that you understand them.


356. Add a new access group: <code>IsAdministrator</code>
356. Add a new access group: IsAdministrator
 
·      Set both the Enable Expression and Viable Expression to: SysSingleton.oclSingleton.CurrentUser.IsAdmin=true
 
·      Save  


357. Refresh the AutoForms. Make sure you get Autoforms for SysUser.
357. Refresh the AutoForms. Make sure you get Autoforms for SysUser.


358. Go to AutoformsysUser and set access group ''IsAdministrator''.
358. Go to AutoformSysUser and set the access group to ''IsAdministrator''.
 
359. Check the result on your webapplication.
 
360. Ensure you don't get access and get an error message (Access denied).
 
361. Create a new ViewModel name AccessDenied to explain that the user does not have access.  Double-click to add the row and input “ in the Expression box. Save.


359. Do the same for AutoFormSysUserSeeker.
362. Set the access group for AutoFormSysUserSeeker to IsAdministrator.


360. Ensure you don't get access.
·      Go to the debugger and Re-Read the model.


361. Create a new ViewModel name: <code>AccessDenied</code>. Make it explain that the user does not have access.
·      Write the expression: SysUser.allinstances. Save


362. Use the debugger and set the user as ''IsAdmin''. Save.
·      Open the Seeker and tick the IsAdmin box. Save


363. Ensure you can get into AutoFormSysUserSeeker since you are now an administrator.
363. Ensure you can get into AutoFormSysUserSeeker since you are now an administrator.


364. Create a new user <code>b@b.se</code> (or something else) and log in as that. Confirm that this user does not reach the AutoFormSysUserSeeker, but instead, ends up at the AccessDenied view.
364. Create a new user b@b.se (or something else) and log in as that. Confirm that this user does not reach the AutoFormSysUserSeeker but, ends up at the AccessDenied view.


'''Next Chapter:'''  
'''Next Chapter:'''  

Revision as of 05:04, 27 March 2024

This is Chapter 11. Are you looking for the beginning? Find it here: Chapter 1, or link to Chapter 10 (the previous chapter)

Video 11: Authentication

To make your experience smooth, we set the main tags mentioned in the video to the right bar menu of this mini-player. Choose an interesting subtitle on the list and immediately get to the exact theme navigation item place in the video. Now you can pick any topic to be instructed on without watching the whole video.

Authentication Introduction Singleton Pattern CIS Supercross CIS Superclose External Login Access Groups Access Group Editor

Chapter 11: User Login, Access Groups, Default Superclass, Singleton Pattern, and Merge Model

332. Go to the Wiki, click on Model Examples in the top menu, and download the SysUserAuthentication model.

333. Open and Merge in the downloaded file.

334. Verify that the SysSingleton has the property IsSingleton set in the objects inspector.

335. Make sure you understand the Singleton pattern.

·       Check the Wiki and also google the concept: https://en.wikipedia.org/wiki/Singleton_pattern

336. Start the prototyper with XML persistence.

337. Test the OCLSingleton operator in the prototype [SysSingleton.oclSingleton] - ensure you get an object.

338. Select the SysSingleton CurrentUser association in the class diagram. Check that Persistent is set to false, and thus, the association is transient.

339. Select the SysSuperClass in the diagram. Check the OnCreate  and OnUpdate on the Wiki.

340. Make sure you understand what OnCreate and OnUpdate do. Follow the video on how the debugger is used to verify the theory on how it works.

341. Ensure that the SysSuperClass is the default superclass for the AuthenticationPackage.

342. Check the oclIsTypeOf, oclIsKindOf, and superTypes operators in the debugger.

·      SysSingleton.oclSingleton.oclIsTypeOf(SysSuperClass)

o   Execute (F5).

o   Verify you get ✅, signifying it is true

·      SysSingleton.oclSingleton.oclIsKindOf(SysSuperClass)SysSingleton

o   Execute (F5)

o   Verify you get ✅, showing it’s a subclass of SysSuperClass

·      SysSingleton.superTypes

o   Verify you get “SysSuperClass”

343. Set the Default superclass of Package1 to the SysSuperClass.

344. Start the debugger or refresh the model. Make sure Person now has the ChangeTime attribute. (we have no doc for this attribute)

345. In the debugger, set the empty Guid property to a new Guid for all persons.

·      Change Person.allinstances to an Action expression

·      Set this expression: Person.allinstances->collect(p|p.Guid:=Guid.NewGuid)

·      Execute(F5). You should see a new Guid assigned to the Guid.

·      Save

346. When you save all persons, ensure the ChangeTime is updated.

347. Start the Local Turnkey Prototyper.

348. Try to login with any user.

349. Register a new user with email and password.

350. Go to the debugger and check that you have a new SysUser object.

·      Input SysUser.allinstances and verify that a new SysUser has been created.

351. Go to the ViewModel Editor, select the CarSeeker ViewModel and click on the box to set its AccessGroups to IsLoggedIn. Save.

352. Try accessing CarSeeker. Ensure you cannot see CarSeeker when you are not logged in.

353. Ensure you can see CarSeeker only when you are logged in.

354. Go to the AccessGroup-tool button found at the top menu, next to the Actions Editor button.

355. Check the expressions that build up the IsLoggedIn access group and see that you understand them.

356. Add a new access group: IsAdministrator

·      Set both the Enable Expression and Viable Expression to: SysSingleton.oclSingleton.CurrentUser.IsAdmin=true

·      Save  

357. Refresh the AutoForms. Make sure you get Autoforms for SysUser.

358. Go to AutoformSysUser and set the access group to IsAdministrator.

359. Check the result on your webapplication.

360. Ensure you don't get access and get an error message (Access denied).

361. Create a new ViewModel name AccessDenied to explain that the user does not have access.  Double-click to add the row and input “ in the Expression box. Save.

362. Set the access group for AutoFormSysUserSeeker to IsAdministrator.

·      Go to the debugger and Re-Read the model.

·      Write the expression: SysUser.allinstances. Save

·      Open the Seeker and tick the IsAdmin box. Save

363. Ensure you can get into AutoFormSysUserSeeker since you are now an administrator.

364. Create a new user b@b.se (or something else) and log in as that. Confirm that this user does not reach the AutoFormSysUserSeeker but, ends up at the AccessDenied view.

Next Chapter:

The_1000_steps_program_to_MDriven_Chapter_12

This page was edited 3 days ago on 05/16/2024. What links here