mirror of
https://github.com/clearml/dropbear
synced 2025-01-31 10:57:01 +00:00
3ee685ad1c
For the sake of review, this commit alters only the code; the affiliated
comments within the source files also need to be updated, but doing so
now would obscure the operational changes that have been made here.
* All on/off options have been switched to the numeric `#if' variant;
that is the only way to make this `default_options.h.in' thing work
in a reasonable manner.
* There is now some very minor compile-time checking of the user's
choice of options.
* NO_FAST_EXPTMOD doesn't seem to be used, so it has been removed.
* ENABLE_USER_ALGO_LIST was supposed to be renamed DROPBEAR_USER_ALGO_LIST,
and this commit completes that work.
* DROPBEAR_FUZZ seems to be a relatively new, as-yet undocumented option,
which was added by the following commit:
commit 6e0b539e9c
Author: Matt Johnston <matt@ucc.asn.au>
Date: Tue May 23 22:29:21 2017 +0800
split out checkpubkey_line() separately
It has now been added to `sysoptions.h' and defined as `0' by default.
* The configuration option `DROPBEAR_PASSWORD_ENV' is no longer listed in
`default_options.h.in'; it is no longer meant to be set by the user, and
is instead left to be defined in `sysoptions.h' (where it was already being
defined) as merely the name of the environment variable in question:
DROPBEAR_PASSWORD
To enable or disable use of that environment variable, the user must now
toggle `DROPBEAR_USE_DROPBEAR_PASSWORD'.
* The sFTP support is now toggled by setting `DROPBEAR_SFTPSERVER', and the
path of the sFTP server program is set independently through the usual
SFTPSERVER_PATH.
95 lines
3.4 KiB
C
95 lines
3.4 KiB
C
/*
|
|
* Dropbear - a SSH2 server
|
|
*
|
|
* Copyright (c) 2002,2003 Matt Johnston
|
|
* All rights reserved.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
* SOFTWARE. */
|
|
|
|
#ifndef DROPBEAR_DBUTIL_H_
|
|
|
|
#define DROPBEAR_DBUTIL_H_
|
|
|
|
#include "includes.h"
|
|
#include "buffer.h"
|
|
#include "queue.h"
|
|
#include "dbhelpers.h"
|
|
|
|
#ifndef DISABLE_SYSLOG
|
|
void startsyslog(const char *ident);
|
|
#endif
|
|
|
|
extern void (*_dropbear_exit)(int exitcode, const char* format, va_list param) ATTRIB_NORETURN;
|
|
extern void (*_dropbear_log)(int priority, const char* format, va_list param);
|
|
|
|
void dropbear_exit(const char* format, ...) ATTRIB_PRINTF(1,2) ATTRIB_NORETURN;
|
|
|
|
void dropbear_close(const char* format, ...) ATTRIB_PRINTF(1,2) ;
|
|
void dropbear_log(int priority, const char* format, ...) ATTRIB_PRINTF(2,3) ;
|
|
|
|
void fail_assert(const char* expr, const char* file, int line) ATTRIB_NORETURN;
|
|
|
|
#if DEBUG_TRACE
|
|
void dropbear_trace(const char* format, ...) ATTRIB_PRINTF(1,2);
|
|
void dropbear_trace2(const char* format, ...) ATTRIB_PRINTF(1,2);
|
|
void printhex(const char * label, const unsigned char * buf, int len);
|
|
void printmpint(const char *label, mp_int *mp);
|
|
void debug_start_net(void);
|
|
extern int debug_trace;
|
|
#endif
|
|
|
|
char * stripcontrol(const char * text);
|
|
|
|
int spawn_command(void(*exec_fn)(const void *user_data), const void *exec_data,
|
|
int *writefd, int *readfd, int *errfd, pid_t *pid);
|
|
void run_shell_command(const char* cmd, unsigned int maxfd, char* usershell);
|
|
#if ENABLE_CONNECT_UNIX
|
|
int connect_unix(const char* addr);
|
|
#endif
|
|
int buf_readfile(buffer* buf, const char* filename);
|
|
int buf_getline(buffer * line, FILE * authfile);
|
|
|
|
void m_close(int fd);
|
|
void * m_malloc(size_t size);
|
|
void * m_strdup(const char * str);
|
|
void * m_realloc(void* ptr, size_t size);
|
|
#define m_free(X) do {free(X); (X) = NULL;} while (0)
|
|
void setnonblocking(int fd);
|
|
void disallow_core(void);
|
|
int m_str_to_uint(const char* str, unsigned int *val);
|
|
|
|
/* Used to force mp_ints to be initialised */
|
|
#define DEF_MP_INT(X) mp_int X = {0, 0, 0, NULL}
|
|
|
|
/* Dropbear assertion */
|
|
#define dropbear_assert(X) do { if (!(X)) { fail_assert(#X, __FILE__, __LINE__); } } while (0)
|
|
|
|
/* Returns 0 if a and b have the same contents */
|
|
int constant_time_memcmp(const void* a, const void *b, size_t n);
|
|
|
|
/* Returns a time in seconds that doesn't go backwards - does not correspond to
|
|
a real-world clock */
|
|
time_t monotonic_now(void);
|
|
|
|
char * expand_homedir_path(const char *inpath);
|
|
|
|
void fsync_parent_dir(const char* fn);
|
|
|
|
#endif /* DROPBEAR_DBUTIL_H_ */
|