2023-08-03 16:49:06 +03:00
/*
2005-10-14 16:38:07 +04:00
Unix SMB / CIFS implementation .
2023-08-03 16:49:06 +03:00
2005-10-14 16:38:07 +04:00
WINS Replication server
2023-08-03 16:49:06 +03:00
2005-10-14 16:38:07 +04:00
Copyright ( C ) Stefan Metzmacher 2005
2023-08-03 16:49:06 +03:00
2005-10-14 16:38:07 +04:00
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
2007-07-10 06:07:03 +04:00
the Free Software Foundation ; either version 3 of the License , or
2005-10-14 16:38:07 +04:00
( at your option ) any later version .
2023-08-03 16:49:06 +03:00
2005-10-14 16:38:07 +04:00
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
2023-08-03 16:49:06 +03:00
2005-10-14 16:38:07 +04:00
You should have received a copy of the GNU General Public License
2007-07-10 06:07:03 +04:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2005-10-14 16:38:07 +04:00
*/
2010-01-20 16:21:47 +03:00
# include "system/network.h"
2005-10-14 16:38:07 +04:00
struct wreplsrv_service ;
struct wreplsrv_in_connection ;
struct wreplsrv_out_connection ;
struct wreplsrv_partner ;
2005-10-14 16:44:47 +04:00
# define WREPLSRV_VALID_ASSOC_CTX 0x12345678
# define WREPLSRV_INVALID_ASSOC_CTX 0x0000000a
2005-10-14 16:38:07 +04:00
/*
state of an incoming wrepl call
*/
struct wreplsrv_in_call {
struct wreplsrv_in_connection * wreplconn ;
struct wrepl_packet req_packet ;
struct wrepl_packet rep_packet ;
2007-08-27 22:10:19 +04:00
bool terminate_after_send ;
2010-01-20 16:21:47 +03:00
DATA_BLOB in ;
DATA_BLOB out ;
struct iovec out_iov [ 1 ] ;
2005-10-14 16:38:07 +04:00
} ;
/*
state of an incoming wrepl connection
*/
struct wreplsrv_in_connection {
struct wreplsrv_in_connection * prev , * next ;
struct stream_connection * conn ;
2010-01-20 16:21:47 +03:00
struct tstream_context * tstream ;
struct tevent_queue * send_queue ;
2005-10-14 16:38:07 +04:00
/* our global service context */
struct wreplsrv_service * service ;
/*
* the partner that connects us ,
* can be NULL , when we got a connection
* from an unknown address
*/
struct wreplsrv_partner * partner ;
2005-10-14 16:44:47 +04:00
/* keep track of the assoc_ctx's */
struct {
2007-08-27 22:10:19 +04:00
bool stopped ;
2005-10-14 16:44:47 +04:00
uint32_t our_ctx ;
uint32_t peer_ctx ;
} assoc_ctx ;
2005-10-14 16:38:07 +04:00
} ;
/*
2006-04-20 15:37:14 +04:00
state of an outgoing wrepl connection
2005-10-14 16:38:07 +04:00
*/
struct wreplsrv_out_connection {
2005-10-14 18:02:47 +04:00
/* our global service context */
struct wreplsrv_service * service ;
/*
2006-04-20 15:37:14 +04:00
* the partner we connect
2005-10-14 18:02:47 +04:00
*/
2005-10-14 16:38:07 +04:00
struct wreplsrv_partner * partner ;
2005-10-14 18:02:47 +04:00
/* keep track of the assoc_ctx's */
struct {
uint32_t our_ctx ;
uint32_t peer_ctx ;
2008-03-26 22:07:10 +03:00
uint16_t peer_major ;
2005-10-14 18:02:47 +04:00
} assoc_ctx ;
2023-08-03 16:49:06 +03:00
/*
2005-10-14 18:02:47 +04:00
* the client socket to the partner ,
* NULL if not yet connected
*/
struct wrepl_socket * sock ;
2005-10-14 16:38:07 +04:00
} ;
2005-10-14 16:52:35 +04:00
enum winsrepl_partner_type {
2005-10-14 18:02:47 +04:00
WINSREPL_PARTNER_NONE = 0x0 ,
2005-10-14 16:52:35 +04:00
WINSREPL_PARTNER_PULL = 0x1 ,
WINSREPL_PARTNER_PUSH = 0x2 ,
WINSREPL_PARTNER_BOTH = ( WINSREPL_PARTNER_PULL | WINSREPL_PARTNER_PUSH )
} ;
# define WINSREPL_DEFAULT_PULL_INTERVAL (30*60)
2005-10-14 18:02:47 +04:00
# define WINSREPL_DEFAULT_PULL_RETRY_INTERVAL (30)
2005-10-14 16:52:35 +04:00
2005-11-07 16:22:51 +03:00
# define WINSREPL_DEFAULT_PUSH_CHANGE_COUNT (0)
2005-10-14 16:52:35 +04:00
/*
this represents one of our configured partners
*/
struct wreplsrv_partner {
struct wreplsrv_partner * prev , * next ;
2005-10-14 18:02:47 +04:00
/* our global service context */
struct wreplsrv_service * service ;
2005-10-14 16:52:35 +04:00
/* the netbios name of the partner, mostly just for debugging */
const char * name ;
/* the ip-address of the partner */
const char * address ;
2023-08-03 16:49:06 +03:00
/*
2005-10-14 16:52:35 +04:00
* as wins partners identified by ip - address , we need to use a specific source - ip
* when we want to connect to the partner
*/
const char * our_address ;
/* the type of the partner, pull, push or both */
enum winsrepl_partner_type type ;
/* pull specific options */
struct {
/* the interval between 2 pull replications to the partner */
uint32_t interval ;
2005-10-14 16:56:42 +04:00
2005-10-14 18:02:47 +04:00
/* the retry_interval if a pull cycle failed to the partner */
uint32_t retry_interval ;
/* the error count till the last success */
uint32_t error_count ;
/* the status of the last pull cycle */
NTSTATUS last_status ;
2005-12-20 03:55:28 +03:00
/* the timestamp of the next pull try */
struct timeval next_run ;
2005-10-14 16:56:42 +04:00
/* this is a list of each wins_owner the partner knows about */
struct wreplsrv_owner * table ;
/* the outgoing connection to the partner */
struct wreplsrv_out_connection * wreplconn ;
2005-10-14 18:02:47 +04:00
/* the current pending pull cycle request */
struct composite_context * creq ;
/* the pull cycle io params */
struct wreplsrv_pull_cycle_io * cycle_io ;
/* the current timed_event to the next pull cycle */
2008-12-29 22:24:57 +03:00
struct tevent_timer * te ;
2005-10-14 16:52:35 +04:00
} pull ;
2005-10-14 18:02:47 +04:00
/* push specific options */
struct {
/* change count till push notification */
uint32_t change_count ;
2006-01-24 20:36:13 +03:00
/* the last wins db maxVersion have reported to the partner */
uint64_t maxVersionID ;
2005-12-31 12:44:04 +03:00
2005-12-14 22:19:43 +03:00
/* we should use WREPL_REPL_INFORM* messages to this partner */
2007-08-27 22:10:19 +04:00
bool use_inform ;
2005-12-14 22:19:43 +03:00
/* the error count till the last success */
uint32_t error_count ;
2005-10-14 18:02:47 +04:00
/* the status of the last push cycle */
NTSTATUS last_status ;
/* the outgoing connection to the partner */
struct wreplsrv_out_connection * wreplconn ;
/* the current push notification */
struct composite_context * creq ;
/* the pull cycle io params */
struct wreplsrv_push_notify_io * notify_io ;
} push ;
2005-10-14 16:52:35 +04:00
} ;
struct wreplsrv_owner {
struct wreplsrv_owner * prev , * next ;
/* this hold the owner_id (address), min_version, max_version and partner_type */
struct wrepl_wins_owner owner ;
/* can be NULL if this owner isn't a configure partner */
2023-08-03 16:49:06 +03:00
struct wreplsrv_partner * partner ;
2005-10-14 16:52:35 +04:00
} ;
2005-10-14 16:38:07 +04:00
/*
state of the whole wrepl service
*/
struct wreplsrv_service {
/* the whole wrepl service is in one task */
struct task_server * task ;
2005-12-22 14:40:14 +03:00
/* the time the service was started */
struct timeval startup_time ;
2005-10-14 16:48:20 +04:00
/* the winsdb handle */
2005-12-30 23:08:52 +03:00
struct winsdb_handle * wins_db ;
2005-10-14 16:48:20 +04:00
2005-11-23 12:38:44 +03:00
/* some configuration */
struct {
2005-12-17 18:45:38 +03:00
/* the wins config db handle */
struct ldb_context * ldb ;
2006-01-03 23:19:39 +03:00
/* the last wins config db seqnumber we know about */
uint64_t seqnumber ;
2023-08-03 16:49:06 +03:00
/*
* the interval ( in secs ) till an active record will be marked as RELEASED
2005-11-23 12:38:44 +03:00
*/
uint32_t renew_interval ;
2023-08-03 16:49:06 +03:00
/*
2005-11-23 12:38:44 +03:00
* the interval ( in secs ) a record remains in RELEASED state ,
* before it will be marked as TOMBSTONE
* ( also known as extinction interval )
*/
uint32_t tombstone_interval ;
2023-08-03 16:49:06 +03:00
/*
2005-11-23 12:38:44 +03:00
* the interval ( in secs ) a record remains in TOMBSTONE state ,
* before it will be removed from the database .
2005-12-22 14:40:14 +03:00
* See also ' tombstone_extra_timeout ' .
2005-11-23 12:38:44 +03:00
* ( also known as extinction timeout )
*/
uint32_t tombstone_timeout ;
2023-08-03 16:49:06 +03:00
/*
2005-12-22 14:40:14 +03:00
* the interval ( in secs ) a record remains in TOMBSTONE state ,
* even after ' tombstone_timeout ' passes the current timestamp .
* this is the minimum uptime of the wrepl service , before
* we start delete tombstones . This is to prevent deletion of
2023-08-03 16:48:16 +03:00
* tombstones , without replicating them .
2005-12-22 14:40:14 +03:00
*/
uint32_t tombstone_extra_timeout ;
2023-08-03 16:49:06 +03:00
/*
2005-11-23 12:38:44 +03:00
* the interval ( in secs ) till a replica record will be verified
* with the owning wins server
*/
uint32_t verify_interval ;
2005-12-14 13:56:43 +03:00
2023-08-03 16:49:06 +03:00
/*
2005-12-22 14:40:14 +03:00
* the interval ( in secs ) till a do a database cleanup
*/
uint32_t scavenging_interval ;
2023-08-03 16:49:06 +03:00
/*
2005-12-14 13:56:43 +03:00
* the interval ( in secs ) to the next periodic processing
2023-08-03 16:48:16 +03:00
* ( this is the maximum interval )
2005-12-14 13:56:43 +03:00
*/
uint32_t periodic_interval ;
2005-11-23 12:38:44 +03:00
} config ;
2005-10-14 16:38:07 +04:00
/* all incoming connections */
struct wreplsrv_in_connection * in_connections ;
/* all partners (pull and push) */
struct wreplsrv_partner * partners ;
2006-01-02 20:19:09 +03:00
/*
* this is our local wins_owner entry , this is also in the table list
2023-08-03 16:49:06 +03:00
* but we need a pointer to it , because we need to update it on each
2006-01-02 20:19:09 +03:00
* query to wreplsrv_find_owner ( ) , as the local records can be added
* to the wins . ldb from external tools and the winsserver
*/
struct wreplsrv_owner * owner ;
2005-10-14 16:52:35 +04:00
/* this is a list of each wins_owner we know about in our database */
struct wreplsrv_owner * table ;
2005-12-14 13:56:43 +03:00
/* some stuff for periodic processing */
struct {
2005-12-14 22:19:43 +03:00
/*
* the timestamp for the next event ,
2023-09-06 03:06:26 +03:00
* this is the timestamp passed to event_add_timed ( )
2005-12-14 13:56:43 +03:00
*/
struct timeval next_event ;
/* here we have a reference to the timed event the schedules the periodic stuff */
2008-12-29 22:24:57 +03:00
struct tevent_timer * te ;
2005-12-14 13:56:43 +03:00
} periodic ;
2005-12-22 14:40:14 +03:00
/* some stuff for scavenging processing */
struct {
/*
* the timestamp for the next scavenging run ,
2023-09-06 03:06:26 +03:00
* this is the timestamp passed to event_add_timed ( )
2005-12-22 14:40:14 +03:00
*/
struct timeval next_run ;
/*
* are we currently inside a scavenging run
*/
2023-08-03 16:49:06 +03:00
bool processing ;
2005-12-22 14:40:14 +03:00
} scavenging ;
2005-10-14 16:38:07 +04:00
} ;
2005-12-28 18:38:36 +03:00
2006-03-18 18:42:57 +03:00
struct socket_context ;
2006-04-20 16:00:38 +04:00
struct wrepl_name ;
2006-01-03 20:27:33 +03:00
# include "wrepl_server/wrepl_out_helpers.h"
2005-12-28 18:38:36 +03:00
# include "wrepl_server/wrepl_server_proto.h"