forked from neomutt/neomutt
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmutt_socket.c
101 lines (93 loc) · 2.72 KB
/
mutt_socket.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/**
* @file
* NeoMutt connections
*
* @authors
* Copyright (C) 2000-2007 Brendan Cully <[email protected]>
*
* @copyright
* This program is free software: you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation, either version 2 of the License, or (at your option) any later
* version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* this program. If not, see <http://www.gnu.org/licenses/>.
*/
/**
* @page neo_mutt_socket NeoMutt connections
*
* NeoMutt connections
*/
#include "config.h"
#include <stdio.h>
#include <string.h>
#include "config/lib.h"
#include "email/lib.h"
#include "core/lib.h"
#include "conn/lib.h"
#include "mutt_socket.h"
#include "hook.h"
#include "mutt_account.h"
#ifndef USE_SSL
#include "mutt/lib.h"
#endif
/**
* mutt_conn_new - Create a new Connection
* @param cac Credentials to use
* @retval ptr New Connection
*/
struct Connection *mutt_conn_new(const struct ConnAccount *cac)
{
enum ConnectionType conn_type;
const char *const c_tunnel = cs_subset_string(NeoMutt->sub, "tunnel");
if (c_tunnel)
conn_type = MUTT_CONNECTION_TUNNEL;
else if (cac->flags & MUTT_ACCT_SSL)
conn_type = MUTT_CONNECTION_SSL;
else
conn_type = MUTT_CONNECTION_SIMPLE;
struct Connection *conn = mutt_socket_new(conn_type);
if (conn)
{
memcpy(&conn->account, cac, sizeof(struct ConnAccount));
}
else
{
if (conn_type == MUTT_CONNECTION_SSL)
{
#ifndef USE_SSL
/* that's probably why it failed */
mutt_error(_("SSL is unavailable, can't connect to %s"), cac->host);
#endif
}
}
return conn;
}
/**
* mutt_conn_find - Find a connection from a list
* @param cac ConnAccount to match
* @retval ptr Matching Connection
*
* find a connection off the list of connections whose account matches cac.
* If start is not null, only search for connections after the given connection
* (allows higher level socket code to make more fine-grained searches than
* account info. Eg in IMAP we may wish to find a connection which is not in
* IMAP_SELECTED state)
*/
struct Connection *mutt_conn_find(const struct ConnAccount *cac)
{
struct Url url = { 0 };
char hook[1024];
/* cac isn't actually modified, since url isn't either */
mutt_account_tourl((struct ConnAccount *) cac, &url);
url.path = NULL;
url_tostring(&url, hook, sizeof(hook), U_NO_FLAGS);
mutt_account_hook(hook);
return mutt_conn_new(cac);
}