#!/bin/sh -ex WRAP=`jose alg -k wrap` ENCR=`jose alg -k encr` tmpdir=`mktemp -d 2>/dev/null || mktemp -d -t jose` onexit() { rm -rf $tmpdir } trap onexit EXIT jwk=$tmpdir/jwk jwe=$tmpdir/jwe jqopt() { if ! which jq >/dev/null 2>&1; then echo "$3" else jq -r "if $2 | type | . = \"string\" then $2 else error(\"\") end" < $1 fi } jqbopt() { if ! which jq >/dev/null 2>&1; then echo "$4" else jq -r "if $2 | type | . = \"string\" then $2 else error(\"\") end" < $1 \ | jose b64 dec -i- \ | jq -r "if $3 | type | . = \"string\" then $3 else error(\"\") end" fi } for msg in "hi" "this is a longer message that is more than one block"; do for w in $WRAP; do [ $w = "dir" ] && continue jose jwk gen -i "{\"alg\":\"$w\"}" -o $jwk printf '%s' "$msg" | jose jwe enc -I- -k $jwk -o $jwe [ "`jqopt $jwe .header.alg $w`" = "$w" ] [ "`jose jwe dec -i $jwe -k $jwk -O-`" = "$msg" ] for e in $ENCR; do printf '%s' "$msg" | jose jwe enc \ -i "{\"protected\":{\"enc\":\"$e\"}}" -I- \ -k $jwk -o $jwe [ "`jqopt $jwe .header.alg $w`" = "$w" ] [ "`jqbopt $jwe .protected .enc $e`" = "$e" ] [ "`jose jwe dec -i $jwe -k $jwk -O-`" = "$msg" ] done done for e in $ENCR; do jose jwk gen -i "{\"alg\":\"$e\"}" -o $jwk printf '%s' "$msg" | jose jwe enc \ -i "{\"protected\":{\"alg\":\"dir\"}}" -I- \ -k $jwk -o $jwe [ "`jqbopt $jwe .protected .alg dir`" = "dir" ] [ "`jqbopt $jwe .protected .enc $e`" = "$e" ] [ "`jose jwe dec -i $jwe -k $jwk -O-`" = "$msg" ] printf '%s' "$msg" | jose jwe enc -I- -k $jwk -o $jwe [ "`jqopt $jwe .header.alg dir`" = "dir" ] [ "`jqbopt $jwe .protected .enc $e`" = "$e" ] [ "`jose jwe dec -i $jwe -k $jwk -O-`" = "$msg" ] done for tmpl in '{"kty":"oct","bytes":32}' '{"kty":"RSA","bits":2048}' '{"kty":"EC","crv":"P-256"}'; do jose jwk gen -i "$tmpl" -o $jwk printf '%s' "$msg" | jose jwe enc -I- -k $jwk -o $jwe [ "`jose jwe dec -i $jwe -k $jwk -O-`" = "$msg" ] done done