Tutorial: Using Sqids encoding
Go Up to Database and LiveBindings Tutorials
This tutorial shows how to use Sqids encoding in RAD Studio. Sqids is a handy feature when navigating a data structure like a database table. 
RAD Server, by default, exposes URLs that might include specific internal information about the records. For instance, it is expected to identify an individual record using the primary key, often an ID. Therefore, servers might have endpoints with an ending similar to this /customer/12345. 
There are multiple reasons why this is far from ideal, from the fact that you are sharing internal details (which might not be as neutral as a number) to the potential security implications of revealing a record ID.
There are many solutions to this problem, mainly around a bidirectional mapping of the record ID to a string. Rather than implementing a custom solution, starting with RAD Studio 12.0, we are adopting the Sqids library.
Contents
What is Sqids?
It is an open-source library that generates short IDs from positive numbers (for example, using the Sqids default settings, 12345 is encoded to A6da).
Moreover, Sqids allows the encoding of one or more positive numbers into a single ID. There is no limit on the amount of numbers to encode, but there is a limit on their length (depending on the implementation language).
To learn more about Sqids, visit Sqids FAQ.
Code Example: How to use Sqids encoding
To implement Sqids, RAD Studio 12.0 introduced a new class named System.NetEncoding.Sqids.TSqidsEncoding, which provides all the methods to use Sqids. The steps to implement it are:
- Make sure the System.NetEncoding.Sqids unit is under the usesclause.
- Create the TSqidsEncoding instance using the Create method.
- Encode the ID or IDs using the Encode method.
- Decode it using one of the following methods, depending on your application needs:
- You can destroy the TSqidsEncoding instance using the Destroy method.
Make a request to a web server using Sqids
There are two ways to make a request to a web server using Sqids:
- Encoding it manually using the methods described above.
- Starting the TRESTRequest.ResourceSuffix parameter name with #.
In the second case, when it is time to send a request whose paramenter name starts with #, TRESTClient automatically creates an instance of TSqidsEncoding using TRESTClient.SqidsAlphabet and TRESTClient.SqidsMinLength properties.
On the other hand, in a RAD Server resource, when the ResourceSuffix parameter name starts with #, the value will be Sqids decoded. The algorithm's configuration is based on the EMSServer.ini file, particularly, Alphabet and MinHashLength parameters:
[Server.Sqids] ;# The following options control URL parameters Sqids decoding ;# ;# Optional alphabet for Sqids decoding Alphabet= ;# Optional minimal hash length for Sqids decoding MinHashLength=0
See Also
- System.NetEncoding.Sqids.TSqidsEncoding.Create
- System.NetEncoding.Sqids.TSqidsEncoding.Encode
- System.NetEncoding.Sqids.TSqidsEncoding.Decode
- System.NetEncoding.Sqids.TSqidsEncoding.DecodeSingle
- System.NetEncoding.Sqids.TSqidsEncoding.TryDecodeSingle
- System.NetEncoding.Sqids.TSqidsEncoding.DecodeToStr
- System.NetEncoding.Sqids.TSqidsEncoding.Destroy
- REST.Client.TRESTClient
- REST.Client.TRESTClient.SqidsAlphabet
- REST.Client.TRESTClient.SqidsMinLength