summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/dsa/dsa_key.c (unfollow)
Commit message (Collapse)AuthorFilesLines
2024-07-14Rewrite EVP_PKEY_add1_attr_by_NID()tb1-11/+41
Instead of jumping through many layers that cause headache, we can achieve the same in an entirely straightforward way without losing clarity. ok jsing
2024-07-14Disable most EVP_PKEY_*attr* APItb1-14/+17
There is a single consumer of this entire family of function, namely the openssl(1) pkcs12 command uses EVP_PKEY_add1_attr_by_NID, so leave that one intact for now. ok jsing
2024-07-14Forgot to annotate the TMP UGLY CAST[S] as requested by jsingtb1-1/+2
h/t to levitte
2024-07-14Document SSL_CIPHER_get_handshake_digest(3)tb1-2/+22
2024-07-14Prepare to provide SSL_CIPHER_get_handshake_digest()tb3-3/+23
Needed by newer freeradius. This is a straightforward implementation that essentially duplicates tls13_cipher_hash(). ok jsing
2024-07-14Remove lhash_local.h.jsing4-99/+26
lhash_local.h was previously needed since conf/conf_api.c and objects/obj_dat.c were fiddling with lhash internals when deleting via a callback. Since we no longer need to do that, inline the structs in lhash.c and remove the header. ok tb@
2024-07-14Add wcsnlen(3), wcslen(3) with a max len argumentjca3-7/+84
Missing function hit by fcambus@ some time ago. ok millert@
2024-07-14Add elf_aux_info(3)jca3-1/+59
Designed to let userland peek at AT_HWCAP and AT_HWCAP2 using an already existing interface coming from FreeBSD. Headers bits were snatched from there. Input & ok kettenis@ libc bump and sets sync will follow soon
2024-07-14"please refer" -> "refer"jsg1-3/+3
missed in 2022 "remove please from manual pages" commit ok tb@
2024-07-13ssl2.h and ssl23.h join the party in the attictb5-257/+11
Now that the SSL2 client hello support is gone, nothing uses this anymore, except that a few ports still need SSL2_VERSION. ok beck
2024-07-13Make error constants const in libssltb1-5/+5
This could be made cleaner if we expose ERR_load_const_strings(), but for now this hackier version with casts achieves the same and removes the last unprotected modifiable globals in this library. ok jsing
2024-07-13Move the sigaction next to multitb1-2/+2
Reduces diff in -portable
2024-07-13Unify X.509v3 extension methodstb21-376/+691
Use C99 initializers for all structs (some were forgotten). Make all the structs static, call them x509v3_ext_* matching NID_*. Add accessors called x509v3_ext_method_* and use these to implement X509V3_EXT_get_nid(). This adds consistency and avoids a few contortions like grouping a few extensions in arrays to save a couple externs. ok beck jsing
2024-07-12Fix the horrible and undocumented behaviour of X509_check_trustbeck4-54/+73
Of allowing you to pass in a NID directly, instead of a trust_id, and have it work, as long as the trust_id's and the NID's did not overlap. This screwball behaviour was depended upon by the OCSP code that called X509_check_trust with the NID, instead of the trust id, so let's fix that. We also rename the confusingly named X509_TRUST_DEFAULT to X509_TRUST_ACCEPT_ALL which makes a lot more sense, and rototill this to remove the confusingly named static functions. This will shortly be follwed up by making this function private, so we have not bothered to fix the amazingly obtuse man page as it will be taken behind the barn at that time. ok tb@
2024-07-12Clean up in X509_check_trust.beck1-14/+8
The XXX comment in here is now outdated. Our behaviour matches boringssl in that passing in a 0 trust gets the default behavior, which is to trust the certificate only if it has EKU any, or is self signed. Remove the goofy unused nid argument to "trust_compat" and rename it to what it really does, instead of some bizzare abstraction to something simple so the code need not change if we ever change our mind on what "compat" is for X.509, which will probably only happen when we are back to identifying things by something more sensible like recognizable grunts and smells. ok jsing@
2024-07-12Drop the unused evp includetb1-2/+1
2024-07-12Rename the sk in this file to extstb1-16/+16
2024-07-12Avoid using ret for an X509_EXTENSIONtb1-16/+16
Instead rename the **ext in this file to **out_ext, freeing up ext in X509_EXTENSION_create_by_OBJ() Appeases some jsing grumbling on review
2024-07-12Tweak variable names in X509v3_add_ext()tb1-12/+12
x -> out_ext, sk -> exts requested by jsing on review
2024-07-12Rename crit to critical in this filetb1-10/+10
requested by jsing on review
2024-07-12Simplify X509_EXTENSION_get_critical()tb1-4/+3
This is a silly API, but there are worse. ok jsing
2024-07-12Lose a few extra lines in X509_EXTENSION_set_object()tb1-4/+2
ok jsing
2024-07-12Streamline X509_EXTENSION_create_by_OBJ()tb1-9/+10
ok jsing
2024-07-12Clean up X509_EXTENSION_create_by_NID()tb1-9/+5
Remove unnecessary ret parameter and freeing of obj (which looks like a double free or freeing of unallocated memory but actually isn't due to various magic flags). Also make this const correct. ok jsing
2024-07-12Rewrite X509v3_add_ext()tb1-24/+23
This is another brilliancy straight out of muppet labs. Overeager and misguided sprinkling of NULL checks, going through the trademark poor code review, made this have semantics not matching what almost every other function with this signature would be doing in OpenSSL land. This is a long standing mistake we can't fix without introducing portability traps, but at least annotate it. Simplify the elaborate dance steps and make this resemble actual code. ok jsing
2024-07-12Simplify X509v3_get_ext() and X509v3_delete_ext()tb1-7/+1
Drop unnecessary checks that are part of the stack API. ok jsing
2024-07-12Align X509v3_get_ext_by_critical() with X509v3_get_ext_by_OBJ()tb1-12/+9
Plus, replace a manual check with a call to X509_EXTENSION_get_critical(). ok jsing
2024-07-12Clean up X509v3_get_ext_by_OBJ()tb1-11/+7
Like most of its siblings, this function can be simplified significantly by making proper use of the API that is being built. Drop unnecessary NULL checks and other weirdness and add some const correctness. ok jsing
2024-07-12use sigaction() to setup SIGARLM so we can set SA_RESTART, andderaadt1-6/+8
remove the re-arming in the handler. Better than using siginterrupt(), and avoids the errno saving requirement in the handler also. ok guenther millert
2024-07-12Despite being an ELF citizen, hppa is its own special snowflake and requiresmiod1-1/+5
different asm stanzas to produce strong aliases. This unbreaks libssl on hppa after the recent switch to LIBRESSL_NAMESPACE.
2024-07-11Despite being an ELF citizen, hppa is its own special snowflake and requiresmiod1-1/+5
different asm stanzas to produce strong aliases. This unbreaks libcrypto (and thus ssh, among other things) on hppa after the recent switch to LIBRESSL_CRYPTO_NAMESPACE.
2024-07-11Adjust regress to match changes in SSL_select_next_proto() argstb1-123/+99
2024-07-11Adjust documentation for SSL_select_next_proto()tb1-30/+48
Use better argument names, add a link to the relevant standards and add CAVEATS and BUGS sections pointing out a few pitfalls. discussed with davidben ok beck
2024-07-11Follow BoringSSL's nomenclature in SSL_select_next_proto()tb1-28/+30
SSL_select_next_poto() was written with NPN in mind. NPN has a weird fallback mechanism which is baked into the API. This is makes no sense for ALPN, where the API behavior is undesirable since it a server should not end up choosing a protocol it doesn't (want to) support. Arguably, ALPN should simply have had its own API for protocol selection supporting the proper semantics, instead of shoehorning an NPN API into working for ALPN. Commit https://boringssl-review.googlesource.com/c/boringssl/+/17206/ renamed the arguments to work for both NPN and ALPN, with the slight downside of honoring client preference instead of the SHOULD in RFC 7301, section 3.2. This grates for most consumers in the wild, but so be it. The behavior is saner and safer. discussed with davidben ok beck
2024-07-10Zap warning against __findenv usage, it is not exported by libcjca1-3/+1
The comment probably made sense before guenther restricted the symbols exported by libc in 2015.
2024-07-10Remove the static symbols.namespace, and just generate the _libre_beck2-3359/+3
symbols from symbols.list now that we have everything hidden ok tb@
2024-07-10Teach symbols test about the namespacetb2-3/+9
This ensures that when adding public symbols, the magic is not omitted. with/ok beck
2024-07-10forgot to add a history section for the TLS PRF APItb1-1/+4
2024-07-10link EVP_PKEY_CTX_set_tls1_prf_md.3 to buildtb1-1/+2