...
As the requirements are not only to trigger the checks from the frontend, but also to perform references-checks from different systems, the checks cannot be performed in the frontend only. Hence, implementing the checks into the front end is considered not as a viable approach. Instead, the checks will be implemented in mod-users-bl so that the front end and different systems may use them.
- First of all we need to implement functionality to check , an additional endpoint needs to be implemented to check for references, if the user can be deleted:As this checks . This endpoint is needed as there is a use case for a pre-check endpoint. A different system (e.g. a campus management system) may check if there are open loans, fees/fines etc. that need to be paid before the user leaves. The actual deletion may take place one year later (for instance to be able to create reports).
- As the references check span multiple modules (e.g. checking open requests via
/request-storage
endpoint of mod-circulation-storage) the checks need to be done in a bl-module, namely mod-users-bl. - In order to check if a user can be deleted, add the endpoint
/bl-users/by-id/{id}/deletablereferences
to mod-bl-users. (There is no convention or standard way to do this. However, the _deletable_ endpoint was discussed in jira )server System Jira columnIds issuekey,summary,issuetype,created,updated,duedate,assignee,reporter,priority,status,resolution columns key,summary,type,created,updated,due,assignee,reporter,priority,status,resolution serverId 01505d01-b853-3c2e-90f1-ee9b165564fc key CIRC-179 - The proposed endpoint performs defined checks for a given user by querying the corresponding modules:
Fetch open loans from mod-circulation-storage via user's id:
/loan-storage/loans?query=(userId==c926be9c-a8ce-4399-a9b3-11ec0fc8d6c9 AND status.name=="Open")
Fetch open requests from mod-circulation-storage via user's id:
/request-storage/requests?query=(requesterId=="c926be9c-a8ce-4399-a9b3-11ec0fc8d6c9" and status=Open)
Fetch open fees/fines from mod-feesfines via user's id:
/accounts?query=(userId==54f65a75-f35b-4f56-86a6-fa4a3d957e57 AND status.name="Open")
Fetch proxy info from mod-users via user's id:
/proxiesfor?query=(userId=="54f65a75-f35b-4f56-86a6-fa4a3d957e57" OR proxyUserId=="54f65a75-f35b-4f56-86a6-fa4a3d957e57")
Fetch manual blocks from mod-feesfines via user's id:
/manualblocks?query=(userId==54f65a75-f35b-4f56-86a6-fa4a3d957e57)
Hence, we need to query three modules: `mod-circulation-storage`, `mod-feesfines` and `mod-users`.
The endpoint
/bl-users/by-id/{id}/deletable
returns ifreferences
returns if there are open references to the user and hence the user can be deleted or not. It can be deleted if totalRecords==0 for all responses of above queries.The response may look like:
{
"userID": "uuid-1234",
"message": "not deletable","deletable": false,
"loans": 1,
"requests": 0,
"fees/fines": 2,
"proxies": 0,
"blocks": 0
}
Based on this we can conclude that the user has one open loan and 2 open fees/fines.
- As the references check span multiple modules (e.g. checking open requests via
- In order to delete a user, add a DELETE endpoint to
/bl-users/by-id/{id}
- This endpoint first calls
/bl-users/by-id/{id}/deletablereferences
(or its implementation) to check if the user can be deleted. If this is the case, it calls DELETE on/users/{id}
. If the user cannot be deleted, as some above mentioned resources are pointing to this user, the response shall clarify this.
- This endpoint first calls
- When deleting a user from the ui, the frontend must call
/bl-users/by-id/{id}
. Another approach might be that DELETE /users/{id} calls /bl-users/by-id/{id}/deletable however this would assume mod-users needs mod-users-bl which would end in a circular dependency
...