mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-24 20:33:31 +01:00
Extract nickname-checking functions from router.c
This commit is contained in:
parent
5c86f3c297
commit
efa978124f
@ -93,6 +93,7 @@ LIBTOR_APP_A_SOURCES = \
|
||||
src/feature/nodelist/dirlist.c \
|
||||
src/feature/nodelist/microdesc.c \
|
||||
src/feature/nodelist/networkstatus.c \
|
||||
src/feature/nodelist/nickname.c \
|
||||
src/feature/nodelist/nodelist.c \
|
||||
src/feature/nodelist/node_select.c \
|
||||
src/feature/nodelist/parsecommon.c \
|
||||
@ -309,6 +310,7 @@ noinst_HEADERS += \
|
||||
src/feature/nodelist/networkstatus_sr_info_st.h \
|
||||
src/feature/nodelist/networkstatus_st.h \
|
||||
src/feature/nodelist/networkstatus_voter_info_st.h \
|
||||
src/feature/nodelist/nickname.h \
|
||||
src/feature/nodelist/node_st.h \
|
||||
src/feature/nodelist/nodelist.h \
|
||||
src/feature/nodelist/node_select.h \
|
||||
|
@ -4,6 +4,11 @@
|
||||
* Copyright (c) 2007-2018, The Tor Project, Inc. */
|
||||
/* See LICENSE for licensing information */
|
||||
|
||||
/**
|
||||
* \file describe.c
|
||||
* \brief Format short descriptions of relays.
|
||||
*/
|
||||
|
||||
#include "core/or/or.h"
|
||||
#include "feature/nodelist/describe.h"
|
||||
#include "feature/relay/router.h"
|
||||
|
62
src/feature/nodelist/nickname.c
Normal file
62
src/feature/nodelist/nickname.c
Normal file
@ -0,0 +1,62 @@
|
||||
/* Copyright (c) 2001 Matej Pfajfar.
|
||||
* Copyright (c) 2001-2004, Roger Dingledine.
|
||||
* Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
|
||||
* Copyright (c) 2007-2018, The Tor Project, Inc. */
|
||||
/* See LICENSE for licensing information */
|
||||
|
||||
/**
|
||||
* \file nickname.c
|
||||
* \brief Check and manipulate relay nicknames.
|
||||
*/
|
||||
|
||||
#include "core/or/or.h"
|
||||
#include "feature/nodelist/nickname.h"
|
||||
|
||||
/** Return true iff <b>s</b> is a valid server nickname. (That is, a string
|
||||
* containing between 1 and MAX_NICKNAME_LEN characters from
|
||||
* LEGAL_NICKNAME_CHARACTERS.) */
|
||||
int
|
||||
is_legal_nickname(const char *s)
|
||||
{
|
||||
size_t len;
|
||||
tor_assert(s);
|
||||
len = strlen(s);
|
||||
return len > 0 && len <= MAX_NICKNAME_LEN &&
|
||||
strspn(s,LEGAL_NICKNAME_CHARACTERS) == len;
|
||||
}
|
||||
|
||||
/** Return true iff <b>s</b> is a valid server nickname or
|
||||
* hex-encoded identity-key digest. */
|
||||
int
|
||||
is_legal_nickname_or_hexdigest(const char *s)
|
||||
{
|
||||
if (*s!='$')
|
||||
return is_legal_nickname(s);
|
||||
else
|
||||
return is_legal_hexdigest(s);
|
||||
}
|
||||
|
||||
/** Return true iff <b>s</b> is a valid hex-encoded identity-key
|
||||
* digest. (That is, an optional $, followed by 40 hex characters,
|
||||
* followed by either nothing, or = or ~ followed by a nickname, or
|
||||
* a character other than =, ~, or a hex character.)
|
||||
*/
|
||||
int
|
||||
is_legal_hexdigest(const char *s)
|
||||
{
|
||||
size_t len;
|
||||
tor_assert(s);
|
||||
if (s[0] == '$') s++;
|
||||
len = strlen(s);
|
||||
if (len > HEX_DIGEST_LEN) {
|
||||
if (s[HEX_DIGEST_LEN] == '=' ||
|
||||
s[HEX_DIGEST_LEN] == '~') {
|
||||
if (!is_legal_nickname(s+HEX_DIGEST_LEN+1))
|
||||
return 0;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
return (len >= HEX_DIGEST_LEN &&
|
||||
strspn(s,HEX_CHARACTERS)==HEX_DIGEST_LEN);
|
||||
}
|
19
src/feature/nodelist/nickname.h
Normal file
19
src/feature/nodelist/nickname.h
Normal file
@ -0,0 +1,19 @@
|
||||
/* Copyright (c) 2001 Matej Pfajfar.
|
||||
* Copyright (c) 2001-2004, Roger Dingledine.
|
||||
* Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
|
||||
* Copyright (c) 2007-2018, The Tor Project, Inc. */
|
||||
/* See LICENSE for licensing information */
|
||||
|
||||
/**
|
||||
* \file nickname.h
|
||||
* \brief Header file for nickname.c.
|
||||
**/
|
||||
|
||||
#ifndef TOR_NICKNAME_H
|
||||
#define TOR_NICKNAME_H
|
||||
|
||||
int is_legal_nickname(const char *s);
|
||||
int is_legal_nickname_or_hexdigest(const char *s);
|
||||
int is_legal_hexdigest(const char *s);
|
||||
|
||||
#endif
|
@ -3104,55 +3104,6 @@ extrainfo_dump_to_string(char **s_out, extrainfo_t *extrainfo,
|
||||
return result;
|
||||
}
|
||||
|
||||
/** Return true iff <b>s</b> is a valid server nickname. (That is, a string
|
||||
* containing between 1 and MAX_NICKNAME_LEN characters from
|
||||
* LEGAL_NICKNAME_CHARACTERS.) */
|
||||
int
|
||||
is_legal_nickname(const char *s)
|
||||
{
|
||||
size_t len;
|
||||
tor_assert(s);
|
||||
len = strlen(s);
|
||||
return len > 0 && len <= MAX_NICKNAME_LEN &&
|
||||
strspn(s,LEGAL_NICKNAME_CHARACTERS) == len;
|
||||
}
|
||||
|
||||
/** Return true iff <b>s</b> is a valid server nickname or
|
||||
* hex-encoded identity-key digest. */
|
||||
int
|
||||
is_legal_nickname_or_hexdigest(const char *s)
|
||||
{
|
||||
if (*s!='$')
|
||||
return is_legal_nickname(s);
|
||||
else
|
||||
return is_legal_hexdigest(s);
|
||||
}
|
||||
|
||||
/** Return true iff <b>s</b> is a valid hex-encoded identity-key
|
||||
* digest. (That is, an optional $, followed by 40 hex characters,
|
||||
* followed by either nothing, or = or ~ followed by a nickname, or
|
||||
* a character other than =, ~, or a hex character.)
|
||||
*/
|
||||
int
|
||||
is_legal_hexdigest(const char *s)
|
||||
{
|
||||
size_t len;
|
||||
tor_assert(s);
|
||||
if (s[0] == '$') s++;
|
||||
len = strlen(s);
|
||||
if (len > HEX_DIGEST_LEN) {
|
||||
if (s[HEX_DIGEST_LEN] == '=' ||
|
||||
s[HEX_DIGEST_LEN] == '~') {
|
||||
if (!is_legal_nickname(s+HEX_DIGEST_LEN+1))
|
||||
return 0;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
return (len >= HEX_DIGEST_LEN &&
|
||||
strspn(s,HEX_CHARACTERS)==HEX_DIGEST_LEN);
|
||||
}
|
||||
|
||||
/** Forget that we have issued any router-related warnings, so that we'll
|
||||
* warn again if we see the same errors. */
|
||||
void
|
||||
|
@ -14,6 +14,7 @@
|
||||
|
||||
#include "lib/testsupport/testsupport.h"
|
||||
#include "feature/nodelist/describe.h"
|
||||
#include "feature/nodelist/nickname.h"
|
||||
|
||||
struct curve25519_keypair_t;
|
||||
struct ed25519_keypair_t;
|
||||
@ -119,9 +120,6 @@ int router_has_orport(const routerinfo_t *router,
|
||||
int extrainfo_dump_to_string(char **s, extrainfo_t *extrainfo,
|
||||
crypto_pk_t *ident_key,
|
||||
const struct ed25519_keypair_t *signing_keypair);
|
||||
int is_legal_nickname(const char *s);
|
||||
int is_legal_nickname_or_hexdigest(const char *s);
|
||||
int is_legal_hexdigest(const char *s);
|
||||
|
||||
const char *routerinfo_err_to_string(int err);
|
||||
int routerinfo_err_is_transient(int err);
|
||||
|
Loading…
Reference in New Issue
Block a user