X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=client.h;h=2f257221510b1cb0b0848eb615d1dfb894f0cc81;hp=0685f33e0a3ac2f06106adbacf151f0773840c3b;hb=refs%2Fheads%2Fmaint;hpb=277ed4a605f68118aff9e671f16c0ac6edb1d55a diff --git a/client.h b/client.h index 0685f33e..7ba56b91 100644 --- a/client.h +++ b/client.h @@ -1,8 +1,4 @@ -/* - * Copyright (C) 1997-2013 Andre Noll - * - * Licensed under the GPL v2. For licencing details see COPYING. - */ +/* Copyright (C) 1997 Andre Noll , see file COPYING. */ /** \file client.h Common client functions and exported symbols from client_common.c. */ @@ -20,12 +16,10 @@ enum { CL_SENT_CH_RESPONSE, /** Server accepts this authentication. */ CL_RECEIVED_PROCEED, - /** Client sends the command. */ - CL_SENT_COMMAND, - /** Server expects data. */ + /** Command is executing. */ + CL_EXECUTING, + /** Server is expecting data (addblob commands only). */ CL_SENDING, - /** Client expects data. */ - CL_RECEIVING, }; /** Data specific to a client task. */ @@ -34,27 +28,34 @@ struct client_task { int status; /** The file descriptor and the session keys. */ struct stream_cipher_context scc; - /** The sideband context. */ - struct sb_context *sbc; + /** The sideband contexts for receiving/sending. */ + struct sb_context *sbc[2]; + /** The buffer tree nodes for receiving/sending. */ + struct btr_node *btrn[2]; /** The hash value of the decrypted challenge. */ unsigned char *challenge_hash; - /** The configuration (including the command). */ - struct client_args_info conf; - /** The config file for client options. */ - char *config_file; + /** The parsed command line (including the command). */ + struct lls_parse_result *lpr; /** The RSA private key. */ char *key_file; /** Paraslash user name. */ char *user; /** The client task structure. */ - struct task task; - /** The buffer tree node of the client task. */ - struct btr_node *btrn; + struct task *task; /** List of features supported by the server. */ char **features; }; -void client_disconnect(struct client_task *ct); +#define CLIENT_CMD_PTR (lls_cmd(0, client_suite)) +#define CLIENT_OPT_RESULT(_name, _lpr) \ + (lls_opt_result(LSG_CLIENT_PARA_CLIENT_OPT_ ## _name, _lpr)) +#define CLIENT_OPT_GIVEN(_name, _lpr) \ + (lls_opt_given(CLIENT_OPT_RESULT(_name, _lpr))) +#define CLIENT_OPT_UINT32_VAL(_name, _lpr) \ + (lls_uint32_val(0, CLIENT_OPT_RESULT(_name, _lpr))) +#define CLIENT_OPT_STRING_VAL(_name, _lpr) \ + (lls_string_val(0, CLIENT_OPT_RESULT(_name, _lpr))) + void client_close(struct client_task *ct); int client_parse_config(int argc, char *argv[], struct client_task **ct_ptr, int *loglevel);