Split crypto and tls libraries into directories

I am calling the crypto library "crypt_ops", since I want
higher-level crypto things to be separated from lower-level ones.
This library will hold only the low-level ones, once we have it
refactored.
This commit is contained in:
Nick Mathewson 2018-06-21 12:46:11 -04:00
parent 49d7c9ce53
commit 25ccfff86a
41 changed files with 75 additions and 49 deletions

7
.gitignore vendored
View File

@ -141,9 +141,6 @@ uptime-*.json
/src/common/libor-ctime.a /src/common/libor-ctime.a
/src/common/libor-ctime-testing.a /src/common/libor-ctime-testing.a
/src/common/libor-ctime.lib /src/common/libor-ctime.lib
/src/common/libor-crypto.a
/src/common/libor-crypto-testing.a
/src/common/libor-crypto.lib
/src/common/libor-event.a /src/common/libor-event.a
/src/common/libor-event-testing.a /src/common/libor-event-testing.a
/src/common/libor-event.lib /src/common/libor-event.lib
@ -169,10 +166,14 @@ uptime-*.json
# /src/lib # /src/lib
/src/lib/libtor-compress.a /src/lib/libtor-compress.a
/src/lib/libtor-compress-testing.a /src/lib/libtor-compress-testing.a
/src/lib/libtor-crypt-ops.a
/src/lib/libtor-crypt-ops-testing.a
/src/lib/libtor-ctime.a /src/lib/libtor-ctime.a
/src/lib/libtor-ctime-testing.a /src/lib/libtor-ctime-testing.a
/src/lib/libtor-err.a /src/lib/libtor-err.a
/src/lib/libtor-err-testing.a /src/lib/libtor-err-testing.a
/src/lib/libtor-tls.a
/src/lib/libtor-tls-testing.a
/src/lib/libtor-trace.a /src/lib/libtor-trace.a
# /src/or/ # /src/or/

View File

@ -52,14 +52,16 @@ TOR_UTIL_TESTING_LIBS = \
# Internal crypto libraries used in Tor # Internal crypto libraries used in Tor
TOR_CRYPTO_LIBS = \ TOR_CRYPTO_LIBS = \
src/common/libor-crypto.a \ src/lib/libtor-tls.a \
src/lib/libtor-crypt-ops.a \
$(LIBKECCAK_TINY) \ $(LIBKECCAK_TINY) \
$(LIBDONNA) $(LIBDONNA)
# Variants of the above for linking the testing variant of tor (for coverage # Variants of the above for linking the testing variant of tor (for coverage
# and tests) # and tests)
TOR_CRYPTO_TESTING_LIBS = \ TOR_CRYPTO_TESTING_LIBS = \
src/common/libor-crypto-testing.a \ src/lib/libtor-tls-testing.a \
src/lib/libtor-crypt-ops-testing.a \
$(LIBKECCAK_TINY) \ $(LIBKECCAK_TINY) \
$(LIBDONNA) $(LIBDONNA)

View File

@ -1,13 +1,11 @@
noinst_LIBRARIES += \ noinst_LIBRARIES += \
src/common/libor.a \ src/common/libor.a \
src/common/libor-crypto.a \
src/common/libor-event.a src/common/libor-event.a
if UNITTESTS_ENABLED if UNITTESTS_ENABLED
noinst_LIBRARIES += \ noinst_LIBRARIES += \
src/common/libor-testing.a \ src/common/libor-testing.a \
src/common/libor-crypto-testing.a \
src/common/libor-event-testing.a src/common/libor-event-testing.a
endif endif
@ -83,24 +81,6 @@ LIBOR_A_SRC = \
src/common/src_common_libor_testing_a-log.$(OBJEXT) \ src/common/src_common_libor_testing_a-log.$(OBJEXT) \
src/common/log.$(OBJEXT): micro-revision.i src/common/log.$(OBJEXT): micro-revision.i
LIBOR_CRYPTO_A_SRC = \
src/common/aes.c \
src/common/buffers_tls.c \
src/common/crypto.c \
src/common/crypto_dh.c \
src/common/crypto_digest.c \
src/common/crypto_format.c \
src/common/crypto_hkdf.c \
src/common/crypto_openssl_mgt.c \
src/common/crypto_pwbox.c \
src/common/crypto_rand.c \
src/common/crypto_rsa.c \
src/common/crypto_s2k.c \
src/common/crypto_util.c \
src/common/tortls.c \
src/common/crypto_curve25519.c \
src/common/crypto_ed25519.c
LIBOR_EVENT_A_SRC = \ LIBOR_EVENT_A_SRC = \
src/common/compat_libevent.c \ src/common/compat_libevent.c \
src/common/procmon.c \ src/common/procmon.c \
@ -108,53 +88,31 @@ LIBOR_EVENT_A_SRC = \
src/ext/timeouts/timeout.c src/ext/timeouts/timeout.c
src_common_libor_a_SOURCES = $(LIBOR_A_SRC) src_common_libor_a_SOURCES = $(LIBOR_A_SRC)
src_common_libor_crypto_a_SOURCES = $(LIBOR_CRYPTO_A_SRC)
src_common_libor_event_a_SOURCES = $(LIBOR_EVENT_A_SRC) src_common_libor_event_a_SOURCES = $(LIBOR_EVENT_A_SRC)
if UNITTESTS_ENABLED if UNITTESTS_ENABLED
src_common_libor_testing_a_SOURCES = $(LIBOR_A_SRC) src_common_libor_testing_a_SOURCES = $(LIBOR_A_SRC)
src_common_libor_crypto_testing_a_SOURCES = $(LIBOR_CRYPTO_A_SRC)
src_common_libor_event_testing_a_SOURCES = $(LIBOR_EVENT_A_SRC) src_common_libor_event_testing_a_SOURCES = $(LIBOR_EVENT_A_SRC)
else else
src_common_libor_testing_a_SOURCES = src_common_libor_testing_a_SOURCES =
src_common_libor_crypto_testing_a_SOURCES =
src_common_libor_event_testing_a_SOURCES = src_common_libor_event_testing_a_SOURCES =
endif endif
src_common_libor_testing_a_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_CPPFLAGS) src_common_libor_testing_a_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_CPPFLAGS)
src_common_libor_crypto_testing_a_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_CPPFLAGS)
src_common_libor_event_testing_a_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_CPPFLAGS) src_common_libor_event_testing_a_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_CPPFLAGS)
src_common_libor_testing_a_CFLAGS = $(AM_CFLAGS) $(TEST_CFLAGS) src_common_libor_testing_a_CFLAGS = $(AM_CFLAGS) $(TEST_CFLAGS)
src_common_libor_crypto_testing_a_CFLAGS = $(AM_CFLAGS) $(TEST_CFLAGS)
src_common_libor_event_testing_a_CFLAGS = $(AM_CFLAGS) $(TEST_CFLAGS) src_common_libor_event_testing_a_CFLAGS = $(AM_CFLAGS) $(TEST_CFLAGS)
COMMONHEADERS = \ COMMONHEADERS = \
src/common/address.h \ src/common/address.h \
src/common/address_set.h \ src/common/address_set.h \
src/common/buffers.h \ src/common/buffers.h \
src/common/buffers_tls.h \
src/common/aes.h \
src/common/ciphers.inc \
src/common/compat.h \ src/common/compat.h \
src/common/compat_libevent.h \ src/common/compat_libevent.h \
src/common/compat_openssl.h \
src/common/compat_threads.h \ src/common/compat_threads.h \
src/common/compat_time.h \ src/common/compat_time.h \
src/common/confline.h \ src/common/confline.h \
src/common/container.h \ src/common/container.h \
src/common/crypto.h \
src/common/crypto_dh.h \
src/common/crypto_digest.h \
src/common/crypto_curve25519.h \
src/common/crypto_ed25519.h \
src/common/crypto_format.h \
src/common/crypto_hkdf.h \
src/common/crypto_openssl_mgt.h \
src/common/crypto_pwbox.h \
src/common/crypto_rand.h \
src/common/crypto_rsa.h \
src/common/crypto_s2k.h \
src/common/crypto_util.h \
src/common/handles.h \ src/common/handles.h \
src/common/memarea.h \ src/common/memarea.h \
src/common/linux_syscalls.inc \ src/common/linux_syscalls.inc \
@ -165,7 +123,6 @@ COMMONHEADERS = \
src/common/timers.h \ src/common/timers.h \
src/common/token_bucket.h \ src/common/token_bucket.h \
src/common/torlog.h \ src/common/torlog.h \
src/common/tortls.h \
src/common/util.h \ src/common/util.h \
src/common/util_bug.h \ src/common/util_bug.h \
src/common/util_format.h \ src/common/util_format.h \

View File

@ -3,6 +3,8 @@ include src/lib/err/include.am
include src/lib/cc/include.am include src/lib/cc/include.am
include src/lib/ctime/include.am include src/lib/ctime/include.am
include src/lib/compress/include.am include src/lib/compress/include.am
include src/lib/crypt_ops/include.am
include src/lib/tls/include.am
include src/lib/trace/include.am include src/lib/trace/include.am
include src/common/include.am include src/common/include.am
include src/trunnel/include.am include src/trunnel/include.am

View File

@ -0,0 +1,44 @@
noinst_LIBRARIES += src/lib/libtor-crypt-ops.a
if UNITTESTS_ENABLED
noinst_LIBRARIES += src/lib/libtor-crypt-ops-testing.a
endif
src_lib_libtor_crypt_ops_a_SOURCES = \
src/lib/crypt_ops/aes.c \
src/lib/crypt_ops/crypto.c \
src/lib/crypt_ops/crypto_curve25519.c \
src/lib/crypt_ops/crypto_dh.c \
src/lib/crypt_ops/crypto_digest.c \
src/lib/crypt_ops/crypto_ed25519.c \
src/lib/crypt_ops/crypto_format.c \
src/lib/crypt_ops/crypto_hkdf.c \
src/lib/crypt_ops/crypto_openssl_mgt.c \
src/lib/crypt_ops/crypto_pwbox.c \
src/lib/crypt_ops/crypto_rand.c \
src/lib/crypt_ops/crypto_rsa.c \
src/lib/crypt_ops/crypto_s2k.c \
src/lib/crypt_ops/crypto_util.c
src_lib_libtor_crypt_ops_testing_a_SOURCES = \
$(src_lib_libtor_crypt_ops_a_SOURCES)
src_lib_libtor_crypt_ops_testing_a_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_CPPFLAGS)
src_lib_libtor_crypt_ops_testing_a_CFLAGS = $(AM_CFLAGS) $(TEST_CFLAGS)
noinst_HEADERS += \
src/lib/crypt_ops/aes.h \
src/lib/crypt_ops/compat_openssl.h \
src/lib/crypt_ops/crypto_curve25519.h \
src/lib/crypt_ops/crypto_dh.h \
src/lib/crypt_ops/crypto_digest.h \
src/lib/crypt_ops/crypto_ed25519.h \
src/lib/crypt_ops/crypto_format.h \
src/lib/crypt_ops/crypto.h \
src/lib/crypt_ops/crypto_hkdf.h \
src/lib/crypt_ops/crypto_openssl_mgt.h \
src/lib/crypt_ops/crypto_pwbox.h \
src/lib/crypt_ops/crypto_rand.h \
src/lib/crypt_ops/crypto_rsa.h \
src/lib/crypt_ops/crypto_s2k.h \
src/lib/crypt_ops/crypto_util.h

20
src/lib/tls/include.am Normal file
View File

@ -0,0 +1,20 @@
noinst_LIBRARIES += src/lib/libtor-tls.a
if UNITTESTS_ENABLED
noinst_LIBRARIES += src/lib/libtor-tls-testing.a
endif
src_lib_libtor_tls_a_SOURCES = \
src/lib/tls/buffers_tls.c \
src/lib/tls/tortls.c
src_lib_libtor_tls_testing_a_SOURCES = \
$(src_lib_libtor_tls_a_SOURCES)
src_lib_libtor_tls_testing_a_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_CPPFLAGS)
src_lib_libtor_tls_testing_a_CFLAGS = $(AM_CFLAGS) $(TEST_CFLAGS)
noinst_HEADERS += \
src/lib/tls/ciphers.inc \
src/lib/tls/buffers_tls.h \
src/lib/tls/tortls.h

View File

@ -149,7 +149,7 @@ pub fn main() {
// will have dependencies on all the other rust packages that // will have dependencies on all the other rust packages that
// tor uses. We must be careful with factoring and dependencies // tor uses. We must be careful with factoring and dependencies
// moving forward! // moving forward!
cfg.component("or-crypto-testing"); cfg.component("tor-crypt-ops-testing");
cfg.component("or-testing"); cfg.component("or-testing");
cfg.component("tor-err-testing"); cfg.component("tor-err-testing");
cfg.component("or-event-testing"); cfg.component("or-event-testing");