mirror of
https://github.com/pintov/1c-jwt.git
synced 2024-11-18 16:21:42 +02:00
HMAC & JSON Web Token implementation in 1C:Enterprise
b7fa0739c1
Update README.md |
||
---|---|---|
src | ||
LICENSE | ||
README.md |
1C HMAC & JWT
This is a pure 1C implementation of RFC 2104 https://www.ietf.org/rfc/rfc2104.txt and RFC 7519 https://tools.ietf.org/html/rfc7519
Limitations
This implementation works only on 1C:Enterprise platform version 8.3.10.2168 or above.
The platform you may download here: https://1c-dn.com/user/updates/1c_enterprise_platform_training_version/
For JWT supported algorithm HS256 only.
HMAC function supports algorithms: MD5, SHA1, SHA256
PS: Since version 8.3.21 you may use AccessToken object to create JWT.
https://wonderland.v8.1c.ru/blog/autentifikatsiya-s-pomoshchyu-jwt-tokenov/
Installing
Download modules Cryptography.bsl and JWT.bsl. Put modules into the 1C application.
Usage
// HMAC
SecretKey = "key";
StringToSign = "The quick brown fox jumps over the lazy dog";
Signature = Cryptography.HMAC(
GetBinaryDataFromString(SecretKey),
GetBinaryDataFromString(StringToSign),
HashFunction.SHA256);
// JWT
SecretKey = "secret";
Payload = New Structure;
Payload.Insert("sub", "1234567890");
Payload.Insert("name", "John Doe");
Payload.Insert("admin", True);
Token = JWT.Encode(SecretKey, Payload);
DecodedPayload = JWT.Decode(Token, SecretKey);
Credits and License
Author: Vasily Pintov vasily@pintov.ru
License: MIT