Salesforce's Algorithm for Converting IDs from 15 to 18 Characters
Need to convert 15-character Salesforce IDs to 18-character IDs. Here's how:
data:image/s3,"s3://crabby-images/91d7f/91d7f6e67acb818302458508283a057d539cf4f3" alt="Salesforce's Algorithm for Converting IDs from 15 to 18 Characters"
The Context
Salesforce IDs are actually comprised of several pieces of data and can come in 15 or 18 character varieties. The difference is that the 18-character flavor has a suffix that will render them case-insensitive. From time to time, you have come across a data extract or something that contains the 15-digit variety and have a need to convert them to 18-digit IDs.
For more information about just what is included in a Salesforce ID, checkout this post:
Salesforce IDs Explained
Everything you ever wanted to know about Salesforce IDs and then some.
data:image/s3,"s3://crabby-images/83b9f/83b9f1d3aa9dbfcf8a1060554e9ff0fcc6a2f9db" alt=""
If you don't care to dig into the details and just want a handy online converter, here ya go:
Salesforce ID Converter
Convert 15-character Salesforce IDs to 18-character IDs.
data:image/s3,"s3://crabby-images/597dd/597dd85c135c0bb8f42228377e845f82ac6dfa70" alt=""
The Algorithm
- First we need to divide the 15-character ID into 3 groups of 5 characters.
data:image/s3,"s3://crabby-images/3377b/3377b390187f2d4fe0f8ab10a232750bfc3d23c5" alt="Illustration showing a 15-character ID divided into 3 sets of 5"
- Now we need to reverse the order of each set
data:image/s3,"s3://crabby-images/2acfd/2acfd09e7cad9dcb6a1e6844d6da3dd79102826f" alt="Illustration showing the reversal of each set"
-
For each set of characters, we will create a new set of bits (
1
s and0
s). Then for each character, we will add a1
to the corresponding set of bits, if the character is an uppercase letter, or a0
if the character is a lowercase letter, or a number.
data:image/s3,"s3://crabby-images/73dd8/73dd843fa621851d99760aa8cf1f056727f10df9" alt="Illustration showing the mapping of character sets to bit sets"
-
The previous step actually converted each character set into a number, in binary. Now we need to convert each binary number to a decimal number. This should leave us with 3 numbers that could range from
0
to31
.
data:image/s3,"s3://crabby-images/cbc10/cbc1015b57205a2e068a6913a268357e0d3509e7" alt="Illustration showing the conversion of binary numbers to decimal numbers"
-
Now we will need to construct a collection of character that will include uppercase letters from
A
toZ
, and the numbers0
through5
, as follows:ABCDEFGHIJKLMNOPQRSTUVWXYZ012345
-
The last step here is to look at our 3 numbers, and find the character in the collection we just created at the index of each number. The index is zero-based so
0
=A
,1
=B
, and so on. The result of this operation should leave us with 3 character.
data:image/s3,"s3://crabby-images/58b7f/58b7fdd7ab07af84f19a1bd3324a424e383b4aa2" alt="Illustration showing the mapping of a number to the index of a character in a collection"
And there's your suffix! 🎉
Simply tack it on to the end of the original ID
data:image/s3,"s3://crabby-images/2762f/2762f1998004fa4bee101c6831443d2744c1f54e" alt="Illustration showing the suffix characters added to the end of the original ID"
Need a code example?
This is the exact JavaScript that I use for my online-converter:
const convertId = id => {
let segments = id.match(/.{5}/g);
segments = segments.map(segment => {
return segment.split('').reverse().join('');
});
let bitArrays = [];
segments.forEach(segment => {
const bitArray = [];
segment.split('').forEach(char => {
bitArray.push(/[A-Z]/.test(char) ? '1' : '0');
});
bitArrays = [...bitArrays, bitArray.join('')]
});
const mapping = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5'];
suffixChars = bitArrays.map(bits => {
return mapping[parseInt(bits, 2)];
});
return suffixChars.join('');
};