summaryrefslogtreecommitdiff
path: root/src/feature/relay/transport_config.h
diff options
context:
space:
mode:
authorteor <teor@torproject.org>2019-10-31 11:49:17 +1000
committerteor <teor@torproject.org>2019-11-04 13:10:01 +1000
commit2dfd18018f7ae087c176dca973b1e8c7eea1b8c9 (patch)
tree9c8d14fe8f212394858f38f19aae13f42b326493 /src/feature/relay/transport_config.h
parent4d9a5c77f8f7a3e2ba9abf92e359e39ee114e350 (diff)
downloadtor-2dfd18018f7ae087c176dca973b1e8c7eea1b8c9.tar.gz
tor-2dfd18018f7ae087c176dca973b1e8c7eea1b8c9.zip
relay: Disable server transport options when the module is disabled
This commit: * disables the ExtORPort, ServerTransportPlugin, ServerTransportListenAddress, and ServerTransportOptions options, when the relay module is disabled. Part of 32213.
Diffstat (limited to 'src/feature/relay/transport_config.h')
-rw-r--r--src/feature/relay/transport_config.h36
1 files changed, 33 insertions, 3 deletions
diff --git a/src/feature/relay/transport_config.h b/src/feature/relay/transport_config.h
index c23eee03c3..799c51c984 100644
--- a/src/feature/relay/transport_config.h
+++ b/src/feature/relay/transport_config.h
@@ -19,13 +19,13 @@
typedef struct or_options_t or_options_t;
typedef struct smartlist_t smartlist_t;
-char *get_transport_bindaddr_from_config(const char *transport);
-smartlist_t *get_options_for_server_transport(const char *transport);
-
int options_validate_server_transport(const or_options_t *old_options,
or_options_t *options,
char **msg);
+char *get_transport_bindaddr_from_config(const char *transport);
+smartlist_t *get_options_for_server_transport(const char *transport);
+
int options_act_server_transport(const or_options_t *old_options);
#ifdef RELAY_TRANSPORT_CONFIG_PRIVATE
@@ -38,6 +38,36 @@ STATIC smartlist_t *get_options_from_transport_options_line(
#else
+/** When tor is compiled with the relay module disabled, it can't be
+ * configured with server pluggable transports.
+ *
+ * Returns -1 and sets msg to a newly allocated string, if ExtORPort,
+ * ServerTransportPlugin, ServerTransportListenAddr, or
+ * ServerTransportOptions are set in options. Otherwise returns 0. */
+static inline int
+options_validate_server_transport(const or_options_t *old_options,
+ or_options_t *options,
+ char **msg)
+{
+ (void)old_options;
+
+ /* These ExtORPort checks are too strict, and will reject valid configs
+ * that disable ports, like "ExtORPort 0". */
+ if (options->ServerTransportPlugin ||
+ options->ServerTransportListenAddr ||
+ options->ServerTransportOptions ||
+ options->ExtORPort_lines) {
+ /* REJECT() this configuration */
+ *msg = tor_strdup("This tor was built with relay mode disabled. "
+ "It can not be configured with an ExtORPort, "
+ "a ServerTransportPlugin, a ServerTransportListenAddr, "
+ "or ServerTransportOptions.");
+ return -1;
+ }
+
+ return 0;
+}
+
#define get_transport_bindaddr_from_config(transport) \
(((void)(transport)),NULL)