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 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
|
/*
* url.h - URL Processing (parsing & retrieval)
*
* Darren Hardy, hardy@cs.colorado.edu, April 1994
*
* $Id: url.h,v 1.2 2006/02/03 16:59:14 golda Exp $
*
* ----------------------------------------------------------------------
* Copyright (c) 1994, 1995. All rights reserved.
*
* Mic Bowman of Transarc Corporation.
* Peter Danzig of the University of Southern California.
* Darren R. Hardy of the University of Colorado at Boulder.
* Udi Manber of the University of Arizona.
* Michael F. Schwartz of the University of Colorado at Boulder.
*
*/
#ifndef _URL_H_
#define _URL_H_
#include "config.h"
#include <time.h>
/*
* The supported URLs look like:
*
* file://host/pathname
* gopher://host[:port][/TypeDigitGopherRequest]
* http://host[:port][/[pathname][#name][?search]]
* ftp://[user[:password]@]host[:port][/pathname]
*
* where host is either a fully qualified hostname, an IP number, or
* a relative hostname.
*
* For http, any '#name' or '?search' directives are ignored.
* For ftp, any user, password, or port directives are unsupported.
*/
struct url {
char *url; /* Complete, normalized URL */
int type; /* file, ftp, http, gopher, etc. */
char *raw_pathname; /* pathname portion of the URL, w/ escapes */
char *pathname; /* pathname portion of the URL, w/o escapes */
char *host; /* fully qualified hostname */
int port; /* TCP/IP port */
/* Information for FTP processing */
char *user; /* Login name for ftp */
char *password; /* password for ftp */
/* Information for Gopher processing */
int gophertype; /* Numeric type for gopher request */
/* Information for HTTP processing */
char *http_version; /* HTTP/1.0 Version */
int http_status_code; /* HTTP/1.0 Status Code */
char *http_reason_line; /* HTTP/1.0 Reason Line */
char *http_mime_hdr; /* HTTP/1.0 MIME Response Header */
/* Information for local copy processing */
char *filename; /* local filename */
FILE *fp; /* ptr to local filename */
time_t lmt; /* Last-Modification-Time */
#ifdef USE_MD5
char *md5; /* MD5 value of URL */
#endif
};
typedef struct url URL;
enum url_types { /* Constants for URL types */
URL_UNKNOWN,
URL_FILE,
URL_FTP,
URL_GOPHER,
URL_HTTP,
URL_NEWS,
URL_NOP,
URL_TELNET,
URL_WAIS
};
#ifndef _PARAMS
#define _PARAMS(ARGS) ARGS
#endif /* _PARAMS */
URL *url_open _PARAMS((char *));
int url_read _PARAMS((char *, int, int, URL *));
int url_retrieve _PARAMS((URL *));
void url_close _PARAMS((URL *));
void init_url _PARAMS(());
void finish_url _PARAMS(());
void url_purge _PARAMS(());
URL *dup_url _PARAMS((URL *));
void print_url _PARAMS((URL *));
int http_get _PARAMS((URL *));
int ftp_get _PARAMS((URL *));
int gopher_get _PARAMS((URL *));
#ifdef USE_LOCAL_CACHE
void init_cache _PARAMS(());
char *lookup_cache _PARAMS((char *));
time_t lmt_cache _PARAMS((char *));
void add_cache _PARAMS((char *, char *));
void finish_cache _PARAMS(());
void expire_cache _PARAMS(());
#endif
#ifdef USE_CCACHE
void url_initCache _PARAMS((int, long));
void url_shutdowncache _PARAMS(());
#endif
#endif /* _URL_H_ */
|