/* ISC license. */ #include #include #include #include #include #include #include int sbearssl_ta_readdir (char const *dirfn, genalloc *taga, stralloc *tasa) { size_t tasabase = tasa->len ; size_t tagabase = genalloc_len(sbearssl_ta, taga) ; size_t dirfnlen = strlen(dirfn) ; int tasawasnull = !tasa->s ; int tagawasnull = !genalloc_s(sbearssl_ta, taga) ; stralloc certsa = STRALLOC_ZERO ; genalloc certga = GENALLOC_ZERO ; DIR *dir = opendir(dirfn) ; if (!dir) return -1 ; for (;;) { direntry *d ; errno = 0 ; d = readdir(dir) ; if (!d) break ; if (d->d_name[0] == '.') continue ; { size_t dlen = strlen(d->d_name) ; char fn[dirfnlen + dlen + 2] ; memcpy(fn, dirfn, dirfnlen) ; fn[dirfnlen] = '/' ; memcpy(fn + dirfnlen + 1, d->d_name, dlen) ; fn[dirfnlen + 1 + dlen] = 0 ; genalloc_setlen(sbearssl_cert, &certga, 0) ; certsa.len = 0 ; if (sbearssl_cert_readfile(fn, &certga, &certsa)) continue ; } sbearssl_ta_certs(taga, tasa, genalloc_s(sbearssl_cert, &certga), genalloc_len(sbearssl_cert, &certga), certsa.s) ; } if (errno) goto fail ; dir_close(dir) ; genalloc_free(sbearssl_cert, &certga) ; stralloc_free(&certsa) ; return 0 ; fail: { int e = errno ; dir_close(dir) ; genalloc_free(sbearssl_cert, &certga) ; stralloc_free(&certsa) ; if (tagawasnull) genalloc_free(sbearssl_ta, taga) ; else genalloc_setlen(sbearssl_ta, taga, tagabase) ; if (tasawasnull) stralloc_free(tasa) ; else tasa->len = tasabase ; errno = e ; } return -1 ; }