annotate netinstall/nio-http.cc @ 4709:db7068430402

Add explicit GPL v2 or later notices to Bill Perry's code, where such notices are missing. This is done with Bill Perry's stated permission, in private email to me.
author Jerry James <james@xemacs.org>
date Mon, 05 Oct 2009 11:08:59 -0600
parents 3078fd1074e8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
448
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
1 /*
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
2 * Copyright (c) 2000, Red Hat, Inc.
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
3 *
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
4 * This program is free software; you can redistribute it and/or modify
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
5 * it under the terms of the GNU General Public License as published by
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
6 * the Free Software Foundation; either version 2 of the License, or
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
7 * (at your option) any later version.
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
8 *
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
9 * A copy of the GNU General Public License can be found at
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
10 * http://www.gnu.org/
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
11 *
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
12 * Written by DJ Delorie <dj@cygnus.com>
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
13 *
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
14 */
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
15
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
16 /* This file is responsible for implementing all direct HTTP protocol
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
17 channels. It is intentionally simplistic. */
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
18
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
19 #include "win32.h"
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
20 #include "winsock.h"
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
21 #include <stdio.h>
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
22 #include <stdlib.h>
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
23
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
24 #include "resource.h"
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
25 #include "state.h"
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
26 #include "simpsock.h"
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
27 #include "msg.h"
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
28
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
29 #include "netio.h"
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
30 #include "nio-http.h"
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
31
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
32 static char six2pr[64] = {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
33 'A','B','C','D','E','F','G','H','I','J','K','L','M',
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
34 'N','O','P','Q','R','S','T','U','V','W','X','Y','Z',
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
35 'a','b','c','d','e','f','g','h','i','j','k','l','m',
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
36 'n','o','p','q','r','s','t','u','v','w','x','y','z',
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
37 '0','1','2','3','4','5','6','7','8','9','+','/'
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
38 };
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
39
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
40 static char *
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
41 base64_encode (char *username, char *password)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
42 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
43 unsigned char *ep;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
44 char *rp;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
45 static char *rv = 0;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
46 if (rv)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
47 free (rv);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
48 rv = (char *) malloc (2 * (strlen (username) + strlen (password)) + 5);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
49
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
50 char *up = (char *) malloc (strlen (username) + strlen (password) + 6);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
51 strcpy (up, username);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
52 strcat (up, ":");
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
53 strcat (up, password);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
54 ep = (unsigned char *)up + strlen (up);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
55 *ep++ = 0;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
56 *ep++ = 0;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
57 *ep++ = 0;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
58
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
59 char block[4];
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
60
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
61 rp = rv;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
62
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
63 for (ep = (unsigned char *)up; *ep; ep += 3)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
64 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
65 block[0] = six2pr[ep[0] >> 2];
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
66 block[1] = six2pr[((ep[0] << 4) & 0x30) | ((ep[1] >> 4) & 0x0f)];
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
67 block[2] = six2pr[((ep[1] << 2) & 0x3c) | ((ep[2] >> 6) & 0x03)];
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
68 block[3] = six2pr[ep[2] & 0x3f];
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
69
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
70 if (ep[1] == 0)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
71 block[2] = block[3] = '=';
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
72 if (ep[2] == 0)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
73 block[3] = '=';
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
74 memcpy (rp, block, 4);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
75 rp += 4;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
76 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
77 *rp = 0;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
78
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
79 free (up);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
80
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
81 return rv;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
82 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
83
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
84 NetIO_HTTP::NetIO_HTTP (char *Purl)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
85 : NetIO (Purl)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
86 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
87 retry_get:
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
88 if (port == 0)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
89 port = 80;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
90
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
91 if (net_method == IDC_NET_PROXY)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
92 s = new SimpleSocket (net_proxy_host, net_proxy_port);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
93 else
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
94 s = new SimpleSocket (host, port);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
95
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
96 if (!s->ok())
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
97 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
98 s = 0;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
99 return;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
100 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
101
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
102 if (net_method == IDC_NET_PROXY)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
103 s->printf ("GET %s HTTP/1.0\r\n", url);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
104 else
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
105 s->printf ("GET %s HTTP/1.0\r\n", path);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
106 s->printf ("Host: %s:%d\r\n", host, port);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
107
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
108 if (net_user && net_passwd)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
109 s->printf ("Authorization: Basic %s\r\n",
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
110 base64_encode (net_user, net_passwd));
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
111
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
112 if (net_proxy_user && net_proxy_passwd)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
113 s->printf ("Proxy-Authorization: Basic %s\r\n",
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
114 base64_encode (net_proxy_user, net_proxy_passwd));
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
115
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
116 s->printf ("\r\n");
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
117
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
118 char *l = s->gets ();
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
119 int code;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
120 sscanf (l, "%*s %d", &code);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
121 if (code >= 300 && code < 400)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
122 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
123 do {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
124 l = s->gets ();
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
125 if (_strnicmp (l, "Location:", 9) == 0)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
126 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
127 char *u = l + 9;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
128 while (*u == ' ' || *u == '\t')
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
129 u++;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
130 set_url (u);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
131 delete s;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
132 goto retry_get;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
133 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
134 } while (*l);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
135 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
136 if (code == 401) /* authorization required */
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
137 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
138 get_auth ();
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
139 delete s;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
140 goto retry_get;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
141 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
142 if (code == 407) /* proxy authorization required */
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
143 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
144 get_proxy_auth ();
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
145 delete s;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
146 goto retry_get;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
147 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
148 if (code >= 300)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
149 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
150 delete s;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
151 s = 0;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
152 return;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
153 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
154 do {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
155 l = s->gets ();
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
156 if (_strnicmp (l, "Content-Length:", 15) == 0)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
157 sscanf (l, "%*s %d", &file_size);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
158 } while (*l);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
159 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
160
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
161 NetIO_HTTP::~NetIO_HTTP ()
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
162 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
163 if (s)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
164 delete s;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
165 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
166
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
167 int
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
168 NetIO_HTTP::ok ()
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
169 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
170 if (s)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
171 return 1;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
172 return 0;
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
173 }
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
174
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
175 int
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
176 NetIO_HTTP::read (char *buf, int nbytes)
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
177 {
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
178 return s->read (buf, nbytes);
3078fd1074e8 Import from CVS: tag r21-2-39
cvs
parents:
diff changeset
179 }