loudmouth/lm-connection.c
author Owen Taylor <otaylor@redhat.com>
Mon, 25 Feb 2008 23:58:43 +0100
changeset 344 11473296fea5
parent 341 f44b206faf54
child 345 9a94f040cc56
permissions -rw-r--r--
Return FALSE from lm_connection_open in the synchronous case instead of open callback This patch fixes things up so that synchronous failures don't call the open callback but instead return the correct FALSE result from lm_connection_open(). Otherwise this means that we will get the callback before the lm_connection_open call has returned. committer: Mikael Hallendal <micke@imendio.com>
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     1
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     2
/*
247
a519eff901e6 Slight code refactoring in _lm_connection_socket_result
Mikael Hallendal <micke@imendio.com>
parents: 245
diff changeset
     3
 * Copyright (C) 2003-2007 Imendio AB
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
     4
 * Copyright (C) 2006 Nokia Corporation. All rights reserved.
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
     5
 * Copyright (C) 2007 Collabora Ltd.
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     6
 *
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     7
 * This program is free software; you can redistribute it and/or
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     8
 * modify it under the terms of the GNU Lesser General Public License as
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     9
 * published by the Free Software Foundation; either version 2 of the
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    10
 * License, or (at your option) any later version.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    11
 *
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    12
 * This program is distributed in the hope that it will be useful,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    13
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    14
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    15
 * Lesser General Public License for more details.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    16
 *
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    17
 * You should have received a copy of the GNU Lesser General Public
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    18
 * License along with this program; if not, write to the
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    19
 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    20
 * Boston, MA 02111-1307, USA.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    21
 */
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    22
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    23
#include <config.h>
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    24
12
fc5e71b1369c 2003-07-07 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 9
diff changeset
    25
#include <string.h>
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
    26
#include <sys/stat.h> 
12
fc5e71b1369c 2003-07-07 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 9
diff changeset
    27
#include <sys/types.h>
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
    28
#include <fcntl.h>
337
7bc0c6ad11ff Fixes LM-118 so that building on Mac OS X works again.
Richard Hult <richard@imendio.com>
parents: 324
diff changeset
    29
7bc0c6ad11ff Fixes LM-118 so that building on Mac OS X works again.
Richard Hult <richard@imendio.com>
parents: 324
diff changeset
    30
/* Needed on Mac OS X */
7bc0c6ad11ff Fixes LM-118 so that building on Mac OS X works again.
Richard Hult <richard@imendio.com>
parents: 324
diff changeset
    31
#if HAVE_NETINET_IN_H
7bc0c6ad11ff Fixes LM-118 so that building on Mac OS X works again.
Richard Hult <richard@imendio.com>
parents: 324
diff changeset
    32
#include <netinet/in.h>
7bc0c6ad11ff Fixes LM-118 so that building on Mac OS X works again.
Richard Hult <richard@imendio.com>
parents: 324
diff changeset
    33
#endif
7bc0c6ad11ff Fixes LM-118 so that building on Mac OS X works again.
Richard Hult <richard@imendio.com>
parents: 324
diff changeset
    34
271
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
    35
#include <arpa/nameser.h>
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
    36
#include <resolv.h>
9
2e14e3ab411b 2003-06-24 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 7
diff changeset
    37
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
    38
#include <glib.h>
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
    39
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
    40
#include "lm-sock.h"
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    41
#include "lm-debug.h"
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    42
#include "lm-error.h"
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    43
#include "lm-internals.h"
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
    44
#include "lm-message-queue.h"
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
    45
#include "lm-misc.h"
137
18785575aa7a 2006-04-05 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 133
diff changeset
    46
#include "lm-ssl-internals.h"
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    47
#include "lm-parser.h"
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    48
#include "lm-sha.h"
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    49
#include "lm-connection.h"
155
d24c4392d4e3 2006-06-16 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 153
diff changeset
    50
#include "lm-utils.h"
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
    51
#include "lm-socket.h"
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
    52
#include "lm-sasl.h"
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
    53
271
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
    54
#define IN_BUFFER_SIZE 1024
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
    55
#define SRV_LEN 8192
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    56
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    57
typedef struct {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    58
	LmHandlerPriority  priority;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    59
	LmMessageHandler  *handler;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    60
} HandlerData;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    61
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    62
struct _LmConnection {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    63
	/* Parameters */
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    64
	GMainContext *context;
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    65
	gchar        *server;
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
    66
	gchar        *jid;
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
    67
	gchar        *effective_jid;
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    68
	guint         port;
245
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
    69
	gboolean      use_srv;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    70
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
    71
	LmSocket     *socket;
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    72
	LmSSL        *ssl;
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    73
	LmProxy      *proxy;
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    74
	LmParser     *parser;
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
    75
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    76
	gchar        *stream_id;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    77
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    78
	GHashTable   *id_handlers;
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    79
	GSList       *handlers[LM_MESSAGE_TYPE_UNKNOWN];
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    80
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
    81
	/* XMPP1.0 stuff (SASL, resource binding, StartTLS) */
332
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
    82
	gboolean      use_sasl;
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
    83
	LmSASL       *sasl;
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
    84
	gchar        *resource;
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
    85
	LmMessageHandler *features_cb;
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
    86
	LmMessageHandler *starttls_cb;
317
e7ceb196a573 Don't require StartTLS after it's already been started.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 316
diff changeset
    87
	gboolean      tls_started;
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
    88
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    89
	/* Communication */
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    90
	guint         open_id;
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    91
	LmCallback   *open_cb;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    92
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
    93
 	gboolean      async_connect_waiting;
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
    94
	gboolean      blocking;
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
    95
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    96
	gboolean      cancel_open;
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    97
	LmCallback   *auth_cb;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    98
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
    99
	LmCallback   *disconnect_cb;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   100
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   101
	LmMessageQueue *queue;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   102
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
   103
	LmConnectionState state;
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
   104
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   105
	guint         keep_alive_rate;
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   106
	GSource      *keep_alive_source;
184
4e16d32b2410 2006-10-16 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 181
diff changeset
   107
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
   108
	gint          ref_count;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   109
};
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   110
21
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   111
typedef enum {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   112
	AUTH_TYPE_PLAIN  = 1,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   113
	AUTH_TYPE_DIGEST = 2,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   114
	AUTH_TYPE_0K     = 4
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   115
} AuthType;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   116
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   117
#define XMPP_NS_BIND "urn:ietf:params:xml:ns:xmpp-bind"
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   118
#define XMPP_NS_SESSION "urn:ietf:params:xml:ns:xmpp-session"
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
   119
#define XMPP_NS_STARTTLS "urn:ietf:params:xml:ns:xmpp-tls"
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   120
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   121
static void     connection_free (LmConnection *connection);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   122
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   123
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   124
static void     connection_handle_message    (LmConnection         *connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   125
					      LmMessage            *message);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   126
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   127
static void     connection_new_message_cb    (LmParser             *parser,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   128
					      LmMessage            *message,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   129
					      LmConnection         *connection);
57
6b168a8917f7 2003-12-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 56
diff changeset
   130
static gboolean connection_do_open           (LmConnection         *connection,
6b168a8917f7 2003-12-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 56
diff changeset
   131
					      GError              **error);
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   132
void            connection_do_close          (LmConnection         *connection);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   133
133
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   134
21
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   135
static LmMessage *     connection_create_auth_req_msg (const gchar *username);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   136
static LmMessage *     connection_create_auth_msg     (LmConnection *connection,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   137
						       const gchar  *username,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   138
						       const gchar  *password,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   139
						       const gchar  *resource,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   140
						       gint          auth_type);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   141
static LmHandlerResult connection_auth_req_reply (LmMessageHandler *handler,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   142
						  LmConnection     *connection,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   143
						  LmMessage        *m,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   144
						  gpointer          user_data);
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   145
static int connection_check_auth_type            (LmMessage      *auth_req_rpl);
21
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   146
					      
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   147
static LmHandlerResult
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   148
connection_auth_reply                            (LmMessageHandler *handler,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   149
						  LmConnection     *connection,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   150
						  LmMessage        *m,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   151
						  gpointer          user_data);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   152
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   153
static void      connection_stream_received      (LmConnection    *connection, 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   154
						  LmMessage       *m);
306
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   155
static void      connection_stream_error         (LmConnection    *connection, 
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   156
						  LmMessage       *m);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   157
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   158
static gint      connection_handler_compare_func (HandlerData     *a,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   159
						  HandlerData     *b);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   160
static gboolean  connection_send_keep_alive      (LmConnection    *connection);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   161
static void      connection_start_keep_alive     (LmConnection    *connection);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   162
static void      connection_stop_keep_alive      (LmConnection    *connection);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   163
static gboolean  connection_send                 (LmConnection    *connection, 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   164
						  const gchar     *str, 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   165
						  gint             len, 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   166
						  GError         **error);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   167
static void      connection_message_queue_cb     (LmMessageQueue  *queue,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   168
						  LmConnection    *connection);
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   169
static void      connection_signal_disconnect    (LmConnection       *connection,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   170
						  LmDisconnectReason  reason);
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   171
static void      connection_incoming_data        (LmSocket        *socket, 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   172
						  const gchar     *buf,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   173
						  LmConnection    *connection);
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   174
static void      connection_socket_closed_cb     (LmSocket        *socket,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   175
						  LmDisconnectReason reason,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   176
						  LmConnection       *connection);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   177
static void      connection_socket_connect_cb    (LmSocket           *socket,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   178
						  gboolean            result,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   179
						  LmConnection       *connection);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   180
245
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   181
static gboolean  connection_get_server_from_jid  (const gchar     *jid,
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   182
						  gchar          **server);
248
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   183
static void      connection_send_stream_header   (LmConnection    *connection);
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   184
static LmHandlerResult connection_features_cb (LmMessageHandler *handler,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   185
					       LmConnection     *connection,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   186
					       LmMessage        *message,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   187
					       gpointer          user_data);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   188
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   189
static void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   190
connection_free (LmConnection *connection)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   191
{
115
f2a921e232e5 2005-04-24 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 114
diff changeset
   192
	int        i;
43
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   193
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   194
	g_free (connection->server);
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
   195
	g_free (connection->jid);
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
   196
	g_free (connection->effective_jid);
230
8acc59cf04ea Free stream_id when freeing the connection.
Mikael Hallendal <micke@imendio.com>
parents: 226
diff changeset
   197
	g_free (connection->stream_id);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   198
	g_free (connection->resource);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   199
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   200
	if (connection->sasl) {
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   201
		lm_sasl_free (connection->sasl);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   202
	}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   203
153
b2324df84971 2006-06-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 143
diff changeset
   204
	if (connection->parser) {
b2324df84971 2006-06-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 143
diff changeset
   205
		lm_parser_free (connection->parser);
b2324df84971 2006-06-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 143
diff changeset
   206
	}
b2324df84971 2006-06-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 143
diff changeset
   207
43
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   208
	/* Unref handlers */
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   209
	for (i = 0; i < LM_MESSAGE_TYPE_UNKNOWN; ++i) {
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   210
		GSList *l;
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   211
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   212
		for (l = connection->handlers[i]; l; l = l->next) {
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   213
			HandlerData *hd = (HandlerData *) l->data;
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   214
			
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   215
			lm_message_handler_unref (hd->handler);
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   216
			g_free (hd);
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   217
		}
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   218
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   219
		g_slist_free (connection->handlers[i]);
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   220
	}
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   221
66ff4339e06e 2003-10-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 40
diff changeset
   222
	g_hash_table_destroy (connection->id_handlers);
113
093ad250d17c 2005-04-18 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 111
diff changeset
   223
	if (connection->state >= LM_CONNECTION_STATE_OPENING) {
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   224
		connection_do_close (connection);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   225
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   226
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   227
	if (connection->open_cb) {
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   228
		_lm_utils_free_callback (connection->open_cb);
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   229
	}
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   230
	
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   231
	if (connection->auth_cb) {
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   232
		_lm_utils_free_callback (connection->auth_cb);
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   233
	}
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   234
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   235
	lm_connection_set_disconnect_function (connection, NULL, NULL, NULL);
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   236
211
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
   237
	if (connection->proxy) {
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
   238
		lm_proxy_unref (connection->proxy);
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
   239
	}
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
   240
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   241
	lm_message_queue_unref (connection->queue);
115
f2a921e232e5 2005-04-24 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 114
diff changeset
   242
128
a1f41ebde5c4 2005-08-16 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 126
diff changeset
   243
        if (connection->context) {
a1f41ebde5c4 2005-08-16 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 126
diff changeset
   244
                g_main_context_unref (connection->context);
a1f41ebde5c4 2005-08-16 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 126
diff changeset
   245
        }
133
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   246
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   247
	if (connection->socket) {
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   248
		lm_socket_unref (connection->socket);
133
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   249
	}
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   250
128
a1f41ebde5c4 2005-08-16 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 126
diff changeset
   251
        g_free (connection);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   252
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   253
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   254
static void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   255
connection_handle_message (LmConnection *connection, LmMessage *m)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   256
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   257
	LmMessageHandler *handler;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   258
	GSList           *l;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   259
	const gchar      *id;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   260
	LmHandlerResult   result = LM_HANDLER_RESULT_ALLOW_MORE_HANDLERS;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   261
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   262
	lm_connection_ref (connection);
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   263
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   264
	if (lm_message_get_type (m) == LM_MESSAGE_TYPE_STREAM) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   265
		connection_stream_received (connection, m);
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   266
		goto out;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   267
	}
306
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   268
294
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   269
	if ((lm_message_get_sub_type (m) == LM_MESSAGE_SUB_TYPE_ERROR) ||
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   270
	    (lm_message_get_sub_type (m) == LM_MESSAGE_SUB_TYPE_RESULT)) {
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   271
		id = lm_message_node_get_attribute (m->node, "id");
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   272
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   273
		if (id) {
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   274
			handler = g_hash_table_lookup (connection->id_handlers, id);
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   275
			if (handler) {
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   276
				result = _lm_message_handler_handle_message (handler,
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   277
									     connection,
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   278
									     m);
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   279
				g_hash_table_remove (connection->id_handlers,
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   280
						    id);
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   281
			}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   282
		}
294
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   283
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   284
		if (result == LM_HANDLER_RESULT_REMOVE_MESSAGE) {
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   285
			goto out;
bd0b7673bc4a Properly check if the message is error/reply before calling the reply handler.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 292
diff changeset
   286
		}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   287
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   288
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   289
	for (l = connection->handlers[lm_message_get_type (m)]; 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   290
	     l && result == LM_HANDLER_RESULT_ALLOW_MORE_HANDLERS; 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   291
	     l = l->next) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   292
		HandlerData *hd = (HandlerData *) l->data;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   293
		
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   294
		result = _lm_message_handler_handle_message (hd->handler,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   295
							     connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   296
							     m);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   297
	}
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   298
311
153357413e1b Allow application handlers on stream errors, before closing down the connection.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 308
diff changeset
   299
	if (lm_message_get_type (m) == LM_MESSAGE_TYPE_STREAM_ERROR) {
153357413e1b Allow application handlers on stream errors, before closing down the connection.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 308
diff changeset
   300
		connection_stream_error (connection, m);
153357413e1b Allow application handlers on stream errors, before closing down the connection.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 308
diff changeset
   301
		goto out;
153357413e1b Allow application handlers on stream errors, before closing down the connection.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 308
diff changeset
   302
	}
153357413e1b Allow application handlers on stream errors, before closing down the connection.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 308
diff changeset
   303
	
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   304
out:
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   305
	lm_connection_unref (connection);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   306
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   307
	return;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   308
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   309
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   310
static void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   311
connection_new_message_cb (LmParser     *parser,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   312
			   LmMessage    *m,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   313
			   LmConnection *connection)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   314
{
100
2b2a0caf1b3a 2004-10-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 99
diff changeset
   315
	const gchar *from;
2b2a0caf1b3a 2004-10-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 99
diff changeset
   316
	
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   317
	lm_message_ref (m);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   318
100
2b2a0caf1b3a 2004-10-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 99
diff changeset
   319
	from = lm_message_node_get_attribute (m->node, "from");
2b2a0caf1b3a 2004-10-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 99
diff changeset
   320
	if (!from) {
2b2a0caf1b3a 2004-10-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 99
diff changeset
   321
		from = "unknown";
2b2a0caf1b3a 2004-10-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 99
diff changeset
   322
	}
2b2a0caf1b3a 2004-10-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 99
diff changeset
   323
	
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   324
	lm_verbose ("New message with type=\"%s\" from: %s\n",
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   325
		    _lm_message_type_to_string (lm_message_get_type (m)),
100
2b2a0caf1b3a 2004-10-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 99
diff changeset
   326
		    from);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   327
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   328
	lm_message_queue_push_tail (connection->queue, m);
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
   329
}
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
   330
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   331
static gboolean
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   332
connection_send_keep_alive (LmConnection *connection)
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   333
{ 
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   334
	if (!connection_send (connection, " ", -1, NULL)) {
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
   335
		lm_verbose ("Error while sending keep alive package!\n");
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   336
	}
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   337
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   338
	return TRUE;
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   339
}
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   340
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   341
static void
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   342
connection_start_keep_alive (LmConnection *connection)
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   343
{
292
bb7269466be2 Use TCP keepalives on Linux if available; if not, fallback to manual keepalives.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 291
diff changeset
   344
	/* try using TCP keepalives if possible */
bb7269466be2 Use TCP keepalives on Linux if available; if not, fallback to manual keepalives.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 291
diff changeset
   345
	if ((connection->keep_alive_rate > 0) &&
bb7269466be2 Use TCP keepalives on Linux if available; if not, fallback to manual keepalives.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 291
diff changeset
   346
		lm_socket_set_keepalive (connection->socket,
bb7269466be2 Use TCP keepalives on Linux if available; if not, fallback to manual keepalives.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 291
diff changeset
   347
			connection->keep_alive_rate))
bb7269466be2 Use TCP keepalives on Linux if available; if not, fallback to manual keepalives.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 291
diff changeset
   348
		return;
bb7269466be2 Use TCP keepalives on Linux if available; if not, fallback to manual keepalives.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 291
diff changeset
   349
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   350
	if (connection->keep_alive_source) {
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   351
		connection_stop_keep_alive (connection);
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   352
	}
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   353
93
903382d1c95d 2004-08-30 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 91
diff changeset
   354
	if (connection->keep_alive_rate > 0) {
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   355
		connection->keep_alive_source =
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   356
			lm_misc_add_timeout (connection->context,
341
f44b206faf54 Fixed the keep alive rate when using TCP for handling keep alive. Fixes LM-121.
Mikael Hallendal <micke@imendio.com>
parents: 340
diff changeset
   357
					     connection->keep_alive_rate * 1000,
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   358
					     (GSourceFunc) connection_send_keep_alive,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   359
					     connection);
93
903382d1c95d 2004-08-30 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 91
diff changeset
   360
	}
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   361
}
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   362
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   363
static void
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   364
connection_stop_keep_alive (LmConnection *connection)
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   365
{
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   366
	if (connection->keep_alive_source) {
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   367
		g_source_destroy (connection->keep_alive_source);
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
   368
	}
64
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
   369
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   370
	connection->keep_alive_source = NULL;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   371
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   372
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   373
static gboolean
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   374
connection_send (LmConnection  *connection, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   375
		 const gchar   *str, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   376
		 gint           len, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   377
		 GError       **error)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   378
{
133
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   379
	gint b_written;
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   380
91
d51b8e4f43d9 2004-08-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 90
diff changeset
   381
	if (connection->state < LM_CONNECTION_STATE_OPENING) {
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
   382
		g_log (LM_LOG_DOMAIN,LM_LOG_LEVEL_NET,
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
   383
		       "Connection is not open.\n");
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
   384
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   385
		g_set_error (error,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   386
			     LM_ERROR,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   387
			     LM_ERROR_CONNECTION_NOT_OPEN,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   388
			     "Connection is not open, call lm_connection_open() first");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   389
		return FALSE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   390
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   391
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   392
	if (len == -1) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   393
		len = strlen (str);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   394
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   395
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   396
	g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_NET, "\nSEND:\n");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   397
	g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_NET, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   398
	       "-----------------------------------\n");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   399
	g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_NET, "%s\n", str);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   400
	g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_NET, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   401
	       "-----------------------------------\n");
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
   402
133
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   403
	/* Check to see if there already is an output buffer, if so, add to the
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   404
	   buffer and return */
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   405
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   406
	if (lm_socket_output_is_buffered (connection->socket, str, len)) {
133
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   407
		return TRUE;
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   408
	}
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   409
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   410
	b_written = lm_socket_do_write (connection->socket, str, len);
133
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   411
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   412
	if (b_written < 0) {
283
b77f6cfe229e lm-connection.c: connection_send(): in case of error, properly set the error variable
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 281
diff changeset
   413
		g_set_error (error,
b77f6cfe229e lm-connection.c: connection_send(): in case of error, properly set the error variable
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 281
diff changeset
   414
			     LM_ERROR,
b77f6cfe229e lm-connection.c: connection_send(): in case of error, properly set the error variable
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 281
diff changeset
   415
			     LM_ERROR_CONNECTION_FAILED,
b77f6cfe229e lm-connection.c: connection_send(): in case of error, properly set the error variable
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 281
diff changeset
   416
			     "Server closed the connection");
133
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   417
		return FALSE;
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   418
	}
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   419
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   420
	if (b_written < len) {
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   421
		lm_socket_setup_output_buffer (connection->socket, 
133
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   422
						str + b_written, 
f7522d7ed6dc 2006-04-03 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 132
diff changeset
   423
						len - b_written);
15
1ff2f81867e1 2003-07-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 12
diff changeset
   424
	}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   425
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   426
	return TRUE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   427
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   428
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   429
static void
249
2cca5ec7b573 Style fixes
Mikael Hallendal <micke@imendio.com>
parents: 248
diff changeset
   430
connection_message_queue_cb (LmMessageQueue *queue, LmConnection *connection)
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   431
{
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   432
	LmMessage *m;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   433
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   434
	m = lm_message_queue_pop_nth (connection->queue, 0);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   435
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   436
	if (m) {
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   437
		connection_handle_message (connection, m);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   438
		lm_message_unref (m);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   439
	}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   440
}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   441
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   442
/* Returns directly */
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   443
/* Setups all data needed to start the connection attempts */
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   444
static gboolean
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   445
connection_do_open (LmConnection *connection, GError **error) 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   446
{
281
4e0421c44a73 Fixed a leak in extracting the domain name from the jid.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 275
diff changeset
   447
	gchar *domain = NULL;
245
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   448
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   449
	if (lm_connection_is_open (connection)) {
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   450
		g_set_error (error,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   451
			     LM_ERROR,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   452
			     LM_ERROR_CONNECTION_NOT_OPEN,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   453
			     "Connection is already open, call lm_connection_close() first");
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   454
		return FALSE;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   455
	}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   456
275
37937c612f62 Made SRV handling more sane, and implemented fallback using jid domain name.
Senko Rasic <senko@phyrexia.(none)>
parents: 274
diff changeset
   457
	if (!connection_get_server_from_jid (connection->jid, &domain)) {
327
2372eec7b179 connection_do_open: behave nicely if jid isn't set (1.2.x also behaves this way)
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 324
diff changeset
   458
		domain = g_strdup (connection->server);
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   459
	}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   460
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   461
	lm_verbose ("Connecting to: %s:%d\n", 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   462
		    connection->server, connection->port);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   463
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   464
	connection->socket = lm_socket_create (connection->context,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   465
					       (IncomingDataFunc) connection_incoming_data,
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   466
					       (SocketClosedFunc) connection_socket_closed_cb,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   467
					       (ConnectResultFunc) connection_socket_connect_cb,
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   468
					       connection,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   469
					       connection,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   470
					       connection->blocking,
275
37937c612f62 Made SRV handling more sane, and implemented fallback using jid domain name.
Senko Rasic <senko@phyrexia.(none)>
parents: 274
diff changeset
   471
					       connection->server,
37937c612f62 Made SRV handling more sane, and implemented fallback using jid domain name.
Senko Rasic <senko@phyrexia.(none)>
parents: 274
diff changeset
   472
					       domain,
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   473
					       connection->port,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   474
					       connection->ssl,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   475
					       connection->proxy,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   476
					       error);
245
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   477
281
4e0421c44a73 Fixed a leak in extracting the domain name from the jid.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 275
diff changeset
   478
	g_free (domain);
4e0421c44a73 Fixed a leak in extracting the domain name from the jid.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 275
diff changeset
   479
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   480
	if (!connection->socket) {
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   481
		return FALSE;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   482
	}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   483
344
11473296fea5 Return FALSE from lm_connection_open in the synchronous case instead of open callback
Owen Taylor <otaylor@redhat.com>
parents: 341
diff changeset
   484
	lm_message_queue_attach (connection->queue, connection->context);
11473296fea5 Return FALSE from lm_connection_open in the synchronous case instead of open callback
Owen Taylor <otaylor@redhat.com>
parents: 341
diff changeset
   485
	
11473296fea5 Return FALSE from lm_connection_open in the synchronous case instead of open callback
Owen Taylor <otaylor@redhat.com>
parents: 341
diff changeset
   486
	connection->state = LM_CONNECTION_STATE_OPENING;
11473296fea5 Return FALSE from lm_connection_open in the synchronous case instead of open callback
Owen Taylor <otaylor@redhat.com>
parents: 341
diff changeset
   487
	connection->async_connect_waiting = FALSE;
11473296fea5 Return FALSE from lm_connection_open in the synchronous case instead of open callback
Owen Taylor <otaylor@redhat.com>
parents: 341
diff changeset
   488
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   489
	return TRUE;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   490
}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   491
					
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   492
void
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   493
connection_do_close (LmConnection *connection)
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   494
{
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   495
	connection_stop_keep_alive (connection);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   496
211
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
   497
	if (connection->socket) {
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
   498
		lm_socket_close (connection->socket);
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
   499
	}
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   500
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   501
	lm_message_queue_detach (connection->queue);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   502
	
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   503
	if (!lm_connection_is_open (connection)) {
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   504
		/* lm_connection_is_open is FALSE for state OPENING as well */
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   505
		connection->state = LM_CONNECTION_STATE_CLOSED;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   506
		connection->async_connect_waiting = FALSE;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   507
		return;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   508
	}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   509
	
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   510
	connection->state = LM_CONNECTION_STATE_CLOSED;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   511
	connection->async_connect_waiting = FALSE;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   512
	if (connection->ssl) {
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   513
		_lm_ssl_close (connection->ssl);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   514
	}
324
4b06b1173262 Properly clean up SASL context on disconnect, allowing connection object reuse.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 323
diff changeset
   515
4b06b1173262 Properly clean up SASL context on disconnect, allowing connection object reuse.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 323
diff changeset
   516
	if (connection->sasl) {
4b06b1173262 Properly clean up SASL context on disconnect, allowing connection object reuse.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 323
diff changeset
   517
		lm_sasl_free (connection->sasl);
4b06b1173262 Properly clean up SASL context on disconnect, allowing connection object reuse.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 323
diff changeset
   518
		connection->sasl = NULL;
4b06b1173262 Properly clean up SASL context on disconnect, allowing connection object reuse.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 323
diff changeset
   519
	}
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   520
}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   521
21
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   522
typedef struct {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   523
	gchar        *username;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   524
	gchar        *password;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   525
	gchar        *resource;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   526
} AuthReqData;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   527
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   528
static void 
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   529
auth_req_data_free (AuthReqData *data) {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   530
	g_free (data->username);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   531
	g_free (data->password);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   532
	g_free (data->resource);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   533
	g_free (data);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   534
}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   535
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   536
static LmMessage *
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   537
connection_create_auth_req_msg (const gchar *username)
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   538
{
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   539
	LmMessage     *m;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   540
	LmMessageNode *q_node;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   541
	
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   542
	m = lm_message_new_with_sub_type (NULL, LM_MESSAGE_TYPE_IQ,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   543
					  LM_MESSAGE_SUB_TYPE_GET);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   544
	q_node = lm_message_node_add_child (m->node, "query", NULL);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   545
	lm_message_node_set_attributes (q_node,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   546
					"xmlns", "jabber:iq:auth",
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   547
					NULL);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   548
	lm_message_node_add_child (q_node, "username", username);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   549
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   550
	return m;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   551
}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   552
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   553
static LmMessage *
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   554
connection_create_auth_msg (LmConnection *connection,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   555
			    const gchar  *username,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   556
			    const gchar  *password,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   557
			    const gchar  *resource,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   558
			    gint          auth_type)
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   559
{
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   560
	LmMessage     *auth_msg;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   561
	LmMessageNode *q_node;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   562
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   563
	auth_msg = lm_message_new_with_sub_type (NULL, LM_MESSAGE_TYPE_IQ,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   564
						 LM_MESSAGE_SUB_TYPE_SET);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   565
	
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   566
	q_node = lm_message_node_add_child (auth_msg->node, "query", NULL);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   567
	
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   568
	lm_message_node_set_attributes (q_node,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   569
					"xmlns", "jabber:iq:auth", 
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   570
					NULL);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   571
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   572
	lm_message_node_add_child (q_node, "username", username);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   573
	
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   574
	if (auth_type & AUTH_TYPE_0K) {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   575
		lm_verbose ("Using 0k auth (not implemented yet)\n");
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   576
		/* TODO: Should probably use this? */
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   577
	}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   578
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   579
	if (auth_type & AUTH_TYPE_DIGEST) {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   580
		gchar       *str;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   581
		const gchar *digest;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   582
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   583
		lm_verbose ("Using digest\n");
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   584
		str = g_strconcat (connection->stream_id, password, NULL);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   585
		digest = lm_sha_hash (str);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   586
		g_free (str);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   587
		lm_message_node_add_child (q_node, "digest", digest);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   588
	} 
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   589
	else if (auth_type & AUTH_TYPE_PLAIN) {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   590
		lm_verbose ("Using plaintext auth\n");
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   591
		lm_message_node_add_child (q_node, "password", password);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   592
	} else {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   593
		/* TODO: Report error somehow */
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   594
	}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   595
	
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   596
	lm_message_node_add_child (q_node, "resource", resource);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   597
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   598
	return auth_msg;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   599
}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   600
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   601
static LmHandlerResult
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   602
connection_auth_req_reply (LmMessageHandler *handler,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   603
			   LmConnection     *connection,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   604
			   LmMessage        *m,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   605
			   gpointer          user_data)
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   606
{
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   607
	int               auth_type;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   608
	LmMessage        *auth_msg;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   609
	LmMessageHandler *auth_handler;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   610
	AuthReqData      *data = (AuthReqData *) user_data;      
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   611
	gboolean          result;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   612
	
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   613
	auth_type = connection_check_auth_type (m);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   614
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   615
	auth_msg = connection_create_auth_msg (connection, 
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   616
					       data->username,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   617
					       data->password,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   618
					       data->resource,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   619
					       auth_type);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   620
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   621
	auth_handler = lm_message_handler_new (connection_auth_reply,
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   622
					       NULL, NULL);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   623
	result = lm_connection_send_with_reply (connection, auth_msg, 
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   624
						auth_handler, NULL);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   625
	lm_message_handler_unref (auth_handler);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   626
	lm_message_unref (auth_msg);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   627
	
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   628
	return LM_HANDLER_RESULT_REMOVE_MESSAGE;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   629
}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   630
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   631
static int
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   632
connection_check_auth_type (LmMessage *auth_req_rpl)
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   633
{
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   634
	LmMessageNode *q_node;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   635
	gint           ret_val = 0; 
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   636
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   637
	q_node = lm_message_node_get_child (auth_req_rpl->node, "query");
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   638
	
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   639
	if (!q_node) {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   640
		return AUTH_TYPE_PLAIN;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   641
	}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   642
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   643
	if (lm_message_node_get_child (q_node, "password")) {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   644
		ret_val |= AUTH_TYPE_PLAIN;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   645
	}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   646
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   647
	if (lm_message_node_get_child (q_node, "digest")) {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   648
		ret_val |= AUTH_TYPE_DIGEST;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   649
	}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   650
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   651
	if (lm_message_node_get_child (q_node, "sequence") &&
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   652
	    lm_message_node_get_child (q_node, "token")) {
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   653
		ret_val |= AUTH_TYPE_0K;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   654
	}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   655
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   656
	return ret_val;
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   657
}
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
   658
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   659
static LmHandlerResult 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   660
connection_auth_reply (LmMessageHandler *handler,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   661
		       LmConnection     *connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   662
		       LmMessage        *m,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   663
		       gpointer          user_data)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   664
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   665
	const gchar *type;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   666
	gboolean     result = TRUE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   667
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   668
	g_return_val_if_fail (connection != NULL, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   669
			      LM_HANDLER_RESULT_ALLOW_MORE_HANDLERS);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   670
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   671
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   672
	type = lm_message_node_get_attribute (m->node, "type");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   673
	if (strcmp (type, "result") == 0) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   674
		result = TRUE;
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
   675
		connection->state = LM_CONNECTION_STATE_AUTHENTICATED;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   676
	} 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   677
	else if (strcmp (type, "error") == 0) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   678
		result = FALSE;
91
d51b8e4f43d9 2004-08-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 90
diff changeset
   679
		connection->state = LM_CONNECTION_STATE_OPEN;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   680
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   681
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   682
	lm_verbose ("AUTH reply: %d\n", result);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   683
	
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   684
	if (connection->auth_cb) {
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   685
	        LmCallback *cb = connection->auth_cb;
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   686
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   687
		connection->auth_cb = NULL;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   688
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   689
		if (cb->func) {
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   690
	    		(* ((LmResultFunction) cb->func)) (connection, 
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   691
						           result, cb->user_data);
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   692
		}
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   693
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   694
		_lm_utils_free_callback (cb);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   695
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   696
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   697
	return LM_HANDLER_RESULT_REMOVE_MESSAGE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   698
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   699
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   700
320
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   701
static LmHandlerResult
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   702
_lm_connection_starttls_cb (LmMessageHandler *handler,
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   703
			    LmConnection *connection,
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   704
			    LmMessage *message,
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   705
			    gpointer user_data)
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   706
{
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   707
	if (lm_socket_starttls (connection->socket)) {
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   708
		connection->tls_started = TRUE;
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   709
		connection_send_stream_header (connection);
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   710
	} else {
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   711
		connection_do_close (connection);
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   712
		connection_signal_disconnect (connection, 
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   713
					      LM_DISCONNECT_REASON_ERROR);
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   714
	}
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   715
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   716
	return LM_HANDLER_RESULT_REMOVE_MESSAGE;
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   717
}
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   718
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   719
static void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   720
connection_stream_received (LmConnection *connection, LmMessage *m)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   721
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   722
	gboolean result;
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   723
	const char *xmpp_version;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   724
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   725
	g_return_if_fail (connection != NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   726
	g_return_if_fail (m != NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   727
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   728
	connection->stream_id = g_strdup (lm_message_node_get_attribute (m->node,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   729
									 "id"));;
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   730
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   731
	xmpp_version = lm_message_node_get_attribute (m->node, "version");
220
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
   732
	if (xmpp_version && strcmp (xmpp_version, "1.0") == 0) {
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
   733
		lm_verbose ("XMPP 1.0 stream received: %s\n",
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
   734
			    connection->stream_id);
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
   735
332
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
   736
		connection->use_sasl = TRUE;
255
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
   737
		
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
   738
		/* stream is started multiple times, but we only want
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
   739
		 * one sasl mechanism */
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
   740
		if (!connection->sasl)
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
   741
			connection->sasl = lm_sasl_new(connection);
320
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   742
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   743
		/* if we'd like to use tls and we didn't already start
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   744
		 * it, prepare for it now */
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   745
		if (connection->ssl &&
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   746
				lm_ssl_get_use_starttls (connection->ssl) &&
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   747
				!connection->starttls_cb) {
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   748
			connection->starttls_cb  =
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   749
				lm_message_handler_new (_lm_connection_starttls_cb,
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   750
					NULL, NULL);
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   751
			lm_connection_register_message_handler (connection,
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   752
				connection->starttls_cb,
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   753
				LM_MESSAGE_TYPE_PROCEED,
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   754
				LM_HANDLER_PRIORITY_FIRST);
02b814ccc535 Register starttls handler at the proper moment, when the stream is received.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 317
diff changeset
   755
		}
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   756
	} else {
220
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
   757
		lm_verbose ("Old Jabber stream received: %s\n", 
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
   758
			    connection->stream_id);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   759
	}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   760
	
323
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
   761
	if (connection->state < LM_CONNECTION_STATE_OPEN)
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
   762
		connection->state = LM_CONNECTION_STATE_OPEN;
64
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
   763
	
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   764
	/* Check to see if the stream is correctly set up */
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   765
	result = TRUE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   766
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   767
	connection_start_keep_alive (connection);
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
   768
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   769
	if (connection->open_cb) {
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   770
		LmCallback *cb = connection->open_cb;
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   771
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   772
		connection->open_cb = NULL;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   773
		
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   774
		if (cb->func) {
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   775
		        (* ((LmResultFunction) cb->func)) (connection, result,
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   776
			        			   cb->user_data);
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   777
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
   778
		}
210
96b01140c00c Free open_cb correctly in connection_stream_received.
Mikael Hallendal <micke@imendio.com>
parents: 207
diff changeset
   779
		_lm_utils_free_callback (cb);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   780
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   781
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   782
306
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   783
static void
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   784
connection_stream_error (LmConnection *connection, LmMessage *m)
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   785
{
329
27b7a4649b6e Properly check for reason node in stream errors.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 327
diff changeset
   786
	LmMessageNode *node, *reason_node;
306
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   787
	LmDisconnectReason reason;
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   788
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   789
	g_return_if_fail (connection != NULL);
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   790
	g_return_if_fail (m != NULL);
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   791
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   792
	node = m->node;
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   793
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   794
	/* Resource conflict */
329
27b7a4649b6e Properly check for reason node in stream errors.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 327
diff changeset
   795
	reason_node = lm_message_node_get_child (node, "conflict");
27b7a4649b6e Properly check for reason node in stream errors.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 327
diff changeset
   796
	if (reason_node) {
306
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   797
		lm_verbose ("Stream error: Conflict (resource connected elsewhere)\n");
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   798
		reason = LM_DISCONNECT_REASON_RESOURCE_CONFLICT;
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   799
		return;
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   800
	}
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   801
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   802
	/* XML is crack */
329
27b7a4649b6e Properly check for reason node in stream errors.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 327
diff changeset
   803
	reason_node = lm_message_node_get_child (node, "xml-not-well-formed");
27b7a4649b6e Properly check for reason node in stream errors.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 327
diff changeset
   804
	if (reason_node) {
306
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   805
		lm_verbose ("Stream error: XML not well formed\n");
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   806
		reason = LM_DISCONNECT_REASON_INVALID_XML;
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   807
		return;
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   808
	}
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   809
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   810
	lm_verbose ("Stream error: Unrecognised error\n");
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   811
	reason = LM_DISCONNECT_REASON_ERROR;
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   812
	connection->stream_id = g_strdup (lm_message_node_get_attribute (m->node,
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   813
									 "id"));;
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   814
	connection_do_close (connection);
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   815
	connection_signal_disconnect (connection, reason);
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   816
}
d466fc30829f Added disconnect error for resource conflict. Fixes LM-55.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 297
diff changeset
   817
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   818
static gint
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   819
connection_handler_compare_func (HandlerData *a, HandlerData *b)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   820
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   821
	return b->priority - a->priority;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   822
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   823
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   824
static void
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   825
connection_signal_disconnect (LmConnection       *connection,
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   826
			      LmDisconnectReason  reason)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   827
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   828
	if (connection->disconnect_cb && connection->disconnect_cb->func) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   829
		LmCallback *cb = connection->disconnect_cb;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   830
		
284
5f82151c42ea temporarily reference connection while calling disconnect callback, so that it's safe for the callback to unref the connection
Dafydd Harries <daf@rhydd.org>
parents: 281
diff changeset
   831
		lm_connection_ref (connection);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   832
		(* ((LmDisconnectFunction) cb->func)) (connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   833
						       reason,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   834
						       cb->user_data);
284
5f82151c42ea temporarily reference connection while calling disconnect callback, so that it's safe for the callback to unref the connection
Dafydd Harries <daf@rhydd.org>
parents: 281
diff changeset
   835
		lm_connection_unref (connection);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   836
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   837
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
   838
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   839
static void
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   840
connection_incoming_data (LmSocket     *socket, 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   841
			  const gchar  *buf, 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   842
			  LmConnection *connection)
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   843
{
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   844
	lm_parser_parse (connection->parser, buf);
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   845
}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   846
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   847
static void
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   848
connection_socket_closed_cb (LmSocket        *socket,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   849
			     LmDisconnectReason reason,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   850
			     LmConnection       *connection)
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   851
{
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   852
	connection_do_close (connection);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   853
	connection_signal_disconnect (connection, reason);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   854
}
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   855
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   856
static void
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   857
connection_socket_connect_cb (LmSocket           *socket,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   858
			      gboolean            result,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   859
			      LmConnection       *connection)
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   860
{
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   861
	if (!result) {
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   862
		connection_do_close (connection);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   863
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   864
		if (connection->open_cb) {
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   865
			LmCallback *cb = connection->open_cb;
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   866
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   867
			connection->open_cb = NULL;
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   868
			
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   869
			(* ((LmResultFunction) cb->func)) (connection, FALSE,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   870
							   cb->user_data);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   871
			_lm_utils_free_callback (cb);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   872
		}
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   873
	
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   874
		return;
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   875
	}
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   876
	
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   877
	/* FIXME: Set up according to XMPP 1.0 specification */
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   878
	/*        StartTLS and the like */
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   879
	if (!connection_send (connection, 
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   880
			      "<?xml version='1.0' encoding='UTF-8'?>", -1,
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   881
			      NULL)) {
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   882
		lm_verbose ("Failed to send xml version and encoding\n");
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   883
		connection_do_close (connection);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   884
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   885
		return;
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   886
	}
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   887
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   888
	connection_send_stream_header (connection);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   889
}
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   890
245
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   891
static gboolean
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   892
connection_get_server_from_jid (const gchar     *jid,
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   893
				gchar          **server)
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   894
{
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   895
	gchar *ch;
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   896
	gchar *ch_end;
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   897
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   898
	if (jid != NULL && (ch = strchr (jid, '@')) != NULL) {
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   899
		ch_end = strchr(ch + 1, '/');
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   900
		if (ch_end != NULL) {
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   901
			*server = g_strndup (ch + 1, ch_end - ch - 1);
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   902
		} else {
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   903
			*server = g_strdup (ch + 1);
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   904
		}
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   905
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   906
		return TRUE;
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   907
	} 
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   908
	
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   909
	return FALSE;
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   910
}
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
   911
248
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   912
static void
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   913
connection_send_stream_header (LmConnection *connection)
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   914
{
247
a519eff901e6 Slight code refactoring in _lm_connection_socket_result
Mikael Hallendal <micke@imendio.com>
parents: 245
diff changeset
   915
	LmMessage *m;
a519eff901e6 Slight code refactoring in _lm_connection_socket_result
Mikael Hallendal <micke@imendio.com>
parents: 245
diff changeset
   916
	gchar     *server_from_jid;
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   917
248
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   918
	lm_verbose ("Sending stream header\n");
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   919
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   920
	if (!connection_get_server_from_jid (connection->jid, &server_from_jid)) {
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   921
		server_from_jid = g_strdup (connection->server);
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   922
	}
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   923
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   924
	m = lm_message_new (server_from_jid, LM_MESSAGE_TYPE_STREAM);
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   925
	lm_message_node_set_attributes (m->node,
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   926
					"xmlns:stream", 
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   927
					"http://etherx.jabber.org/streams",
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   928
					"xmlns", "jabber:client",
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   929
					"version", "1.0",
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   930
					NULL);
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   931
	
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   932
	g_free (server_from_jid);
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   933
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   934
	if (!lm_connection_send (connection, m, NULL)) {
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   935
		lm_verbose ("Failed to send stream information\n");
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
   936
		connection_do_close (connection);
248
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   937
	}
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   938
		
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   939
	lm_message_unref (m);
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   940
}
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
   941
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   942
gboolean 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   943
_lm_connection_async_connect_waiting (LmConnection *connection)
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   944
{
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   945
	return connection->async_connect_waiting;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   946
}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   947
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   948
void
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   949
_lm_connection_set_async_connect_waiting (LmConnection *connection,
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   950
					  gboolean      waiting)
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   951
{
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   952
	connection->async_connect_waiting = waiting;
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   953
}
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
   954
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   955
static void
222
ca97251ddee8 Renamed internal functions to conform to code style.
Mikael Hallendal <micke@imendio.com>
parents: 221
diff changeset
   956
connection_call_auth_cb (LmConnection *connection, gboolean success)
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   957
{
226
5a31f474b9fd Update the connection state after SASL authentication result.
Mikael Hallendal <micke@imendio.com>
parents: 223
diff changeset
   958
	if (success) {
5a31f474b9fd Update the connection state after SASL authentication result.
Mikael Hallendal <micke@imendio.com>
parents: 223
diff changeset
   959
		connection->state = LM_CONNECTION_STATE_AUTHENTICATED;
5a31f474b9fd Update the connection state after SASL authentication result.
Mikael Hallendal <micke@imendio.com>
parents: 223
diff changeset
   960
	} else {
5a31f474b9fd Update the connection state after SASL authentication result.
Mikael Hallendal <micke@imendio.com>
parents: 223
diff changeset
   961
		connection->state = LM_CONNECTION_STATE_OPEN;
5a31f474b9fd Update the connection state after SASL authentication result.
Mikael Hallendal <micke@imendio.com>
parents: 223
diff changeset
   962
	}
5a31f474b9fd Update the connection state after SASL authentication result.
Mikael Hallendal <micke@imendio.com>
parents: 223
diff changeset
   963
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   964
	if (connection->auth_cb) {
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   965
	        LmCallback *cb = connection->auth_cb;
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   966
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   967
		connection->auth_cb = NULL;
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   968
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   969
		if (cb->func) {
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   970
	    		(* ((LmResultFunction) cb->func)) (connection, 
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   971
						           success,
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   972
							   cb->user_data);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   973
		}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   974
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   975
		_lm_utils_free_callback (cb);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   976
	}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   977
}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   978
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   979
static LmHandlerResult
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   980
connection_bind_reply (LmMessageHandler *handler,
255
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
   981
			LmConnection    *connection,
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
   982
			LmMessage       *message,
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
   983
			gpointer         user_data)
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   984
{
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
   985
	LmMessage        *m;
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
   986
	LmMessageNode    *session_node;
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
   987
	LmMessageNode    *jid_node;
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
   988
	int               result;
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
   989
	LmMessageSubType  type;
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   990
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   991
	type = lm_message_get_sub_type (message);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   992
	if (type == LM_MESSAGE_SUB_TYPE_ERROR) {
340
ce4dcda8797c Added new line for g_log printouts
Mikael Hallendal <micke@imendio.com>
parents: 339
diff changeset
   993
		g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_SASL, 
ce4dcda8797c Added new line for g_log printouts
Mikael Hallendal <micke@imendio.com>
parents: 339
diff changeset
   994
		       "%s: error while binding to resource\n", G_STRFUNC);
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
   995
	
222
ca97251ddee8 Renamed internal functions to conform to code style.
Mikael Hallendal <micke@imendio.com>
parents: 221
diff changeset
   996
		connection_call_auth_cb (connection, FALSE);
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
   997
		
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   998
		return LM_HANDLER_RESULT_REMOVE_MESSAGE;
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
   999
	}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1000
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1001
	/* use whatever server returns as our effective jid */
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1002
	jid_node = lm_message_node_find_child (message->node, "jid");
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1003
	if (jid_node) {
307
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1004
		g_free (connection->effective_jid);
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1005
		connection->effective_jid = g_strdup
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1006
			(lm_message_node_get_value (jid_node));
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1007
	}
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1008
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1009
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1010
	m = lm_message_new_with_sub_type (NULL,
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1011
					  LM_MESSAGE_TYPE_IQ, 
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1012
					  LM_MESSAGE_SUB_TYPE_SET);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1013
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1014
	session_node = lm_message_node_add_child (m->node, "session", NULL);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1015
	lm_message_node_set_attributes (session_node,
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1016
					"xmlns", XMPP_NS_SESSION,
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1017
					NULL);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1018
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1019
	result = lm_connection_send (connection, m, NULL);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1020
	lm_message_unref (m);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1021
	if (result < 0) {
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
  1022
		connection_do_close (connection);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1023
	}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1024
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1025
	/* We may finally tell the client they're authorized */
222
ca97251ddee8 Renamed internal functions to conform to code style.
Mikael Hallendal <micke@imendio.com>
parents: 221
diff changeset
  1026
	connection_call_auth_cb (connection, TRUE);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1027
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1028
	return LM_HANDLER_RESULT_REMOVE_MESSAGE;
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1029
}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1030
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1031
static LmHandlerResult
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
  1032
connection_features_cb (LmMessageHandler *handler,
255
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
  1033
			    LmConnection     *connection,
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
  1034
			    LmMessage        *message,
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
  1035
			    gpointer          user_data)
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1036
{
255
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
  1037
	LmMessageNode *bind_node;
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
  1038
	LmMessageNode    *starttls_node;
332
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1039
	LmMessageNode *old_auth;
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1040
	
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
  1041
	starttls_node = lm_message_node_find_child (message->node, "starttls");
289
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1042
	if (connection->ssl && lm_ssl_get_use_starttls (connection->ssl)) {
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1043
		if (starttls_node) {
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1044
			LmMessage        *msg;
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
  1045
289
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1046
			msg = lm_message_new (NULL, LM_MESSAGE_TYPE_STARTTLS);
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
  1047
289
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1048
			lm_message_node_set_attributes (
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1049
				msg->node,
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1050
				"xmlns", XMPP_NS_STARTTLS,
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1051
				NULL);
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
  1052
289
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1053
			lm_connection_send (connection, msg, NULL);
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1054
			lm_message_unref (msg);
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
  1055
289
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1056
			return LM_HANDLER_RESULT_REMOVE_MESSAGE;
317
e7ceb196a573 Don't require StartTLS after it's already been started.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 316
diff changeset
  1057
		} else if (!connection->tls_started &&
e7ceb196a573 Don't require StartTLS after it's already been started.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 316
diff changeset
  1058
				lm_ssl_get_require_starttls (connection->ssl)) {
289
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1059
			/* If there were no starttls features present and we require it, this is
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1060
			 * the place to scream. */
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
  1061
340
ce4dcda8797c Added new line for g_log printouts
Mikael Hallendal <micke@imendio.com>
parents: 339
diff changeset
  1062
			g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_SASL, 
ce4dcda8797c Added new line for g_log printouts
Mikael Hallendal <micke@imendio.com>
parents: 339
diff changeset
  1063
			       "%s: required StartTLS feature not supported by server\n", G_STRFUNC);
289
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1064
			connection_do_close (connection);
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1065
			connection_signal_disconnect (connection,
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1066
				LM_DISCONNECT_REASON_ERROR);
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1067
			return LM_HANDLER_RESULT_REMOVE_MESSAGE;
839adca0d863 LmConnection: take starttls settings from LmSSL object
Dafydd Harries <daf@rhydd.org>
parents: 288
diff changeset
  1068
		}
274
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
  1069
	}
c32a7011e435 Adding StartTLS support.
Senko Rasic <senko@phyrexia.(none)>
parents: 271
diff changeset
  1070
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1071
	bind_node = lm_message_node_find_child (message->node, "bind");
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1072
	if (bind_node) {
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1073
		LmMessageHandler *bind_handler;
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1074
		LmMessage        *bind_msg;
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1075
		const gchar      *ns;
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1076
		int               result;
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1077
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1078
		ns = lm_message_node_get_attribute (bind_node, "xmlns");
220
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
  1079
		if (!ns || strcmp (ns, XMPP_NS_BIND) != 0) {
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1080
			return LM_HANDLER_RESULT_ALLOW_MORE_HANDLERS;
220
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
  1081
		}
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1082
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1083
		bind_msg = lm_message_new_with_sub_type (NULL,
220
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
  1084
							 LM_MESSAGE_TYPE_IQ, 
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
  1085
							 LM_MESSAGE_SUB_TYPE_SET);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1086
220
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
  1087
		bind_node = lm_message_node_add_child (bind_msg->node, 
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
  1088
						       "bind", NULL);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1089
		lm_message_node_set_attributes (bind_node,
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1090
						"xmlns", XMPP_NS_BIND,
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1091
						NULL);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1092
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1093
		lm_message_node_add_child (bind_node, "resource",
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1094
					   connection->resource);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1095
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1096
		bind_handler = lm_message_handler_new (connection_bind_reply,
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1097
						       NULL, NULL);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1098
		result = lm_connection_send_with_reply (connection, bind_msg, 
223
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1099
							bind_handler, NULL);
b343ed8b3fea More style fixes to the SASL patch
Mikael Hallendal <micke@imendio.com>
parents: 222
diff changeset
  1100
		lm_message_handler_unref (bind_handler);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1101
		lm_message_unref (bind_msg);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1102
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1103
		if (result < 0) {
339
b1e0d0551a8c Use g_log instead of g_debug for debug output.
Mikael Hallendal <micke@imendio.com>
parents: 338
diff changeset
  1104
			g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_SASL, 
340
ce4dcda8797c Added new line for g_log printouts
Mikael Hallendal <micke@imendio.com>
parents: 339
diff changeset
  1105
			       "%s: can't send resource binding request\n", G_STRFUNC);
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
  1106
			connection_do_close (connection);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1107
		}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1108
	}
220
f6b9482ae89e Some style fixes to the SASL patch.
Mikael Hallendal <micke@imendio.com>
parents: 219
diff changeset
  1109
332
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1110
	old_auth = lm_message_node_find_child (message->node, "auth");
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1111
	if (connection->use_sasl && old_auth) {
340
ce4dcda8797c Added new line for g_log printouts
Mikael Hallendal <micke@imendio.com>
parents: 339
diff changeset
  1112
		g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_SASL, 
ce4dcda8797c Added new line for g_log printouts
Mikael Hallendal <micke@imendio.com>
parents: 339
diff changeset
  1113
		       "Server uses XEP-0078 (jabber iq auth) instead of SASL\n");
332
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1114
		/* So the server is XMPP1.0, but doesn't support SASL and uses
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1115
		 * obsolete XEP-0078 instead. Let's cope. */
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1116
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1117
		connection->use_sasl = FALSE;
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1118
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1119
		if (connection->sasl) {
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1120
			const gchar *user, *pass;
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1121
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1122
			lm_sasl_get_auth_params (connection->sasl, &user, &pass);
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1123
			if (user && pass) {
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1124
				GError *error = NULL;
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1125
				_lm_connection_old_auth (connection, user, pass,
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1126
					connection->resource, &error);
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1127
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1128
				if (error)
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1129
					g_error_free (error);
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1130
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1131
			}
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1132
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1133
			lm_sasl_free (connection->sasl);
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1134
			connection->sasl = NULL;
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1135
		}
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1136
	}
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1137
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1138
	return LM_HANDLER_RESULT_ALLOW_MORE_HANDLERS;
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1139
}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1140
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1141
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1142
 * lm_connection_new:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1143
 * @server: The hostname to the server for the connection.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1144
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1145
 * Creates a new closed connection. To open the connection call 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1146
 * lm_connection_open(). @server can be #NULL but must be set before calling lm_connection_open().
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1147
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1148
 * Return value: A newly created LmConnection, should be unreffed with lm_connection_unref().
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1149
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1150
LmConnection *
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1151
lm_connection_new (const gchar *server)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1152
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1153
	LmConnection *connection;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1154
	gint          i;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1155
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1156
	lm_debug_init ();
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
  1157
	_lm_sock_library_init ();
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
  1158
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1159
	connection = g_new0 (LmConnection, 1);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1160
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1161
	if (server) {
245
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
  1162
		connection->server  = _lm_utils_hostname_to_punycode (server);
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
  1163
		connection->use_srv = FALSE;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1164
	} else {
245
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
  1165
		connection->server  = NULL;
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
  1166
		connection->use_srv = TRUE;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1167
	}
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1168
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1169
	connection->context           = NULL;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1170
	connection->port              = LM_CONNECTION_DEFAULT_PORT;
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1171
	connection->jid               = NULL;
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1172
	connection->effective_jid     = NULL;
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1173
	connection->ssl               = NULL;
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1174
	connection->proxy             = NULL;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1175
	connection->disconnect_cb     = NULL;
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1176
	connection->queue             = lm_message_queue_new ((LmMessageQueueCallback) connection_message_queue_cb, 
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1177
							      connection);
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1178
	connection->cancel_open       = FALSE;
91
d51b8e4f43d9 2004-08-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 90
diff changeset
  1179
	connection->state             = LM_CONNECTION_STATE_CLOSED;
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1180
	connection->keep_alive_source = NULL;
93
903382d1c95d 2004-08-30 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 91
diff changeset
  1181
	connection->keep_alive_rate   = 0;
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1182
	connection->socket            = NULL;
332
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1183
	connection->use_sasl          = FALSE;
317
e7ceb196a573 Don't require StartTLS after it's already been started.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 316
diff changeset
  1184
	connection->tls_started       = FALSE;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1185
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1186
	connection->id_handlers = g_hash_table_new_full (g_str_hash, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1187
							 g_str_equal,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1188
							 g_free, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1189
							 (GDestroyNotify) lm_message_handler_unref);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1190
	connection->ref_count         = 1;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1191
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1192
	for (i = 0; i < LM_MESSAGE_TYPE_UNKNOWN; ++i) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1193
		connection->handlers[i] = NULL;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1194
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1195
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1196
	connection->parser = lm_parser_new 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1197
		((LmParserMessageFunction) connection_new_message_cb, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1198
		 connection, NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1199
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1200
	return connection;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1201
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1202
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1203
/**
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1204
 * lm_connection_new_with_context:
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1205
 * @server: The hostname to the server for the connection.
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1206
 * @context: The context this connection should be running in.
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1207
 * 
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1208
 * Creates a new closed connection running in a certain context. To open the 
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1209
 * connection call #lm_connection_open. @server can be #NULL but must be set 
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1210
 * before calling #lm_connection_open.
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1211
 * 
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1212
 * Return value: A newly created LmConnection, should be unreffed with lm_connection_unref().
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1213
 **/
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1214
LmConnection *
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1215
lm_connection_new_with_context (const gchar *server, GMainContext *context)
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1216
{
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1217
	LmConnection *connection;
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1218
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1219
	connection = lm_connection_new (server);
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1220
	connection->context = context;
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1221
168
ac1affcd5d22 2006-09-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 156
diff changeset
  1222
	if (context) {
ac1affcd5d22 2006-09-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 156
diff changeset
  1223
        	g_main_context_ref (connection->context);
ac1affcd5d22 2006-09-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 156
diff changeset
  1224
	}
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1225
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1226
	return connection;
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1227
}
63
7b8d0db459ff 2004-01-05 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 62
diff changeset
  1228
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1229
/**
62
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1230
 * lm_connection_open:
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1231
 * @connection: #LmConnection to open
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1232
 * @function: Callback function that will be called when the connection is open.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1233
 * @user_data: User data that will be passed to @function.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1234
 * @notify: Function for freeing that user_data, can be NULL.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1235
 * @error: location to store error, or %NULL
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1236
 * 
62
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1237
 * An async call to open @connection. When the connection is open @function will be called.
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1238
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1239
 * Return value: #TRUE if everything went fine, otherwise #FALSE.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1240
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1241
gboolean
62
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1242
lm_connection_open (LmConnection      *connection, 
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1243
		    LmResultFunction   function,
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1244
		    gpointer           user_data,
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1245
		    GDestroyNotify     notify,
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1246
		    GError           **error)
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1247
{
63
7b8d0db459ff 2004-01-05 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 62
diff changeset
  1248
	g_return_val_if_fail (connection != NULL, FALSE);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1249
	
63
7b8d0db459ff 2004-01-05 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 62
diff changeset
  1250
	connection->open_cb = _lm_utils_new_callback (function, 
7b8d0db459ff 2004-01-05 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 62
diff changeset
  1251
						      user_data, notify);
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
  1252
	connection->blocking = FALSE;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1253
64
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1254
	return connection_do_open (connection, error);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1255
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1256
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1257
/**
62
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1258
 * lm_connection_open_and_block:
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1259
 * @connection: an #LmConnection to open
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1260
 * @error: location to store error, or %NULL
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1261
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1262
 * Opens @connection and waits until the stream is setup. 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1263
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1264
 * Return value: #TRUE if no errors where encountered during opening and stream setup successfully, #FALSE otherwise.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1265
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1266
gboolean
62
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1267
lm_connection_open_and_block (LmConnection *connection, GError **error)
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1268
{
64
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1269
	gboolean          result;
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1270
	LmConnectionState state;
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1271
	
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1272
	g_return_val_if_fail (connection != NULL, FALSE);
57
6b168a8917f7 2003-12-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 56
diff changeset
  1273
63
7b8d0db459ff 2004-01-05 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 62
diff changeset
  1274
	connection->open_cb = NULL;
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
  1275
	connection->blocking = TRUE;
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
  1276
64
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1277
	result = connection_do_open (connection, error);
63
7b8d0db459ff 2004-01-05 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 62
diff changeset
  1278
7b8d0db459ff 2004-01-05 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 62
diff changeset
  1279
	if (result == FALSE) {
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1280
		return FALSE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1281
	}
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
  1282
		
91
d51b8e4f43d9 2004-08-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 90
diff changeset
  1283
	while ((state = lm_connection_get_state (connection)) == LM_CONNECTION_STATE_OPENING) {
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1284
		if (g_main_context_pending (connection->context)) {
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1285
			g_main_context_iteration (connection->context, TRUE);
64
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1286
		} else {
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
  1287
			/* Sleep for 1 millisecond */
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
  1288
			g_usleep (1000);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1289
		}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1290
	}
64
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1291
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1292
	if (lm_connection_is_open (connection)) {
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1293
		connection_start_keep_alive (connection);
64
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1294
		return TRUE;
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1295
	}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1296
132
8c9c1629f691 2006-03-20 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 130
diff changeset
  1297
	/* Need to set the error here: LM-15 */
8c9c1629f691 2006-03-20 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 130
diff changeset
  1298
	g_set_error (error,
8c9c1629f691 2006-03-20 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 130
diff changeset
  1299
		     LM_ERROR,
8c9c1629f691 2006-03-20 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 130
diff changeset
  1300
		     LM_ERROR_CONNECTION_FAILED,
8c9c1629f691 2006-03-20 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 130
diff changeset
  1301
		     "Opening the connection failed");
8c9c1629f691 2006-03-20 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 130
diff changeset
  1302
64
dd835d5cee71 2004-01-06 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 63
diff changeset
  1303
	return FALSE;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1304
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1305
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1306
/**
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1307
 * lm_connection_cancel_open:
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1308
 * @connection: an #LmConnection to cancel opening on
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1309
 *
91
d51b8e4f43d9 2004-08-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 90
diff changeset
  1310
 * Cancels the open operation of a connection. The connection should be in the state #LM_CONNECTION_STATE_OPENING.
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1311
 **/
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1312
void
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1313
lm_connection_cancel_open (LmConnection *connection)
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1314
{
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1315
	g_return_if_fail (connection != NULL);
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1316
211
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
  1317
	if (connection->open_cb) {
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
  1318
		_lm_utils_free_callback (connection->open_cb);
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
  1319
		connection->open_cb = NULL;
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
  1320
	}
efbf2da5e443 Added checks when freeing proxy and closing socket. Also free open_cb in cancel_open.
Mikael Hallendal <micke@imendio.com>
parents: 210
diff changeset
  1321
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1322
	connection->cancel_open = TRUE;
271
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
  1323
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
  1324
#ifdef HAVE_ASYNCNS
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
  1325
	_asyncns_cancel(connection->socket);
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
  1326
#endif
57
6b168a8917f7 2003-12-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 56
diff changeset
  1327
}
6b168a8917f7 2003-12-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 56
diff changeset
  1328
6b168a8917f7 2003-12-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 56
diff changeset
  1329
/**
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1330
 * lm_connection_close:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1331
 * @connection: #LmConnection to close 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1332
 * @error: location to store error, or %NULL
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1333
 * 
56
3bf928955fc5 2003-11-20 Ross Burton <ross@burtonini.com>
hallski <hallski>
parents: 55
diff changeset
  1334
 * A synchronous call to close the connection. When returning the connection is considered to be closed and can be opened again with lm_connection_open().
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1335
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1336
 * Return value: Returns #TRUE if no errors where detected, otherwise #FALSE.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1337
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1338
gboolean
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1339
lm_connection_close (LmConnection      *connection, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1340
		     GError           **error)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1341
{
156
8c054d9e98b8 2006-06-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 155
diff changeset
  1342
	gboolean no_errors = TRUE;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1343
	
156
8c054d9e98b8 2006-06-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 155
diff changeset
  1344
	g_return_val_if_fail (connection != NULL, FALSE);
8c054d9e98b8 2006-06-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 155
diff changeset
  1345
271
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
  1346
#ifdef HAVE_ASYNCNS
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
  1347
	_asyncns_cancel (connection->socket);
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
  1348
#endif
52ea4e0b897a Perform name resolution asynchronously. Patch by Senko Rašić.
Dafydd Harries <daf@rhydd.org>
parents: 256
diff changeset
  1349
156
8c054d9e98b8 2006-06-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 155
diff changeset
  1350
	if (connection->state == LM_CONNECTION_STATE_CLOSED) {
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1351
		g_set_error (error,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1352
			     LM_ERROR,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1353
			     LM_ERROR_CONNECTION_NOT_OPEN,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1354
			     "Connection is not open, call lm_connection_open() first");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1355
		return FALSE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1356
	}
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1357
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1358
	lm_verbose ("Disconnecting from: %s:%d\n", 
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1359
		    connection->server, connection->port);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1360
	
156
8c054d9e98b8 2006-06-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 155
diff changeset
  1361
	if (lm_connection_is_open (connection)) {
8c054d9e98b8 2006-06-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 155
diff changeset
  1362
		if (!connection_send (connection, "</stream:stream>", -1, error)) {
8c054d9e98b8 2006-06-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 155
diff changeset
  1363
			no_errors = FALSE;
8c054d9e98b8 2006-06-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 155
diff changeset
  1364
		}
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1365
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1366
		lm_socket_flush (connection->socket);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1367
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1368
	
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
  1369
	connection_do_close (connection);
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
  1370
	connection_signal_disconnect (connection, LM_DISCONNECT_REASON_OK);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1371
	
156
8c054d9e98b8 2006-06-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 155
diff changeset
  1372
	return no_errors;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1373
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1374
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1375
static void
222
ca97251ddee8 Renamed internal functions to conform to code style.
Mikael Hallendal <micke@imendio.com>
parents: 221
diff changeset
  1376
connection_sasl_auth_finished (LmSASL *sasl,
ca97251ddee8 Renamed internal functions to conform to code style.
Mikael Hallendal <micke@imendio.com>
parents: 221
diff changeset
  1377
			       LmConnection *connection,
ca97251ddee8 Renamed internal functions to conform to code style.
Mikael Hallendal <micke@imendio.com>
parents: 221
diff changeset
  1378
			       gboolean success,
ca97251ddee8 Renamed internal functions to conform to code style.
Mikael Hallendal <micke@imendio.com>
parents: 221
diff changeset
  1379
			       const gchar *reason)
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1380
{
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1381
	if (!success) {
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1382
		lm_verbose ("SASL authentication failed, closing connection\n");
222
ca97251ddee8 Renamed internal functions to conform to code style.
Mikael Hallendal <micke@imendio.com>
parents: 221
diff changeset
  1383
		connection_call_auth_cb (connection, FALSE);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1384
		return;
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1385
	}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1386
248
09a3e0e55ab8 Refactored sending of the stream header.
Mikael Hallendal <micke@imendio.com>
parents: 247
diff changeset
  1387
	connection_send_stream_header (connection);
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1388
}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1389
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1390
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1391
 * lm_connection_authenticate:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1392
 * @connection: #LmConnection to authenticate.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1393
 * @username: Username used to authenticate.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1394
 * @password: Password corresponding to @username.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1395
 * @resource: Resource used for this connection.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1396
 * @function: Callback called when authentication is finished.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1397
 * @user_data: Userdata passed to @function when called.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1398
 * @notify: Destroy function to free the memory used by @user_data, can be NULL.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1399
 * @error: location to store error, or %NULL
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1400
 * 
56
3bf928955fc5 2003-11-20 Ross Burton <ross@burtonini.com>
hallski <hallski>
parents: 55
diff changeset
  1401
 * Tries to authenticate a user against the server. The #LmResult in the result callback @function will say whether it succeeded or not. 
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1402
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1403
 * Return value: #TRUE if no errors where detected while sending the authentication message, #FALSE otherwise.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1404
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1405
gboolean
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1406
lm_connection_authenticate (LmConnection      *connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1407
			    const gchar       *username,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1408
			    const gchar       *password,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1409
			    const gchar       *resource,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1410
			    LmResultFunction   function,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1411
			    gpointer           user_data,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1412
			    GDestroyNotify     notify,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1413
			    GError           **error)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1414
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1415
	g_return_val_if_fail (connection != NULL, FALSE);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1416
	g_return_val_if_fail (username != NULL, FALSE);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1417
	g_return_val_if_fail (password != NULL, FALSE);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1418
	g_return_val_if_fail (resource != NULL, FALSE);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1419
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1420
	if (!lm_connection_is_open (connection)) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1421
		g_set_error (error,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1422
			     LM_ERROR,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1423
			     LM_ERROR_CONNECTION_NOT_OPEN,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1424
			     "Connection is not open, call lm_connection_open() first");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1425
		return FALSE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1426
	}
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1427
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1428
	connection->state = LM_CONNECTION_STATE_AUTHENTICATING;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1429
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1430
	connection->auth_cb = _lm_utils_new_callback (function, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1431
						      user_data, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1432
						      notify);
21
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1433
307
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1434
	connection->resource = g_strdup (resource);
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1435
	connection->effective_jid = g_strdup_printf ("%s/%s", 
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1436
		connection->jid, connection->resource);
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1437
332
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1438
	if (connection->use_sasl) {
255
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
  1439
		lm_sasl_authenticate (connection->sasl,
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
  1440
				      username, password,
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
  1441
				      connection->server,
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
  1442
				      connection_sasl_auth_finished);
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 249
diff changeset
  1443
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1444
		connection->features_cb  =
256
2266e56746ed Refactoring to clear up interface between LmSocket and LmConnection.
Mikael Hallendal <micke@imendio.com>
parents: 255
diff changeset
  1445
			lm_message_handler_new (connection_features_cb,
219
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1446
				NULL, NULL);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1447
		lm_connection_register_message_handler (connection,
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1448
			connection->features_cb,
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1449
			LM_MESSAGE_TYPE_STREAM_FEATURES,
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1450
			LM_HANDLER_PRIORITY_FIRST);
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1451
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1452
		return TRUE;
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1453
	}
6daf884bc7bd Added SASL-support to LmConnection, patch from Senko Rasic
Mikael Hallendal <micke@imendio.com>
parents: 211
diff changeset
  1454
332
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1455
	return _lm_connection_old_auth (connection, username, password,
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1456
		resource, error);
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1457
}
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1458
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1459
gboolean
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1460
_lm_connection_old_auth (LmConnection *connection, const gchar *username,
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1461
	const gchar *password, const gchar *resource, GError **error)
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1462
{
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1463
	LmMessage        *m;
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1464
	AuthReqData      *data;
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1465
	LmMessageHandler *handler;
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1466
	gboolean          result;
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1467
	
6b6ad42cd508 Support obsolete XEP-0078 (old-style jabber auth for XMPP1.0).
Senko Rasic <senko@phyrexia.lan>
parents: 329
diff changeset
  1468
21
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1469
	m = connection_create_auth_req_msg (username);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1470
		
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1471
	data = g_new0 (AuthReqData, 1);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1472
	data->username = g_strdup (username);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1473
	data->password = g_strdup (password);
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1474
	data->resource = g_strdup (resource);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1475
	
21
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1476
	handler = lm_message_handler_new (connection_auth_req_reply, 
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1477
					  data, 
091f3e5ec468 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 15
diff changeset
  1478
					  (GDestroyNotify) auth_req_data_free);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1479
	result = lm_connection_send_with_reply (connection, m, handler, error);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1480
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1481
	lm_message_handler_unref (handler);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1482
	lm_message_unref (m);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1483
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1484
	return result;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1485
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1486
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1487
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1488
 * lm_connection_authenticate_and_block:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1489
 * @connection: an #LmConnection
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1490
 * @username: Username used to authenticate.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1491
 * @password: Password corresponding to @username.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1492
 * @resource: Resource used for this connection.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1493
 * @error: location to store error, or %NULL
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1494
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1495
 * Tries to authenticate a user against the server. This function blocks until a reply to the authentication attempt is returned and returns whether it was successful or not.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1496
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1497
 * Return value: #TRUE if no errors where detected and authentication was successful. #FALSE otherwise.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1498
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1499
gboolean
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1500
lm_connection_authenticate_and_block (LmConnection  *connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1501
				      const gchar   *username,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1502
				      const gchar   *password,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1503
				      const gchar   *resource,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1504
				      GError       **error)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1505
{
323
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1506
	gboolean          result;
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1507
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1508
	result = lm_connection_authenticate (connection, username, password,
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1509
		resource, NULL, NULL, NULL, error);
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1510
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1511
	if (!result)
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1512
		return result;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1513
323
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1514
	while (lm_connection_get_state (connection) == LM_CONNECTION_STATE_AUTHENTICATING) {
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1515
		if (g_main_context_pending (connection->context)) {
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1516
			g_main_context_iteration (connection->context, TRUE);
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1517
		} else {
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1518
			/* Sleep for 1 millisecond */
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1519
			g_usleep (1000);
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1520
		}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1521
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1522
323
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1523
	switch (lm_connection_get_state (connection)) {
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1524
	case LM_CONNECTION_STATE_AUTHENTICATED:
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1525
		return TRUE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1526
		break;
323
64ea88f05696 Make lm_connection_authenticate_and_block reuse lm_connection_authenticate
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 320
diff changeset
  1527
	case LM_CONNECTION_STATE_OPEN:
54
eee846c76348 2003-11-11 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 47
diff changeset
  1528
		g_set_error (error,
eee846c76348 2003-11-11 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 47
diff changeset
  1529
			     LM_ERROR,
eee846c76348 2003-11-11 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 47
diff changeset
  1530
			     LM_ERROR_AUTH_FAILED,
eee846c76348 2003-11-11 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 47
diff changeset
  1531
			     "Authentication failed");
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1532
		return FALSE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1533
		break;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1534
	default:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1535
		g_assert_not_reached ();
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1536
		break;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1537
	} 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1538
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1539
	return FALSE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1540
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1541
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1542
/**
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1543
 * lm_connection_set_keep_alive_rate:
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1544
 * @connection: #LmConnection to check if it is open.
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1545
 * @rate: Number of seconds between keep alive packages are sent.
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1546
 * 
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1547
 * Set the keep alive rate, in seconds. Set to 0 to prevent keep alive messages to be sent.
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1548
 * A keep alive message is a single space character.
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1549
 **/
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1550
void
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1551
lm_connection_set_keep_alive_rate (LmConnection *connection, guint rate)
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1552
{
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1553
	g_return_if_fail (connection != NULL);
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1554
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1555
	connection_stop_keep_alive (connection);
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1556
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1557
	if (rate == 0) {
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1558
		connection->keep_alive_source = NULL;
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1559
		return;
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1560
	}
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1561
341
f44b206faf54 Fixed the keep alive rate when using TCP for handling keep alive. Fixes LM-121.
Mikael Hallendal <micke@imendio.com>
parents: 340
diff changeset
  1562
	connection->keep_alive_rate = rate;
90
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1563
	
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1564
	if (lm_connection_is_open (connection)) {
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1565
		connection_start_keep_alive (connection);
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1566
	}
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1567
}
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1568
3f4b38614416 2004-08-25 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 89
diff changeset
  1569
/**
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1570
 * lm_connection_is_open:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1571
 * @connection: #LmConnection to check if it is open.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1572
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1573
 * Check if the @connection is currently open.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1574
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1575
 * Return value: #TRUE if connection is open and #FALSE if it is closed.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1576
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1577
gboolean
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1578
lm_connection_is_open (LmConnection *connection)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1579
{
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1580
	g_return_val_if_fail (connection != NULL, FALSE);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1581
	
91
d51b8e4f43d9 2004-08-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 90
diff changeset
  1582
	return connection->state >= LM_CONNECTION_STATE_OPEN;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1583
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1584
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1585
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1586
 * lm_connection_is_authenticated:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1587
 * @connection: #LmConnection to check if it is authenticated
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1588
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1589
 * Check if @connection is authenticated.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1590
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1591
 * Return value: #TRUE if connection is authenticated, #FALSE otherwise.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1592
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1593
gboolean 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1594
lm_connection_is_authenticated (LmConnection *connection)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1595
{
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1596
	g_return_val_if_fail (connection != NULL, FALSE);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1597
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  1598
	return connection->state >= LM_CONNECTION_STATE_AUTHENTICATED;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1599
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1600
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1601
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1602
 * lm_connection_get_server:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1603
 * @connection: an #LmConnection
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1604
 * 
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1605
 * Fetches the server address that @connection is using. 
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1606
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1607
 * Return value: the server address
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1608
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1609
const gchar *
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1610
lm_connection_get_server (LmConnection *connection)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1611
{
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1612
	g_return_val_if_fail (connection != NULL, NULL);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1613
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1614
	return connection->server;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1615
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1616
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1617
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1618
 * lm_connection_set_server:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1619
 * @connection: an #LmConnection
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1620
 * @server: Address of the server
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1621
 * 
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1622
 * Sets the server address for @connection to @server. Notice that @connection
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1623
 * can't be open while doing this. 
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1624
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1625
void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1626
lm_connection_set_server (LmConnection *connection, const gchar *server)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1627
{
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1628
	g_return_if_fail (connection != NULL);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1629
	g_return_if_fail (server != NULL);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1630
	
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1631
	if (lm_connection_is_open (connection)) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1632
		g_warning ("Can't change server address while connected");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1633
		return;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1634
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1635
	
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1636
	g_free (connection->server);
155
d24c4392d4e3 2006-06-16 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 153
diff changeset
  1637
	connection->server = _lm_utils_hostname_to_punycode (server);
245
df2655dbe873 Make LmConnection accept not having a server set as long as JID is set.
Mikael Hallendal <micke@imendio.com>
parents: 244
diff changeset
  1638
	connection->use_srv = FALSE;
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1639
}
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1640
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1641
/**
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1642
 * lm_connection_get_jid:
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1643
 * @connection: an #LmConnection
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1644
 * 
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1645
 * Fetches the jid set for @connection is using. 
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1646
 * 
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1647
 * Return value: the jid
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1648
 **/
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1649
const gchar *
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1650
lm_connection_get_jid (LmConnection *connection)
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1651
{
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1652
	g_return_val_if_fail (connection != NULL, NULL);
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1653
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1654
	return connection->jid;
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1655
}
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1656
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1657
/**
307
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1658
 * lm_connection_get_full_jid:
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1659
 * @connection: an #LmConnection
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1660
 * 
307
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1661
 * Returns the full jid that server set for us after
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1662
 * resource binding, complete with the resource.
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1663
 *
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1664
 * Return value: the jid
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1665
 **/
307
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1666
gchar *
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1667
lm_connection_get_full_jid (LmConnection *connection)
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1668
{
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1669
	g_return_val_if_fail (connection != NULL, NULL);
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1670
307
f169e9281745 Rename lm_conn_get_effective_jid() to lm_conn_get_full_jid() to
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 306
diff changeset
  1671
	return connection->effective_jid;
297
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1672
}
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1673
f65eee8ec802 Support for returning effective JID, possibly changed by the server.
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 294
diff changeset
  1674
/**
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1675
 * lm_connection_set_jid:
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1676
 * @connection: an #LmConnection
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1677
 * @jid: JID to be used for @connection
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1678
 * 
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1679
 * Sets the JID to be used for @connection.
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1680
 **/
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1681
void 
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1682
lm_connection_set_jid (LmConnection *connection, const gchar *jid)
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1683
{
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1684
	g_return_if_fail (connection != NULL);
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1685
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1686
	if (lm_connection_is_open (connection)) {
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1687
		g_warning ("Can't change JID while connected");
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1688
		return;
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1689
	}
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1690
89
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1691
	g_free (connection->jid);
e756a937e540 2004-08-09 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 87
diff changeset
  1692
	connection->jid = g_strdup (jid);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1693
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1694
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1695
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1696
 * lm_connection_get_port:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1697
 * @connection: an #LmConnection
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1698
 * 
56
3bf928955fc5 2003-11-20 Ross Burton <ross@burtonini.com>
hallski <hallski>
parents: 55
diff changeset
  1699
 * Fetches the port that @connection is using.
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1700
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1701
 * Return value: 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1702
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1703
guint
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1704
lm_connection_get_port (LmConnection *connection)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1705
{
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1706
	g_return_val_if_fail (connection != NULL, 0);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1707
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1708
	return connection->port;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1709
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1710
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1711
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1712
 * lm_connection_set_port:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1713
 * @connection: an #LmConnection
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1714
 * @port: server port
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1715
 * 
56
3bf928955fc5 2003-11-20 Ross Burton <ross@burtonini.com>
hallski <hallski>
parents: 55
diff changeset
  1716
 * Sets the server port that @connection will be using.
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1717
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1718
void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1719
lm_connection_set_port (LmConnection *connection, guint port)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1720
{
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1721
	g_return_if_fail (connection != NULL);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1722
	
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1723
	if (lm_connection_is_open (connection)) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1724
		g_warning ("Can't change server port while connected");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1725
		return;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1726
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1727
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1728
	connection->port = port;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1729
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1730
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1731
/**
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1732
 * lm_connection_get_ssl: 
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1733
 * @connection: an #LmConnection
15
1ff2f81867e1 2003-07-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 12
diff changeset
  1734
 *
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1735
 * Returns the SSL struct if the connection is using one.
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1736
 * 
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1737
 * Return value: The ssl struct or %NULL if no proxy is used.
15
1ff2f81867e1 2003-07-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 12
diff changeset
  1738
 **/
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1739
LmSSL *
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1740
lm_connection_get_ssl (LmConnection *connection)
15
1ff2f81867e1 2003-07-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 12
diff changeset
  1741
{
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1742
	g_return_val_if_fail (connection != NULL, NULL);
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1743
	
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1744
	return connection->ssl;
15
1ff2f81867e1 2003-07-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 12
diff changeset
  1745
}
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1746
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1747
/**
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1748
 * lm_connection_set_ssl:
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1749
 * @connection: An #LmConnection
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1750
 * @ssl: An #LmSSL
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1751
 *
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1752
 * Sets SSL struct or unset if @ssl is %NULL. If set @connection will use SSL to for the connection.
62
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1753
 */
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1754
void
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1755
lm_connection_set_ssl (LmConnection *connection, LmSSL *ssl)
62
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1756
{
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1757
	g_return_if_fail (connection != NULL);
123
c1c7eb267b52 * loudmouth/lm-connection.c (lm_connection_set_ssl):
mr <mr>
parents: 121
diff changeset
  1758
	g_return_if_fail (lm_ssl_is_supported () == TRUE);
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1759
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1760
	if (connection->ssl) {
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1761
		lm_ssl_unref (connection->ssl);
62
39b83ccd70ff 2003-12-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 61
diff changeset
  1762
	}
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1763
68
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1764
	if (ssl) {
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1765
		connection->ssl = lm_ssl_ref (ssl);
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1766
	} else {
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1767
		connection->ssl = NULL;
28203e15de0e 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 67
diff changeset
  1768
	}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1769
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1770
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1771
/**
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1772
 * lm_connection_get_proxy: 
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1773
 * @connection: an #LmConnection
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1774
 *
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1775
 * Returns the proxy if the connection is using one.
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1776
 * 
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1777
 * Return value: The proxy or %NULL if no proxy is used.
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1778
 **/
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1779
LmProxy *
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1780
lm_connection_get_proxy (LmConnection *connection)
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1781
{
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1782
	g_return_val_if_fail (connection != NULL, NULL);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1783
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1784
	return connection->proxy;
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1785
} 
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1786
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1787
/**
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1788
 * lm_connection_set_proxy: 
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1789
 * @connection: an #LmConnection
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1790
 * @proxy: an #LmProxy
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1791
 *
94
85b606ac2c0c 2004-09-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 93
diff changeset
  1792
 * Sets the proxy to use for this connection. To unset pass #NULL.
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1793
 * 
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1794
 **/
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1795
void
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1796
lm_connection_set_proxy (LmConnection *connection, LmProxy *proxy)
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1797
{
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1798
	g_return_if_fail (connection != NULL);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1799
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1800
	if (lm_connection_is_open (connection)) {
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1801
		g_warning ("Can't change server proxy while connected");
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1802
		return;
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1803
	}
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1804
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1805
	if (connection->proxy) {
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1806
		lm_proxy_unref (connection->proxy);
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1807
		connection->proxy = NULL;
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1808
	}
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1809
94
85b606ac2c0c 2004-09-02 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 93
diff changeset
  1810
	if (proxy && lm_proxy_get_type (proxy) != LM_PROXY_TYPE_NONE) {
87
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1811
		connection->proxy = lm_proxy_ref (proxy);
2d68f59e3fd4 2004-08-08 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
  1812
	}
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1813
}
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1814
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1815
/**
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1816
 * lm_connection_send: 
56
3bf928955fc5 2003-11-20 Ross Burton <ross@burtonini.com>
hallski <hallski>
parents: 55
diff changeset
  1817
 * @connection: #LmConnection to send message over.
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1818
 * @message: #LmMessage to send.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1819
 * @error: location to store error, or %NULL
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1820
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1821
 * Asynchronous call to send a message.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1822
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1823
 * Return value: Returns #TRUE if no errors where detected while sending, #FALSE otherwise.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1824
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1825
gboolean
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1826
lm_connection_send (LmConnection  *connection, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1827
		    LmMessage     *message, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1828
		    GError       **error)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1829
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1830
	gchar    *xml_str;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1831
	gchar    *ch;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1832
	gboolean  result;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1833
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1834
	g_return_val_if_fail (connection != NULL, FALSE);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1835
	g_return_val_if_fail (message != NULL, FALSE);
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1836
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1837
	xml_str = lm_message_node_to_string (message->node);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1838
	if ((ch = strstr (xml_str, "</stream:stream>"))) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1839
		*ch = '\0';
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1840
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1841
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1842
	result = connection_send (connection, xml_str, -1, error);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1843
	g_free (xml_str);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1844
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1845
	return result;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1846
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1847
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1848
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1849
 * lm_connection_send_with_reply:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1850
 * @connection: #LmConnection used to send message.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1851
 * @message: #LmMessage to send.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1852
 * @handler: #LmMessageHandler that will be used when a reply to @message arrives
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1853
 * @error: location to store error, or %NULL
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1854
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1855
 * Send a #LmMessage which will result in a reply. 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1856
 * 
56
3bf928955fc5 2003-11-20 Ross Burton <ross@burtonini.com>
hallski <hallski>
parents: 55
diff changeset
  1857
 * Return value: Returns #TRUE if no errors where detected while sending, #FALSE otherwise.
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1858
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1859
gboolean 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1860
lm_connection_send_with_reply (LmConnection      *connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1861
			       LmMessage         *message,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1862
			       LmMessageHandler  *handler,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1863
			       GError           **error)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1864
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1865
	gchar *id;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1866
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1867
	g_return_val_if_fail (connection != NULL, FALSE);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1868
	g_return_val_if_fail (message != NULL, FALSE);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1869
	g_return_val_if_fail (handler != NULL, FALSE);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1870
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1871
	if (lm_message_node_get_attribute (message->node, "id")) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1872
		id = g_strdup (lm_message_node_get_attribute (message->node, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1873
							      "id"));
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1874
	} else {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1875
		id = _lm_utils_generate_id ();
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1876
		lm_message_node_set_attributes (message->node, "id", id, NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1877
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1878
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1879
	g_hash_table_insert (connection->id_handlers, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1880
			     id, lm_message_handler_ref (handler));
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1881
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1882
	return lm_connection_send (connection, message, error);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1883
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1884
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1885
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1886
 * lm_connection_send_with_reply_and_block:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1887
 * @connection: an #LmConnection
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1888
 * @message: an #LmMessage
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1889
 * @error: Set if error was detected during sending.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1890
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1891
 * Send @message and wait for return.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1892
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1893
 * Return value: The reply
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1894
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1895
LmMessage *
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1896
lm_connection_send_with_reply_and_block (LmConnection  *connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1897
					 LmMessage     *message,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1898
					 GError       **error)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1899
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1900
	gchar     *id;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1901
	LmMessage *reply = NULL;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1902
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1903
	g_return_val_if_fail (connection != NULL, NULL);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1904
	g_return_val_if_fail (message != NULL, NULL);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  1905
125
6163119136b5 2005-08-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 124
diff changeset
  1906
	if (connection->state < LM_CONNECTION_STATE_OPENING) {
6163119136b5 2005-08-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 124
diff changeset
  1907
		g_set_error (error,
6163119136b5 2005-08-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 124
diff changeset
  1908
			     LM_ERROR,
6163119136b5 2005-08-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 124
diff changeset
  1909
			     LM_ERROR_CONNECTION_NOT_OPEN,
6163119136b5 2005-08-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 124
diff changeset
  1910
			     "Connection is not open, call lm_connection_open() first");
6163119136b5 2005-08-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 124
diff changeset
  1911
		return FALSE;
6163119136b5 2005-08-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 124
diff changeset
  1912
	}
6163119136b5 2005-08-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 124
diff changeset
  1913
6163119136b5 2005-08-12 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 124
diff changeset
  1914
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1915
	if (lm_message_node_get_attribute (message->node, "id")) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1916
		id = g_strdup (lm_message_node_get_attribute (message->node, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1917
							      "id"));
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1918
	} else {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1919
		id = _lm_utils_generate_id ();
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1920
		lm_message_node_set_attributes (message->node, "id", id, NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1921
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1922
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1923
	lm_message_queue_detach (connection->queue);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1924
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1925
	lm_connection_send (connection, message, error);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1926
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1927
	while (!reply) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1928
		const gchar *m_id;
140
103227122f45 2006-04-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 137
diff changeset
  1929
		guint        n;
39
b909b5af5a97 2003-10-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 37
diff changeset
  1930
82
a32b54e654e2 2004-03-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 80
diff changeset
  1931
		g_main_context_iteration (connection->context, TRUE);
39
b909b5af5a97 2003-10-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 37
diff changeset
  1932
	
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1933
		if (lm_message_queue_is_empty (connection->queue)) {
39
b909b5af5a97 2003-10-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 37
diff changeset
  1934
			continue;
b909b5af5a97 2003-10-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 37
diff changeset
  1935
		}
b909b5af5a97 2003-10-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 37
diff changeset
  1936
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1937
		for (n = 0; n < lm_message_queue_get_length (connection->queue); n++) {
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1938
			LmMessage *m;
39
b909b5af5a97 2003-10-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 37
diff changeset
  1939
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1940
			m = (LmMessage *) lm_message_queue_peek_nth (connection->queue, n);
39
b909b5af5a97 2003-10-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 37
diff changeset
  1941
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1942
			m_id = lm_message_node_get_attribute (m->node, "id");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1943
			
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1944
			if (m_id && strcmp (m_id, id) == 0) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1945
				reply = m;
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1946
				lm_message_queue_pop_nth (connection->queue, n);
39
b909b5af5a97 2003-10-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 37
diff changeset
  1947
				break;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1948
			}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1949
		}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1950
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1951
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1952
	g_free (id);
196
209bfa124066 Imported LmConnection refactor from old repository.
Mikael Hallendal <micke@imendio.com>
parents: 187
diff changeset
  1953
	lm_message_queue_attach (connection->queue, connection->context);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1954
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1955
	return reply;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1956
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1957
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1958
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1959
 * lm_connection_register_message_handler:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1960
 * @connection: Connection to register a handler for.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1961
 * @handler: Message handler to register.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1962
 * @type: Message type that @handler will handle.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1963
 * @priority: The priority in which to call @handler.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1964
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1965
 * Registers a #LmMessageHandler to handle incoming messages of a certain type.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1966
 * To unregister the handler call lm_connection_unregister_message_handler().
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1967
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1968
void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1969
lm_connection_register_message_handler  (LmConnection       *connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1970
					 LmMessageHandler   *handler,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1971
					 LmMessageType       type,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1972
					 LmHandlerPriority   priority)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1973
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1974
	HandlerData      *hd;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1975
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1976
	g_return_if_fail (connection != NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1977
	g_return_if_fail (handler != NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1978
	g_return_if_fail (type != LM_MESSAGE_TYPE_UNKNOWN);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1979
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1980
	hd = g_new0 (HandlerData, 1);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1981
	hd->priority = priority;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1982
	hd->handler  = lm_message_handler_ref (handler);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1983
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1984
	connection->handlers[type] = g_slist_insert_sorted (connection->handlers[type],
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1985
							    hd, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1986
							    (GCompareFunc) connection_handler_compare_func);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1987
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1988
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1989
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1990
 * lm_connection_unregister_message_handler:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1991
 * @connection: Connection to unregister a handler for.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1992
 * @handler: The handler to unregister.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1993
 * @type: What type of messages to unregister this handler for.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1994
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1995
 * Unregisters a handler for @connection. @handler will no longer be called 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1996
 * when incoming messages of @type arrive.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1997
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1998
void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  1999
lm_connection_unregister_message_handler (LmConnection      *connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2000
					  LmMessageHandler  *handler,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2001
					  LmMessageType      type)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2002
{
207
6dd9dc2f6b69 Cleaned up lm_connection_unref_message_handler.
Mikael Hallendal <micke@imendio.com>
parents: 196
diff changeset
  2003
	GSList *l;
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2004
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2005
	g_return_if_fail (connection != NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2006
	g_return_if_fail (handler != NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2007
	g_return_if_fail (type != LM_MESSAGE_TYPE_UNKNOWN);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2008
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2009
	for (l = connection->handlers[type]; l; l = l->next) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2010
		HandlerData *hd = (HandlerData *) l->data;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2011
		
207
6dd9dc2f6b69 Cleaned up lm_connection_unref_message_handler.
Mikael Hallendal <micke@imendio.com>
parents: 196
diff changeset
  2012
		if (handler == hd->handler) {
6dd9dc2f6b69 Cleaned up lm_connection_unref_message_handler.
Mikael Hallendal <micke@imendio.com>
parents: 196
diff changeset
  2013
			connection->handlers[type] = g_slist_remove_link (connection->handlers[type], l);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2014
			g_slist_free (l);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2015
			lm_message_handler_unref (hd->handler);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2016
			g_free (hd);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2017
			break;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2018
		}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2019
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2020
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2021
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2022
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2023
 * lm_connection_set_disconnect_function:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2024
 * @connection: Connection to register disconnect callback for.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2025
 * @function: Function to be called when @connection is closed.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2026
 * @user_data: User data passed to @function.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2027
 * @notify: Function that will be called with @user_data when @user_data needs to be freed. Pass #NULL if it shouldn't be freed.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2028
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2029
 * Set the callback that will be called when a connection is closed. 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2030
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2031
void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2032
lm_connection_set_disconnect_function (LmConnection         *connection,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2033
				       LmDisconnectFunction  function,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2034
				       gpointer              user_data,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2035
				       GDestroyNotify        notify)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2036
{
66
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  2037
	g_return_if_fail (connection != NULL);
577d5059b718 2004-01-15 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 65
diff changeset
  2038
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2039
	if (connection->disconnect_cb) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2040
		_lm_utils_free_callback (connection->disconnect_cb);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2041
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2042
		
143
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
  2043
	if (function) {
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
  2044
		connection->disconnect_cb = _lm_utils_new_callback (function, 
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
  2045
	    					                    user_data,
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
  2046
							            notify);
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
  2047
	} else {
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
  2048
		connection->disconnect_cb = NULL;
92193c23b0c7 2006-05-26 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 140
diff changeset
  2049
	}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2050
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2051
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2052
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2053
 * lm_connection_send_raw:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2054
 * @connection: Connection used to send
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2055
 * @str: The string to send, the entire string will be sent.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2056
 * @error: Set if error was detected during sending.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2057
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2058
 * Asynchronous call to send a raw string. Useful for debugging and testing.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2059
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2060
 * Return value: Returns #TRUE if no errors was detected during sending, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2061
 * #FALSE otherwise.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2062
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2063
gboolean 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2064
lm_connection_send_raw (LmConnection  *connection, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2065
			const gchar   *str, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2066
			GError       **error)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2067
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2068
	g_return_val_if_fail (connection != NULL, FALSE);
168
ac1affcd5d22 2006-09-01 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 156
diff changeset
  2069
	g_return_val_if_fail (str != NULL, FALSE);
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2070
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2071
	return connection_send (connection, str, -1, error);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2072
}
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2073
/**
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2074
 * lm_connection_get_state:
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2075
 * @connection: Connection to get state on
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2076
 *
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2077
 * Returns the state of the connection.
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2078
 *
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2079
 * Return value: The state of the connection.
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2080
 **/
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2081
LmConnectionState 
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2082
lm_connection_get_state (LmConnection *connection)
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2083
{
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2084
	g_return_val_if_fail (connection != NULL, 
91
d51b8e4f43d9 2004-08-27 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 90
diff changeset
  2085
			      LM_CONNECTION_STATE_CLOSED);
59
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2086
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2087
	return connection->state;
ef952e8c114d 2003-12-19 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 57
diff changeset
  2088
}
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2089
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2090
/**
308
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2091
 * lm_connection_get_client_host:
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2092
 * @connection: An #LmConnection
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2093
 *
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2094
 * Returns the local host name of the connection.
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2095
 *
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2096
 * Return value: A newly allocated string representing the local host name.
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2097
 **/
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2098
gchar *
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2099
lm_connection_get_local_host (LmConnection *connection)
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2100
{
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2101
	return lm_socket_get_local_host (connection->socket);
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2102
}
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2103
7e2050a6df75 Added lm_connection_get_client_host (forward-port from LM1.2).
Senko Rasic <senko.rasic@collabora.co.uk>
parents: 307
diff changeset
  2104
/**
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2105
 * lm_connection_ref:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2106
 * @connection: Connection to add a reference to.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2107
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2108
 * Add a reference on @connection. To remove a reference call 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2109
 * lm_connection_unref().
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2110
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2111
 * Return value: Returns the same connection.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2112
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2113
LmConnection*
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2114
lm_connection_ref (LmConnection *connection)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2115
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2116
	g_return_val_if_fail (connection != NULL, NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2117
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2118
	connection->ref_count++;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2119
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2120
	return connection;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2121
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2122
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2123
/**
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2124
 * lm_connection_unref:
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2125
 * @connection: Connection to remove reference from.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2126
 * 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2127
 * Removes a reference on @connection. If there are no references to
56
3bf928955fc5 2003-11-20 Ross Burton <ross@burtonini.com>
hallski <hallski>
parents: 55
diff changeset
  2128
 * @connection it will be freed and shouldn't be used again.
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2129
 **/
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2130
void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2131
lm_connection_unref (LmConnection *connection)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2132
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2133
	g_return_if_fail (connection != NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2134
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2135
	connection->ref_count--;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2136
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2137
	if (connection->ref_count == 0) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2138
		connection_free (connection);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2139
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
  2140
}