UE-EasyJWT
UE-EasyJWT copied to clipboard
JWT wrapper (Engine Sub-system) for Unreal Engine.
This project is no longer maintained on GitHub, but you may obtain the latest maintained version on Unreal Marketplace.
Json Web Tokens for Unreal Engine 4/5
EasyJwt subsystem
EasyJwt is a JSON web tokens engine sub-system for Unreal Engine 4/5, that provides a c++ and bluprint interface to Generate, Sign, Verify and manage claims of JWT.
Supported Platforms
- Windows x86_64
- Hololens 2 (Windows ARM64)
- Linux x86_64
- Linux ARM64
C++ Modules Link
Link the plugin modules to your project through <YourModule>.build.cs
:
bEnableExceptions = true;//we are using exceptions
PrivateDependencyModuleNames.AddRange( new string[]
{
"EasyJwt",
"JwtCpp",
"JwtVerifier",
"JwtGenerator"
});
JWT Generator Basic Usage
C++
Initialize the Generator
#include "EasyJwtSubsystem.h"
TSharedPtr<FEasyJwtModule> EasyJwt = GEngine->GetEngineSubsystem<UEasyJwtSubsystem>()->GetEasyJwt();
EasyJwt->GetGenerator()->InitGenerator(`<SIGNING_KEY>`, EGeneratorAlgorithm::HS256);
Generate Signed Token Basic Example:
#include "EasyJwtSubsystem.h"
TSharedPtr<FEasyJwtModule> EasyJwt = GEngine->GetEngineSubsystem<UEasyJwtSubsystem>()->GetEasyJwt();
TMap<FString, FString> Claims =
{
{"Claim1","34235"},
{"Claim2","dfgds"}
};
TMap<FString, FString> HeaderClaims =
{
{"HeaderClaim1","345343"},
{"HeaderClaim2","jhgfdrtt"}
};
/*
Valid since generating it and for 900sec with the givem claims.
*/
FString JwtToken = EasyJwt->GetGenerator()->GenerateJwtToken(true, 0, 900, Claims, HeaderClaims);
Blueprint
Initialize the Generator
data:image/s3,"s3://crabby-images/9a3ff/9a3ff7c5dfc58b828527837e5342ca04aaa2fcb2" alt="InitGenerator"
Generate Signed Toker
data:image/s3,"s3://crabby-images/3099e/3099e3d4b7fd8e16a3d5fb87a967b2487869e59e" alt="GenerateToken"
Blueprint API
data:image/s3,"s3://crabby-images/363b6/363b6a4b7439bf97446bb79c05d7100902dbd3d4" alt="GeneratorBp"
JWT Verifier Basic Usage
C++
Initialize the Verifier
#include "EasyJwtSubsystem.h"
TSharedPtr<FEasyJwtModule> EasyJwt = GEngine->GetEngineSubsystem<UEasyJwtSubsystem>()->GetEasyJwt();
EasyJwt->GetVerifier()->InitVerifier(`<SIGNING_KEY>`, EVerifierAlgorithm::HS256);
Verify a Token
#include "EasyJwtSubsystem.h"
TSharedPtr<FEasyJwtModule> EasyJwt = GEngine->GetEngineSubsystem<UEasyJwtSubsystem>()->GetEasyJwt();
bool bValid = EasyJwt->GetVerifier()->VerifyJWT(`<TOKEN_TO_VERIFY>`);
Get Claims From JWT
#include "EasyJwtSubsystem.h"
TSharedPtr<FEasyJwtModule> EasyJwt = GEngine->GetEngineSubsystem<UEasyJwtSubsystem>()->GetEasyJwt();
TMap<FString, FString> Claims = EasyJwt->GetVerifier()->GetClaims(`<JWT>`);
Blueprint
Initialize the Verifier
data:image/s3,"s3://crabby-images/2ad26/2ad268f913f9a972531c50ff6cb231c7eb154f2f" alt="InitVerifier"
Verify a Token
data:image/s3,"s3://crabby-images/aa60b/aa60b21741aaa48072486e7b1291fbd5d8c5fd4b" alt="GenerateToken"
Extract Claims From a JWT
data:image/s3,"s3://crabby-images/21479/21479ad1a8378390e30544ce84360ef6516e4167" alt="Claims"
Blueprint API
data:image/s3,"s3://crabby-images/1dfff/1dfff7bf081bffd1419f9e10276d4763a9178567" alt="VerifierBp"
Supported Algorithms
- HS256
- HS348
- HS512
- RS256
- RS384
- RS512
More to come soon!!
Find it helpful?
Give us a ⭐️!