2024-06-28 16:04:57 +05:30
|
|
|
{.push raises: [].}
|
2023-02-14 09:19:06 +01:00
|
|
|
|
2024-07-09 13:14:28 +02:00
|
|
|
import stew/[byteutils, base64], results
|
2023-02-14 09:19:06 +01:00
|
|
|
|
|
|
|
type Base64String* = distinct string
|
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
proc encode*[T: byte | char](value: openArray[T]): Base64String =
|
2023-02-23 09:31:06 +01:00
|
|
|
Base64String(encode(Base64Pad, value))
|
|
|
|
|
|
|
|
proc encode*(value: string): Base64String =
|
|
|
|
encode(toBytes(value))
|
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
proc decode[T: byte | char](
|
|
|
|
btype: typedesc[Base64Types], instr: openArray[T]
|
|
|
|
): Result[seq[byte], string] =
|
2023-02-23 09:31:06 +01:00
|
|
|
## Decode BASE64 string ``instr`` and return sequence of bytes as result.
|
|
|
|
if len(instr) == 0:
|
|
|
|
return ok(newSeq[byte]())
|
|
|
|
|
|
|
|
var bufferLen = decodedLength(btype, len(instr))
|
|
|
|
var buffer = newSeq[byte](bufferLen)
|
|
|
|
|
|
|
|
if decode(btype, instr, buffer, bufferLen) != Base64Status.Success:
|
|
|
|
return err("Incorrect base64 string")
|
|
|
|
|
|
|
|
buffer.setLen(bufferLen)
|
|
|
|
ok(buffer)
|
2023-02-14 09:19:06 +01:00
|
|
|
|
|
|
|
proc decode*(t: Base64String): Result[seq[byte], string] =
|
2023-02-23 09:31:06 +01:00
|
|
|
decode(Base64Pad, string(t))
|
2023-02-14 09:19:06 +01:00
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
proc `$`*(t: Base64String): string {.inline.} =
|
2023-02-14 09:19:06 +01:00
|
|
|
string(t)
|
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
proc `==`*(lhs: Base64String | string, rhs: Base64String | string): bool {.inline.} =
|
2023-02-14 09:19:06 +01:00
|
|
|
string(lhs) == string(rhs)
|