v3_attrmap.c 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. /*
  2. * Copyright 2024 The OpenSSL Project Authors. All Rights Reserved.
  3. *
  4. * Licensed under the Apache License 2.0 (the "License"). You may not use
  5. * this file except in compliance with the License. You can obtain a copy
  6. * in the file LICENSE in the source distribution or at
  7. * https://www.openssl.org/source/license.html
  8. */
  9. #include <openssl/asn1t.h>
  10. #include <openssl/x509v3.h>
  11. #include <crypto/x509.h>
  12. #include "ext_dat.h"
  13. ASN1_SEQUENCE(OSSL_ATAV) = {
  14. ASN1_SIMPLE(OSSL_ATAV, type, ASN1_OBJECT),
  15. ASN1_SIMPLE(OSSL_ATAV, value, ASN1_ANY)
  16. } ASN1_SEQUENCE_END(OSSL_ATAV)
  17. ASN1_SEQUENCE(OSSL_ATTRIBUTE_TYPE_MAPPING) = {
  18. ASN1_IMP(OSSL_ATTRIBUTE_TYPE_MAPPING, local, ASN1_OBJECT, 0),
  19. ASN1_IMP(OSSL_ATTRIBUTE_TYPE_MAPPING, remote, ASN1_OBJECT, 1),
  20. } ASN1_SEQUENCE_END(OSSL_ATTRIBUTE_TYPE_MAPPING)
  21. ASN1_SEQUENCE(OSSL_ATTRIBUTE_VALUE_MAPPING) = {
  22. ASN1_IMP(OSSL_ATTRIBUTE_VALUE_MAPPING, local, OSSL_ATAV, 0),
  23. ASN1_IMP(OSSL_ATTRIBUTE_VALUE_MAPPING, remote, OSSL_ATAV, 1),
  24. } ASN1_SEQUENCE_END(OSSL_ATTRIBUTE_VALUE_MAPPING)
  25. ASN1_CHOICE(OSSL_ATTRIBUTE_MAPPING) = {
  26. ASN1_IMP(OSSL_ATTRIBUTE_MAPPING, choice.typeMappings,
  27. OSSL_ATTRIBUTE_TYPE_MAPPING, OSSL_ATTR_MAP_TYPE),
  28. ASN1_IMP(OSSL_ATTRIBUTE_MAPPING, choice.typeValueMappings,
  29. OSSL_ATTRIBUTE_VALUE_MAPPING, OSSL_ATTR_MAP_VALUE),
  30. } ASN1_CHOICE_END(OSSL_ATTRIBUTE_MAPPING)
  31. ASN1_ITEM_TEMPLATE(OSSL_ATTRIBUTE_MAPPINGS) =
  32. ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SET_OF, 0, OSSL_ATTRIBUTE_MAPPINGS, OSSL_ATTRIBUTE_MAPPING)
  33. ASN1_ITEM_TEMPLATE_END(OSSL_ATTRIBUTE_MAPPINGS)
  34. IMPLEMENT_ASN1_FUNCTIONS(OSSL_ATAV)
  35. IMPLEMENT_ASN1_FUNCTIONS(OSSL_ATTRIBUTE_TYPE_MAPPING)
  36. IMPLEMENT_ASN1_FUNCTIONS(OSSL_ATTRIBUTE_VALUE_MAPPING)
  37. IMPLEMENT_ASN1_FUNCTIONS(OSSL_ATTRIBUTE_MAPPING)
  38. IMPLEMENT_ASN1_FUNCTIONS(OSSL_ATTRIBUTE_MAPPINGS)
  39. static int i2r_ATTRIBUTE_MAPPING(X509V3_EXT_METHOD *method,
  40. OSSL_ATTRIBUTE_MAPPING *am,
  41. BIO *out, int indent)
  42. {
  43. ASN1_OBJECT *local_type, *remote_type;
  44. int local_attr_nid, remote_attr_nid;
  45. ASN1_TYPE *local_val, *remote_val;
  46. switch (am->type) {
  47. case (OSSL_ATTR_MAP_TYPE):
  48. if (i2a_ASN1_OBJECT(out, am->choice.typeMappings->local) <= 0)
  49. return 0;
  50. if (BIO_puts(out, " == ") <= 0)
  51. return 0;
  52. return i2a_ASN1_OBJECT(out, am->choice.typeMappings->remote);
  53. case (OSSL_ATTR_MAP_VALUE):
  54. local_type = am->choice.typeValueMappings->local->type;
  55. remote_type = am->choice.typeValueMappings->remote->type;
  56. local_val = am->choice.typeValueMappings->local->value;
  57. remote_val = am->choice.typeValueMappings->remote->value;
  58. local_attr_nid = OBJ_obj2nid(local_type);
  59. remote_attr_nid = OBJ_obj2nid(remote_type);
  60. if (i2a_ASN1_OBJECT(out, local_type) <= 0)
  61. return 0;
  62. if (BIO_puts(out, ":") <= 0)
  63. return 0;
  64. if (ossl_print_attribute_value(out, local_attr_nid, local_val, 0) <= 0)
  65. return 0;
  66. if (BIO_puts(out, " == ") <= 0)
  67. return 0;
  68. if (i2a_ASN1_OBJECT(out, remote_type) <= 0)
  69. return 0;
  70. if (BIO_puts(out, ":") <= 0)
  71. return 0;
  72. return ossl_print_attribute_value(out, remote_attr_nid, remote_val, 0);
  73. default:
  74. return 0;
  75. }
  76. return 1;
  77. }
  78. static int i2r_ATTRIBUTE_MAPPINGS(X509V3_EXT_METHOD *method,
  79. OSSL_ATTRIBUTE_MAPPINGS *ams,
  80. BIO *out, int indent)
  81. {
  82. int i;
  83. OSSL_ATTRIBUTE_MAPPING *am;
  84. for (i = 0; i < sk_OSSL_ATTRIBUTE_MAPPING_num(ams); i++) {
  85. am = sk_OSSL_ATTRIBUTE_MAPPING_value(ams, i);
  86. if (BIO_printf(out, "%*s", indent, "") <= 0)
  87. return 0;
  88. if (i2r_ATTRIBUTE_MAPPING(method, am, out, indent + 4) <= 0)
  89. return 0;
  90. if (BIO_puts(out, "\n") <= 0)
  91. return 0;
  92. }
  93. return 1;
  94. }
  95. const X509V3_EXT_METHOD ossl_v3_attribute_mappings = {
  96. NID_attribute_mappings, X509V3_EXT_MULTILINE,
  97. ASN1_ITEM_ref(OSSL_ATTRIBUTE_MAPPINGS),
  98. 0, 0, 0, 0,
  99. 0, 0,
  100. 0,
  101. 0,
  102. (X509V3_EXT_I2R)i2r_ATTRIBUTE_MAPPINGS,
  103. 0,
  104. NULL
  105. };