/* * Copyright 2014-2015 Con Kolivas * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation; either version 3 of the License, or (at your option) * any later version. See COPYING for more details. */ #ifndef CKPOOL_H #define CKPOOL_H #include "config.h" #include #include #include #include "libckpool.h" #include "uthash.h" struct ckpool_instance; typedef struct ckpool_instance ckpool_t; struct ckmsg { struct ckmsg *next; struct ckmsg *prev; void *data; }; typedef struct ckmsg ckmsg_t; struct ckmsgq { ckpool_t *ckp; char name[16]; pthread_t pth; pthread_mutex_t *lock; pthread_cond_t *cond; ckmsg_t *msgs; void (*func)(ckpool_t *, void *); int64_t messages; }; typedef struct ckmsgq ckmsgq_t; struct proc_instance { ckpool_t *ckp; unixsock_t us; char *processname; char *sockname; int pid; int oldpid; int (*process)(proc_instance_t *); }; struct connsock { int fd; char *url; char *port; char *auth; char *buf; int bufofs; int buflen; }; typedef struct connsock connsock_t; struct server_instance { /* Hash table data */ UT_hash_handle hh; int id; char *url; char *auth; char *pass; bool notify; connsock_t cs; void *data; // Private data }; typedef struct server_instance server_instance_t; struct ckpool_instance { /* The initial command line arguments */ char **initial_args; /* Number of arguments */ int args; /* Filename of config file */ char *config; /* Kill old instance with same name */ bool killold; /* Whether to log shares or not */ bool logshares; /* Logging level */ int loglevel; /* Main process name */ char *name; /* Directory where sockets are created */ char *socket_dir; /* Directory where ckdb sockets are */ char *ckdb_sockdir; /* Name of the ckdb process */ char *ckdb_name; char *ckdb_sockname; /* Group ID for unix sockets */ char *grpnam; gid_t gr_gid; /* Directory where logs are written */ char *logdir; /* Logfile */ FILE *logfp; int logfd; /* Connector fds if we inherit them from a running process */ int *oldconnfd; /* Should we inherit a running instance's socket and shut it down */ bool handover; /* How many clients maximum to accept before rejecting further */ int maxclients; /* Logger message queue NOTE: Unique per process */ ckmsgq_t *logger; /* Process instance data of parent/child processes */ proc_instance_t main; int proc_instances; proc_instance_t **children; proc_instance_t *generator; proc_instance_t *stratifier; proc_instance_t *connector; /* Threads of main process */ pthread_t pth_listener; pthread_t pth_watchdog; /* Are we running in passthrough mode */ bool passthrough; /* Are we running as a proxy */ bool proxy; /* Do we prefer more proxy clients over support for >5TH clients */ bool clientsvspeed; /* Are we running without ckdb */ bool standalone; /* Should we daemonise the ckpool process */ bool daemon; /* Bitcoind data */ int btcds; char **btcdurl; char **btcdauth; char **btcdpass; bool *btcdnotify; int blockpoll; // How frequently in ms to poll bitcoind for block updates int nonce1length; // Extranonce1 length int nonce2length; // Extranonce2 length /* Difficulty settings */ int64_t mindiff; // Default 1 int64_t startdiff; // Default 42 int64_t maxdiff; // No default /* Coinbase data */ char *btcaddress; // Address to mine to char *btcsig; // Optional signature to add to coinbase char *donaddress; // Donation address bool donvalid; // Donation address works on this network /* Stratum options */ server_instance_t **servers; char **serverurl; // Array of URLs to bind our server/proxy to int serverurls; // Number of server bindings int update_interval; // Seconds between stratum updates int chosen_server; // Chosen server for next connection /* Proxy options */ int proxies; char **proxyurl; char **proxyauth; char **proxypass; /* Private data for each process */ void *data; }; #ifdef USE_CKDB #define CKP_STANDALONE(CKP) ((CKP)->standalone == true) #else #define CKP_STANDALONE(CKP) ((CKP) == (CKP)) /* Always true, silences unused warn */ #endif #define SAFE_HASH_OVERHEAD(HASHLIST) (HASHLIST ? HASH_OVERHEAD(hh, HASHLIST) : 0) ckmsgq_t *create_ckmsgq(ckpool_t *ckp, const char *name, const void *func); ckmsgq_t *create_ckmsgqs(ckpool_t *ckp, const char *name, const void *func, const int count); void ckmsgq_add(ckmsgq_t *ckmsgq, void *data); bool ckmsgq_empty(ckmsgq_t *ckmsgq); ckpool_t *global_ckp; bool ping_main(ckpool_t *ckp); void empty_buffer(connsock_t *cs); int read_socket_line(connsock_t *cs, const int timeout); bool _send_proc(proc_instance_t *pi, const char *msg, const char *file, const char *func, const int line); #define send_proc(pi, msg) _send_proc(pi, msg, __FILE__, __func__, __LINE__) char *_send_recv_proc(proc_instance_t *pi, const char *msg, const char *file, const char *func, const int line); #define send_recv_proc(pi, msg) _send_recv_proc(pi, msg, __FILE__, __func__, __LINE__) char *_send_recv_ckdb(const ckpool_t *ckp, const char *msg, const char *file, const char *func, const int line); #define send_recv_ckdb(ckp, msg) _send_recv_ckdb(ckp, msg, __FILE__, __func__, __LINE__) char *_ckdb_msg_call(const ckpool_t *ckp, const char *msg, const char *file, const char *func, const int line); #define ckdb_msg_call(ckp, msg) _ckdb_msg_call(ckp, msg, __FILE__, __func__, __LINE__) json_t *json_rpc_call(connsock_t *cs, const char *rpc_req); int process_exit(ckpool_t *ckp, const proc_instance_t *pi, int ret); bool json_get_string(char **store, const json_t *val, const char *res); bool json_get_int64(int64_t *store, const json_t *val, const char *res); bool json_get_int(int *store, const json_t *val, const char *res); bool json_get_double(double *store, const json_t *val, const char *res); #endif /* CKPOOL_H */