| package(default_visibility = ["//:__subpackages__"]) |
| |
| licenses(["notice"]) |
| |
| cc_library( |
| name = "public_key_verify_wrapper", |
| srcs = ["public_key_verify_wrapper.cc"], |
| hdrs = ["public_key_verify_wrapper.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| "//:crypto_format", |
| "//:primitive_set", |
| "//:primitive_wrapper", |
| "//:public_key_verify", |
| "//proto:tink_cc_proto", |
| "//subtle:subtle_util_boringssl", |
| "//util:status", |
| "//util:statusor", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "public_key_verify_factory", |
| srcs = ["public_key_verify_factory.cc"], |
| hdrs = ["public_key_verify_factory.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| ":public_key_verify_wrapper", |
| "//:key_manager", |
| "//:keyset_handle", |
| "//:primitive_set", |
| "//:public_key_verify", |
| "//:registry", |
| "//util:status", |
| "//util:statusor", |
| "@com_google_absl//absl/base:core_headers", |
| ], |
| ) |
| |
| cc_library( |
| name = "public_key_sign_wrapper", |
| srcs = ["public_key_sign_wrapper.cc"], |
| hdrs = ["public_key_sign_wrapper.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| "//:crypto_format", |
| "//:primitive_set", |
| "//:primitive_wrapper", |
| "//:public_key_sign", |
| "//proto:tink_cc_proto", |
| "//subtle:subtle_util_boringssl", |
| "//util:status", |
| "//util:statusor", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "public_key_sign_factory", |
| srcs = ["public_key_sign_factory.cc"], |
| hdrs = ["public_key_sign_factory.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| ":public_key_sign_wrapper", |
| "//:key_manager", |
| "//:keyset_handle", |
| "//:primitive_set", |
| "//:public_key_sign", |
| "//:registry", |
| "//util:status", |
| "//util:statusor", |
| "@com_google_absl//absl/base:core_headers", |
| ], |
| ) |
| |
| cc_library( |
| name = "signature_key_templates", |
| srcs = ["signature_key_templates.cc"], |
| hdrs = ["signature_key_templates.h"], |
| include_prefix = "tink/signature", |
| visibility = ["//visibility:public"], |
| deps = [ |
| "//proto:common_cc_proto", |
| "//proto:ecdsa_cc_proto", |
| "//proto:ed25519_cc_proto", |
| "//proto:rsa_ssa_pkcs1_cc_proto", |
| "//proto:rsa_ssa_pss_cc_proto", |
| "//proto:tink_cc_proto", |
| "//subtle:subtle_util_boringssl", |
| "//util:constants", |
| "@boringssl//:crypto", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "ecdsa_sign_key_manager", |
| srcs = ["ecdsa_sign_key_manager.cc"], |
| hdrs = ["ecdsa_sign_key_manager.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| ":ecdsa_verify_key_manager", |
| "//:core/private_key_type_manager", |
| "//:public_key_sign", |
| "//proto:ecdsa_cc_proto", |
| "//subtle:ecdsa_sign_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:constants", |
| "//util:enums", |
| "//util:errors", |
| "//util:protobuf_helper", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "//util:validation", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "ecdsa_verify_key_manager", |
| srcs = ["ecdsa_verify_key_manager.cc"], |
| hdrs = ["ecdsa_verify_key_manager.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| "//:core/key_type_manager", |
| "//:public_key_verify", |
| "//proto:ecdsa_cc_proto", |
| "//subtle:ecdsa_verify_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:constants", |
| "//util:enums", |
| "//util:errors", |
| "//util:protobuf_helper", |
| "//util:status", |
| "//util:statusor", |
| "//util:validation", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "ed25519_sign_key_manager", |
| srcs = ["ed25519_sign_key_manager.cc"], |
| hdrs = ["ed25519_sign_key_manager.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| ":ed25519_verify_key_manager", |
| "//:core/private_key_type_manager", |
| "//:public_key_sign", |
| "//proto:ed25519_cc_proto", |
| "//subtle:ed25519_sign_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:constants", |
| "//util:enums", |
| "//util:errors", |
| "//util:protobuf_helper", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "//util:validation", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "ed25519_verify_key_manager", |
| srcs = ["ed25519_verify_key_manager.cc"], |
| hdrs = ["ed25519_verify_key_manager.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| "//:core/key_type_manager", |
| "//:public_key_verify", |
| "//proto:ed25519_cc_proto", |
| "//subtle:ed25519_verify_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:constants", |
| "//util:errors", |
| "//util:protobuf_helper", |
| "//util:status", |
| "//util:statusor", |
| "//util:validation", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "sig_util", |
| srcs = ["sig_util.cc"], |
| hdrs = ["sig_util.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//util:status", |
| ], |
| ) |
| |
| cc_library( |
| name = "rsa_ssa_pkcs1_sign_key_manager", |
| srcs = ["rsa_ssa_pkcs1_sign_key_manager.cc"], |
| hdrs = ["rsa_ssa_pkcs1_sign_key_manager.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| ":rsa_ssa_pkcs1_verify_key_manager", |
| ":sig_util", |
| "//:core/private_key_type_manager", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//proto:rsa_ssa_pkcs1_cc_proto", |
| "//subtle:rsa_ssa_pkcs1_sign_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:constants", |
| "//util:enums", |
| "//util:errors", |
| "//util:protobuf_helper", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "rsa_ssa_pkcs1_verify_key_manager", |
| srcs = ["rsa_ssa_pkcs1_verify_key_manager.cc"], |
| hdrs = ["rsa_ssa_pkcs1_verify_key_manager.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| "//:core/key_type_manager", |
| "//:public_key_verify", |
| "//proto:rsa_ssa_pkcs1_cc_proto", |
| "//subtle:rsa_ssa_pkcs1_verify_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:constants", |
| "//util:enums", |
| "//util:errors", |
| "//util:protobuf_helper", |
| "//util:status", |
| "//util:statusor", |
| "//util:validation", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "rsa_ssa_pss_sign_key_manager", |
| srcs = ["rsa_ssa_pss_sign_key_manager.cc"], |
| hdrs = ["rsa_ssa_pss_sign_key_manager.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| ":rsa_ssa_pss_verify_key_manager", |
| ":sig_util", |
| "//:core/key_type_manager", |
| "//:core/private_key_type_manager", |
| "//:public_key_sign", |
| "//:registry", |
| "//proto:common_cc_proto", |
| "//proto:rsa_ssa_pss_cc_proto", |
| "//proto:tink_cc_proto", |
| "//subtle:rsa_ssa_pss_sign_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:constants", |
| "//util:enums", |
| "//util:errors", |
| "//util:protobuf_helper", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "rsa_ssa_pss_verify_key_manager", |
| srcs = ["rsa_ssa_pss_verify_key_manager.cc"], |
| hdrs = ["rsa_ssa_pss_verify_key_manager.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| "//:core/key_type_manager", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//:registry", |
| "//proto:common_cc_proto", |
| "//proto:rsa_ssa_pss_cc_proto", |
| "//proto:tink_cc_proto", |
| "//subtle:rsa_ssa_pss_verify_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:constants", |
| "//util:enums", |
| "//util:errors", |
| "//util:protobuf_helper", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| cc_library( |
| name = "signature_config", |
| srcs = ["signature_config.cc"], |
| hdrs = ["signature_config.h"], |
| include_prefix = "tink/signature", |
| visibility = ["//visibility:public"], |
| deps = [ |
| ":ecdsa_sign_key_manager", |
| ":ecdsa_verify_key_manager", |
| ":ed25519_sign_key_manager", |
| ":ed25519_verify_key_manager", |
| ":public_key_sign_wrapper", |
| ":public_key_verify_wrapper", |
| ":rsa_ssa_pkcs1_sign_key_manager", |
| ":rsa_ssa_pkcs1_verify_key_manager", |
| ":rsa_ssa_pss_sign_key_manager", |
| ":rsa_ssa_pss_verify_key_manager", |
| "//:registry", |
| "//config:config_util", |
| "//config:tink_fips", |
| "//proto:config_cc_proto", |
| "//util:status", |
| "@com_google_absl//absl/base:core_headers", |
| "@com_google_absl//absl/memory", |
| ], |
| ) |
| |
| cc_library( |
| name = "signature_pem_keyset_reader", |
| srcs = ["signature_pem_keyset_reader.cc"], |
| hdrs = ["signature_pem_keyset_reader.h"], |
| include_prefix = "tink/signature", |
| deps = [ |
| ":rsa_ssa_pkcs1_sign_key_manager", |
| ":rsa_ssa_pkcs1_verify_key_manager", |
| ":rsa_ssa_pss_sign_key_manager", |
| ":rsa_ssa_pss_verify_key_manager", |
| "//:keyset_reader", |
| "//proto:common_cc_proto", |
| "//proto:rsa_ssa_pkcs1_cc_proto", |
| "//proto:rsa_ssa_pss_cc_proto", |
| "//proto:tink_cc_proto", |
| "//subtle:pem_parser_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:enums", |
| "//util:keyset_util", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| ], |
| ) |
| |
| # tests |
| |
| cc_test( |
| name = "public_key_verify_wrapper_test", |
| size = "small", |
| srcs = ["public_key_verify_wrapper_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":public_key_verify_wrapper", |
| "//:primitive_set", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//proto:tink_cc_proto", |
| "//util:status", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "public_key_verify_factory_test", |
| size = "small", |
| srcs = ["public_key_verify_factory_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":ecdsa_verify_key_manager", |
| ":public_key_verify_factory", |
| ":signature_config", |
| "//:config", |
| "//:keyset_handle", |
| "//:public_key_verify", |
| "//:registry", |
| "//proto:ecdsa_cc_proto", |
| "//proto:tink_cc_proto", |
| "//util:status", |
| "//util:test_keyset_handle", |
| "//util:test_util", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "public_key_sign_wrapper_test", |
| size = "small", |
| srcs = ["public_key_sign_wrapper_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":public_key_sign_wrapper", |
| "//:crypto_format", |
| "//:primitive_set", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//proto:tink_cc_proto", |
| "//util:status", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "public_key_sign_factory_test", |
| size = "small", |
| srcs = ["public_key_sign_factory_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":ecdsa_sign_key_manager", |
| ":public_key_sign_factory", |
| ":signature_config", |
| "//:config", |
| "//:keyset_handle", |
| "//:public_key_sign", |
| "//:registry", |
| "//proto:ecdsa_cc_proto", |
| "//proto:tink_cc_proto", |
| "//util:status", |
| "//util:test_keyset_handle", |
| "//util:test_util", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "ecdsa_verify_key_manager_test", |
| size = "small", |
| srcs = ["ecdsa_verify_key_manager_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":ecdsa_sign_key_manager", |
| ":ecdsa_verify_key_manager", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//:registry", |
| "//proto:aes_eax_cc_proto", |
| "//proto:common_cc_proto", |
| "//proto:ecdsa_cc_proto", |
| "//proto:tink_cc_proto", |
| "//subtle:ecdsa_sign_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:enums", |
| "//util:secret_data", |
| "//util:status", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "ed25519_verify_key_manager_test", |
| size = "small", |
| srcs = ["ed25519_verify_key_manager_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":ed25519_sign_key_manager", |
| ":ed25519_verify_key_manager", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//:registry", |
| "//proto:ed25519_cc_proto", |
| "//subtle:ed25519_sign_boringssl", |
| "//util:enums", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "rsa_ssa_pkcs1_verify_key_manager_test", |
| size = "small", |
| srcs = ["rsa_ssa_pkcs1_verify_key_manager_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":rsa_ssa_pkcs1_sign_key_manager", |
| ":rsa_ssa_pkcs1_verify_key_manager", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//proto:rsa_ssa_pkcs1_cc_proto", |
| "//proto:tink_cc_proto", |
| "//subtle:rsa_ssa_pkcs1_sign_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@boringssl//:crypto", |
| "@com_google_absl//absl/strings", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "rsa_ssa_pss_verify_key_manager_test", |
| size = "small", |
| srcs = ["rsa_ssa_pss_verify_key_manager_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":rsa_ssa_pss_sign_key_manager", |
| ":rsa_ssa_pss_verify_key_manager", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//proto:rsa_ssa_pss_cc_proto", |
| "//subtle:rsa_ssa_pss_sign_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@boringssl//:crypto", |
| "@com_google_absl//absl/strings", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "ecdsa_sign_key_manager_test", |
| size = "small", |
| srcs = ["ecdsa_sign_key_manager_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":ecdsa_sign_key_manager", |
| ":ecdsa_verify_key_manager", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//proto:ecdsa_cc_proto", |
| "//util:enums", |
| "//util:status", |
| "//util:statusor", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "ed25519_sign_key_manager_test", |
| size = "small", |
| srcs = ["ed25519_sign_key_manager_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":ed25519_sign_key_manager", |
| ":ed25519_verify_key_manager", |
| "//:public_key_sign", |
| "//:registry", |
| "//proto:ed25519_cc_proto", |
| "//subtle:ed25519_verify_boringssl", |
| "//util:enums", |
| "//util:protobuf_helper", |
| "//util:status", |
| "//util:statusor", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@com_google_absl//absl/container:flat_hash_set", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "rsa_ssa_pkcs1_sign_key_manager_test", |
| size = "small", |
| srcs = ["rsa_ssa_pkcs1_sign_key_manager_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":rsa_ssa_pkcs1_sign_key_manager", |
| ":rsa_ssa_pkcs1_verify_key_manager", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//proto:rsa_ssa_pkcs1_cc_proto", |
| "//proto:tink_cc_proto", |
| "//subtle:rsa_ssa_pkcs1_verify_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@boringssl//:crypto", |
| "@com_google_absl//absl/container:flat_hash_set", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "rsa_ssa_pss_sign_key_manager_test", |
| size = "small", |
| srcs = ["rsa_ssa_pss_sign_key_manager_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":rsa_ssa_pss_sign_key_manager", |
| ":rsa_ssa_pss_verify_key_manager", |
| ":signature_key_templates", |
| "//:public_key_sign", |
| "//:registry", |
| "//proto:rsa_ssa_pss_cc_proto", |
| "//subtle:rsa_ssa_pss_verify_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:secret_data", |
| "//util:status", |
| "//util:statusor", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@boringssl//:crypto", |
| "@com_google_absl//absl/container:flat_hash_set", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "signature_config_test", |
| size = "small", |
| srcs = ["signature_config_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":rsa_ssa_pss_sign_key_manager", |
| ":rsa_ssa_pss_verify_key_manager", |
| ":signature_config", |
| ":signature_key_templates", |
| "//:config", |
| "//:keyset_handle", |
| "//:public_key_sign", |
| "//:public_key_verify", |
| "//:registry", |
| "//config:tink_fips", |
| "//util:status", |
| "//util:test_matchers", |
| "//util:test_util", |
| "@com_google_absl//absl/memory", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "signature_key_templates_test", |
| size = "small", |
| srcs = ["signature_key_templates_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":ecdsa_sign_key_manager", |
| ":ed25519_sign_key_manager", |
| ":ed25519_verify_key_manager", |
| ":rsa_ssa_pkcs1_sign_key_manager", |
| ":rsa_ssa_pss_sign_key_manager", |
| ":signature_key_templates", |
| "//proto:common_cc_proto", |
| "//proto:ecdsa_cc_proto", |
| "//proto:ed25519_cc_proto", |
| "//proto:empty_cc_proto", |
| "//proto:rsa_ssa_pkcs1_cc_proto", |
| "//proto:rsa_ssa_pss_cc_proto", |
| "//proto:tink_cc_proto", |
| "//subtle:subtle_util_boringssl", |
| "@boringssl//:crypto", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |
| |
| cc_test( |
| name = "signature_pem_keyset_reader_test", |
| size = "small", |
| srcs = ["signature_pem_keyset_reader_test.cc"], |
| copts = ["-Iexternal/gtest/include"], |
| deps = [ |
| ":signature_config", |
| ":signature_pem_keyset_reader", |
| "//:keyset_handle", |
| "//:keyset_reader", |
| "//proto:common_cc_proto", |
| "//proto:rsa_ssa_pss_cc_proto", |
| "//proto:tink_cc_proto", |
| "//subtle:pem_parser_boringssl", |
| "//subtle:subtle_util_boringssl", |
| "//util:enums", |
| "//util:keyset_util", |
| "//util:secret_data", |
| "//util:status", |
| "//util:test_matchers", |
| "@com_google_absl//absl/memory", |
| "@com_google_absl//absl/strings", |
| "@com_google_googletest//:gtest_main", |
| ], |
| ) |