bitsToOctetsWithOrderPadding static method
Converts a sequence of bits represented as a byte array to octets.
This method takes a byte array 'data' containing a sequence of bits and converts it to octets by first converting it to a BigInt 'z1' and then computing 'z2' as 'z1' modulo 'order'. If 'z2' is negative, it is replaced with 'z1'. The resulting 'z2' is then converted to a byte array with padding to match the length of 'order' in octets.
Parameters:
- data: A
List<int>
containing the bits to be converted. - order: A BigInt representing the order of a cryptographic curve.
Returns:
List<int>
: A byte array representing the converted bits as octets.
Details:
- The method first converts the binary data to a BigInt 'z1'.
- It then computes 'z2' by taking 'z1' modulo 'order' and ensures that 'z2' is not negative; if it is, 'z2' is replaced with 'z1'.
- Finally, 'z2' is converted to a byte array with padding to match the length of 'order' in octets. The output is a byte array suitable for cryptographic use.
Implementation
static List<int> bitsToOctetsWithOrderPadding(List<int> data, BigInt order) {
final BigInt z1 = bitsToBigIntWithLengthLimit(data, order.bitLength);
BigInt z2 = z1 - order;
if (z2 < BigInt.zero) {
z2 = z1;
}
final bytes = bigintToBytesWithPadding(z2, order);
return bytes;
}