Skip to content

Commit

Permalink
Merge branch 'latchset:master' into libfixes
Browse files Browse the repository at this point in the history
  • Loading branch information
hdholm authored Jan 6, 2024
2 parents 26013dd + 4878253 commit 9a438c8
Show file tree
Hide file tree
Showing 5 changed files with 41 additions and 32 deletions.
8 changes: 4 additions & 4 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,10 +22,10 @@ jobs:
stable:: [true]
include:
- compiler: gcc
os: fedora:rawhide
os: quay.io/fedora/fedora:rawhide
stable: false
- compiler: clang
os: fedora:rawhide
os: quay.io/fedora/fedora:rawhide
stable: false
- compiler: gcc
os: ubuntu:devel
Expand All @@ -34,7 +34,7 @@ jobs:
os: ubuntu:devel
stable: false
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3

- name: Show OS information
run: |
Expand Down Expand Up @@ -81,7 +81,7 @@ jobs:
- gcc
- clang
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3

- name: Show OS information
run: |
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/install-dependencies
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ debian:*|ubuntu:*)
done
;;

fedora:*)
*fedora:*)
echo 'max_parallel_downloads=10' >> /etc/dnf/dnf.conf
dnf -y clean all
dnf -y --setopt=deltarpm=0 update
Expand Down
2 changes: 1 addition & 1 deletion lib/meson.build
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ if not cc.links(code, args: flags, name: '-Wl,--version-script=...')
flags = [ '-export-symbols-regex=^jose_.*' ]
endif

libjose_lib = library('jose',
libjose_lib = shared_library('jose',
'misc.c', 'misc.h',
'cfg.c',
'io.c',
Expand Down
6 changes: 3 additions & 3 deletions lib/openssl/hmac.c
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ ver_done(jose_io_t *io)
}

static HMAC_CTX *
hmac(const jose_hook_alg_t *alg, jose_cfg_t *cfg,
jhmac(const jose_hook_alg_t *alg, jose_cfg_t *cfg,
const json_t *sig, const json_t *jwk)
{
uint8_t key[KEYMAX] = {};
Expand Down Expand Up @@ -251,7 +251,7 @@ alg_sign_sig(const jose_hook_alg_t *alg, jose_cfg_t *cfg, json_t *jws,

i->obj = json_incref(jws);
i->sig = json_incref(sig);
i->hctx = hmac(alg, cfg, sig, jwk);
i->hctx = jhmac(alg, cfg, sig, jwk);
if (!i->obj || !i->sig || !i->hctx)
return NULL;

Expand All @@ -275,7 +275,7 @@ alg_sign_ver(const jose_hook_alg_t *alg, jose_cfg_t *cfg, const json_t *jws,
io->free = io_free;

i->sig = json_incref((json_t *) sig);
i->hctx = hmac(alg, cfg, sig, jwk);
i->hctx = jhmac(alg, cfg, sig, jwk);
if (!i->sig || !i->hctx)
return NULL;

Expand Down
55 changes: 32 additions & 23 deletions tests/alg_comp.c
Original file line number Diff line number Diff line change
Expand Up @@ -41,22 +41,23 @@ const struct {
{}
};

typedef typeof(((jose_hook_alg_t *) NULL)->comp.inf) comp_func_t;

static void
test(const jose_hook_alg_t *a, comp_func_t func, bool iter,
const uint8_t *i, size_t il,
const uint8_t *o, size_t ol)
test(const jose_hook_alg_t *a, bool iter,
const uint8_t *i, size_t il)
{
jose_io_auto_t *b = NULL;
jose_io_auto_t *c = NULL;
jose_io_auto_t *z = NULL;
void *buf = NULL;
size_t len = 0;
void *buf1 = NULL;
void *buf2 = NULL;
size_t blen = 0;
size_t clen = 0;

b = jose_io_malloc(NULL, &buf, &len);
/* Test compression first. */
b = jose_io_malloc(NULL, &buf1, &blen);
assert(b);

z = func(a, NULL, b);
z = a->comp.def(a, NULL, b);
assert(z);

if (iter) {
Expand All @@ -68,8 +69,26 @@ test(const jose_hook_alg_t *a, comp_func_t func, bool iter,

assert(z->done(z));

assert(len == ol);
assert(memcmp(buf, o, ol) == 0);
/* Test decompression now. */
c = jose_io_malloc(NULL, &buf2, &clen);
assert(b);

z = a->comp.inf(a, NULL, c);
assert(z);

if (iter) {
uint8_t *m = buf1;
for (size_t j = 0; j < blen; j++)
assert(z->feed(z, &m[j], 1));
} else {
assert(z->feed(z, buf1, blen));
}

assert(z->done(z));

/* Compare the final output with the original input. */
assert(clen == il);
assert(memcmp(buf2, i, il) == 0);
}

int
Expand All @@ -93,20 +112,10 @@ main(int argc, char *argv[])
assert(jose_b64_dec_buf(tests[i].def, strlen(tests[i].def),
tst_def, sizeof(tst_def)) == sizeof(tst_def));

test(a, a->comp.def, false,
tst_inf, sizeof(tst_inf),
tst_def, sizeof(tst_def));

test(a, a->comp.inf, false,
tst_def, sizeof(tst_def),
test(a, false,
tst_inf, sizeof(tst_inf));

test(a, a->comp.def, true,
tst_inf, sizeof(tst_inf),
tst_def, sizeof(tst_def));

test(a, a->comp.inf, true,
tst_def, sizeof(tst_def),
test(a, true,
tst_inf, sizeof(tst_inf));
}

Expand Down

0 comments on commit 9a438c8

Please sign in to comment.