| // Copyright 2006-2016 The OpenSSL Project Authors. All Rights Reserved. | 
 | // | 
 | // Licensed under the Apache License, Version 2.0 (the "License"); | 
 | // you may not use this file except in compliance with the License. | 
 | // You may obtain a copy of the License at | 
 | // | 
 | //     https://www.apache.org/licenses/LICENSE-2.0 | 
 | // | 
 | // Unless required by applicable law or agreed to in writing, software | 
 | // distributed under the License is distributed on an "AS IS" BASIS, | 
 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
 | // See the License for the specific language governing permissions and | 
 | // limitations under the License. | 
 |  | 
 | #include <openssl/obj.h> | 
 |  | 
 | #include "../internal.h" | 
 |  | 
 |  | 
 | typedef struct { | 
 |   int sign_nid; | 
 |   int digest_nid; | 
 |   int pkey_nid; | 
 | } nid_triple; | 
 |  | 
 | static const nid_triple kTriples[] = { | 
 |     // RSA PKCS#1. | 
 |     {NID_md4WithRSAEncryption, NID_md4, NID_rsaEncryption}, | 
 |     {NID_md5WithRSAEncryption, NID_md5, NID_rsaEncryption}, | 
 |     {NID_sha1WithRSAEncryption, NID_sha1, NID_rsaEncryption}, | 
 |     {NID_sha224WithRSAEncryption, NID_sha224, NID_rsaEncryption}, | 
 |     {NID_sha256WithRSAEncryption, NID_sha256, NID_rsaEncryption}, | 
 |     {NID_sha384WithRSAEncryption, NID_sha384, NID_rsaEncryption}, | 
 |     {NID_sha512WithRSAEncryption, NID_sha512, NID_rsaEncryption}, | 
 |     // DSA. | 
 |     {NID_dsaWithSHA1, NID_sha1, NID_dsa}, | 
 |     {NID_dsaWithSHA1_2, NID_sha1, NID_dsa_2}, | 
 |     {NID_dsa_with_SHA224, NID_sha224, NID_dsa}, | 
 |     {NID_dsa_with_SHA256, NID_sha256, NID_dsa}, | 
 |     // ECDSA. | 
 |     {NID_ecdsa_with_SHA1, NID_sha1, NID_X9_62_id_ecPublicKey}, | 
 |     {NID_ecdsa_with_SHA224, NID_sha224, NID_X9_62_id_ecPublicKey}, | 
 |     {NID_ecdsa_with_SHA256, NID_sha256, NID_X9_62_id_ecPublicKey}, | 
 |     {NID_ecdsa_with_SHA384, NID_sha384, NID_X9_62_id_ecPublicKey}, | 
 |     {NID_ecdsa_with_SHA512, NID_sha512, NID_X9_62_id_ecPublicKey}, | 
 |     // The following algorithms use more complex (or simpler) parameters. The | 
 |     // digest "undef" indicates the caller should handle this explicitly. | 
 |     {NID_rsassaPss, NID_undef, NID_rsaEncryption}, | 
 |     {NID_ED25519, NID_undef, NID_ED25519}, | 
 | }; | 
 |  | 
 | int OBJ_find_sigid_algs(int sign_nid, int *out_digest_nid, int *out_pkey_nid) { | 
 |   for (const auto &triple : kTriples) { | 
 |     if (triple.sign_nid == sign_nid) { | 
 |       if (out_digest_nid != nullptr) { | 
 |         *out_digest_nid = triple.digest_nid; | 
 |       } | 
 |       if (out_pkey_nid != nullptr) { | 
 |         *out_pkey_nid = triple.pkey_nid; | 
 |       } | 
 |       return 1; | 
 |     } | 
 |   } | 
 |  | 
 |   return 0; | 
 | } | 
 |  | 
 | int OBJ_find_sigid_by_algs(int *out_sign_nid, int digest_nid, int pkey_nid) { | 
 |   for (const auto &triple : kTriples) { | 
 |     if (triple.digest_nid == digest_nid && | 
 |         triple.pkey_nid == pkey_nid) { | 
 |       if (out_sign_nid != nullptr) { | 
 |         *out_sign_nid = triple.sign_nid; | 
 |       } | 
 |       return 1; | 
 |     } | 
 |   } | 
 |  | 
 |   return 0; | 
 | } |