X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=src%2Fclient.h;h=6f8aa39d789007701eb22bac3b2471d2c0f4f96a;hb=fcc2c96e9785d94ac924fa6b008549c1357f6151;hp=60c86dbfa2657c821d289df33f236e6bef2629d3;hpb=a0e46b6337ab6736bb391703338d2ad3b5ee514f;p=umurmur.git diff --git a/src/client.h b/src/client.h index 60c86db..6f8aa39 100644 --- a/src/client.h +++ b/src/client.h @@ -59,43 +59,46 @@ #define IS_AUTH(_a_) ((_a_)->authenticated) +struct channel; + typedef struct { - int tcpfd; SSL_handle_t *ssl; - bool_t SSLready; - bool_t shutdown_wait; - cryptState_t cryptState; - bool_t readBlockedOnWrite, writeBlockedOnRead; - - struct sockaddr_storage remote_tcp; - struct sockaddr_storage remote_udp; - char addressString[INET6_ADDRSTRLEN]; - uint8_t rxbuf[BUFSIZE], txbuf[BUFSIZE]; - uint32_t rxcount, msgsize, drainleft, txcount, txsize; - int sessionId; - uint8_t key[KEY_LENGTH]; + struct dlist node; char *username; - bool_t bUDP, authenticated, deaf, mute, self_deaf, self_mute, recording, bOpus; char *os, *release, *os_version; + uint32_t rxcount, msgsize, drainleft, txcount, txsize; + int sessionId; uint32_t version; int codec_count; struct dlist codecs; - int availableBandwidth; etimer_t lastActivity, connectTime, idleTime; - struct dlist node; struct dlist txMsgQueue; int txQueueCount; - void *channel; /* Ugly... */ + int availableBandwidth; + struct channel *channel; char *context; struct dlist chan_node; struct dlist voicetargets; struct dlist tokens; int tokencount; - uint8_t hash[20]; - bool_t isAdmin; - bool_t isSuppressed; + int tcpfd; float UDPPingAvg, UDPPingVar, TCPPingAvg, TCPPingVar; uint32_t UDPPackets, TCPPackets; + + bool_t SSLready; + bool_t shutdown_wait; + bool_t readBlockedOnWrite, writeBlockedOnRead; + bool_t bUDP, authenticated, deaf, mute, self_deaf, self_mute, recording, bOpus; + bool_t isAdmin; + bool_t isSuppressed; + + struct sockaddr_storage remote_tcp; + struct sockaddr_storage remote_udp; + + uint8_t key[KEY_LENGTH]; + uint8_t hash[20]; + cryptState_t cryptState; + uint8_t rxbuf[BUFSIZE], txbuf[BUFSIZE]; } client_t; typedef struct { @@ -129,5 +132,8 @@ void Client_codec_add(client_t *client, int codec); void Client_codec_free(client_t *client); codec_t *Client_codec_iterate(client_t *client, codec_t **codec_itr); void Client_textmessage(client_t *client, char *text); +bool_t Client_token_match(client_t *client, char const *str); +void Client_token_free(client_t *client); +void Client_token_add(client_t *client, char *token_string); #endif