Lock records: A step-by-step guide
There has been a major change on 2019/09/22 in the events_lock_record()-function. This function has to return FALSE to skip overwriting membership after events_after_insert() call.
In Step 2 please have a look at lines 24 – 27 and change your code.
It has been requested many times: this is a step-by-step guide for conditionally locking records in AppGini applications.
This example will show how to lock a record and make fields readonly depending on the status of the record. I’m using the well known “OCMS” (clinic management) which is an AppGini demo project available here: http://bigprof.com/appgini/applications/online-clinic-management-system .
To illustrate the necessary changes I’m going to change the existing events
-table (“Appointments”).
Whenever the user changes the status to Closed
the record will be locked.
Due to the limits of AppGini 5.7x, not every field type can be locked. For example dropdowns, date-pickers and richtext editors will still look like editable and still be editable even if user has no permission to edit or insert.
What we can do is locking most of the field types and deny saving.
Locking all controls is a different story which will be told another day. See my last comment at the bottom of this page.
Prerequisites
Ensure that you have a separate user-group with at least one member for testing purposes. I’m going to create a group doctors
with one member doctor1
for this example.
Create Group
Go to Admin-Area
Create a group (if you don’t have one already) and grant the following permissions:
Create User
Create a new group-member (if you don’t have one already)
Now check if you can login as the newly created user. Also check if you can enter the table which you like to lock later on. In this example it is table events
.
[toc]
Step 1: Changes in AppGini project
1.1 Add a new status “Closed”
First we need a field which will be used to control the locking state. In this example we can use the already existing field status
.
Before we change the field, let’s have a look at the form:
There is only these two options available. We are going to add Closed
as third option now:
The status field is an “Options list” fields with list values “Active;;Cancelled”:
Available list options:
Add ;;Closed
1.2 Add a new field “created_by”
Create a new field which will will hold the creator of the record.
We will need this field later on whenever we need to unlock the record again.
1.3 Hide “Save As Copy”
1.4 Save and generate
Let us check the result: Now we can see all three options.
Step 2: Code changes in hooks/events.php
Whenever a user saves the record we have to check the status and lock it if status = "Closed"
.
This check shall be executed after insert and after update.
I am going to write a re-usable function named events_lock_record()
for this to avoid redundant code. This new function will be called after insert and after update
Let’s open hooks/events.php
in our code editor and insert some code.
// file: hooks/events.php // add this: function events_lock_record($data, $memberInfo, &$args) { $status = $data["status"]; $table = "events"; // PHP 5 $id = $data["selectedID"] ? $data["selectedID"] : $data["id"]; $creator = $data["created_by"] ? $data["created_by"] : $memberInfo["username"]; // in PHP 7 you can write // $id = $data["selectedID"] ?? $data["id"]; // $creator = $data["created_by"] ?? $memberInfo["username"]; $owner = "admin"; if ($status === "Closed") { set_record_owner($table, $id, $owner); } else { set_record_owner($table, $id, $creator); } // update 2019/09/22 // by returning FALSE we exit the AppGini function // BEFORE AppGini overwrites our ownership-setting return FALSE; } // ... // change this existing function function events_after_insert($data, $memberInfo, &$args) { return events_lock_record($data, $memberInfo, $args); } // ... // change this existing function function events_after_update($data, $memberInfo, &$args) { return events_lock_record($data, $memberInfo, $args); }
Step 3: Login and test
Summary
Solved issues
At this point we have reached the following:
- Users can insert and edit records as long as status is not
Closed
- As soon as
status = "Closed"
users will still be able to see the record but not able to save changes any more
Open issues at this point
- some fields are not locked, yet. As metioned at the beginning, certain fields like dropdowns, richtext-aread or datepickers are still editable.
Solving open issues
We are currently working on a couple of new cool features for our AppGini Helper JavaScript library.
One feature will help us on the open issues mentioned here: .readonly()-function which will work even for dropdons, datepickers or richtext fields.