1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- #!/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 ! command -v jq >/dev/null 2>&1; then
- echo "$3"
- else
- jq -r "if $2 | type | . = \"string\" then $2 else error(\"\") end" < $1
- fi
- }
- jqbopt() {
- if ! command -v 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
|