NAME
w3mir - all purpose HTTP-copying and mirroring tool
SYNOPSIS
w3mir [options] [HTTP-URL]
w3mir -B [options] <HTTP-URLS>
w3mir is a all purpose HTTP copying and mirroring tool. The main focus of w3mir is to create and maintain a browsable copy of one, or several, remote WWW site(s).
w3mir has options for all operations that are simple enough for options. For authentication and passwords, multiple site retrievals and such you will have to resort to a "CONFIGURATION-FILE"
w3mirs default behavior is to do as little as possible and to be as nice as possible to the server(s) it is getting documents from. You will need to read through the options list to make w3mir do more complex, and, useful things.
DESCRIPTION
You may specify many options and one HTTP-URL on the w3mir command line.
A single HTTP URL must be specified either on the command line or in a URL directive in a configuration file. If the URL refers to a directory it must end with a "/", otherwise you might get surprised at what gets retrieved (e.g. rather more than you expect).
Options must be prefixed with at least one - as shown below, you can use more if you want to. -cfgfile is equivalent to --cfgfile or even ------cfgfile. Options cannot be clustered, i.e., -r -R is not equivalent to -rR.
- -h | -help | -?
-
prints a brief summary of all command line options and exits.
- -cfgfile file
-
Makes w3mir read the given configuration file. See the next section for how to write such a file.
- -r
-
Puts w3mir into recursive mode. The default is to fetch only one document and then quit. 'recursive' mode means that all the documents linked to the given document that are fetched, and all they link to in turn and so on. But only Iff they are in the same directory or under the same directory as the start document. Any document that is in or under the starting documents directory is said to be within the scope of retrieval.
- -fa
-
Fetch All. Normally w3mir will only get the document if it has been updated since the last time it was fetched. This switch turns that check off.
- -fs
-
Fetch Some. Not the opposite of -fa, but rather, fetch the ones we don't have already. This is handy to restart copying of a site incompletely copied by earlier, interrupted, runs of w3mir.
- -p n
-
Pause for n seconds between getting each document. The default is 30 seconds.
- -rp n
-
Retry Pause, in seconds. When w3mir fails to get a document for some technical reason (timeout mainly) the document will be queued for a later retry. The retry pause is how long w3mir waits between finishing a mirror pass before starting a new one to get the still missing documents. This should be a long time, so network conditions have a chance to get better. The default is 600 seconds (10 minutes), which might be a bit too short, for batch running w3mir I would suggest an hour (3600 seconds) or more.
- -t n
-
Number of reTries. If w3mir cannot get all the documents by the nth retry w3mir gives up. The default is 3.
- -drr
-
Disable Robot Rules. The robot exclusion standard is described in http://info.webcrawler.com/mak/projects/robots/norobots.html. By default w3mir honors this standard. This option causes w3mir to ignore it.
- -R
-
Remove files. Normally w3mir will not remove files that are no longer on the server/part of the retrieved web of files. When this option is specified all files no longer needed or found on the servers will be removed. If w3mir fails to get a document for any other reason the file will not be removed.
- -B
-
Batch fetch documents whose URLs are given on the commandline.
In combination with the -r and/or -l switch all HTML and PDF documents will be mined for URLs, but the documents will be saved on disk unchanged. When used with the -r switch only one single URL is allowed. When not used with the -r switch no HTML/URL processing will be performed at all. When the -B switch is used with -r w3mir will not do repeated mirrorings reliably since the changes w3mir needs to do, in the documents, to work reliably are not done. In any case it's best not to use -R in combination with -B since that can result in deleting rather more documents than expected. Hwowever, if the person writing the documents being copied is good about making references relative and placing the <HTML> tag at the beginning of documents there is a fair chance that things will work even so. But I wouln't bet on it. It will, however, work reliably for repeated mirroring if the -r switch is not used.
When the -B switch is specified redirects for a given document will be followed no matter where they point. The redirected-to document will be retrieved in the place of the original document. This is a potential weakness, since w3mir can be directed to fetch any document anywhere on the web.
Unless used with -r all retrived files will be stored in one directory using the remote filename as the local filename. I.e., http://foo/bar/gazonk.html will be saved as gazonk.html. http://foo/bar/ will be saved as bar-index.html so as to avoid name colitions for the common case of URLs ending in /.
- -I
-
This switch can only be used with the -B switch, and only after it on the commandline or configuration file. When given w3mir will get URLs from standard input (i.e., w3mir can be used as the end of a pipe that produces URLs.) There should only be one URL pr. line of input.
- -q
-
Quiet. Turns off all informational messages, only errors will be output.
- -c
-
Chatty. w3mir will output more progress information. This can be used if you're watching w3mir work.
- -v
-
Version. Output w3mirs version.
- -s
-
Copy the given document(s) to STDOUT.
- -f
-
Forget. The retrieved documents are not saved on disk, they are just forgotten. This can be used to prime the cache in proxy servers, or not save documents you just want to list the URLs in (see -l).
- -l
-
List the URLs referred to in the retrieved document(s) on STDOUT.
- -umask n
-
Sets the umask, i.e., the permission bits of all retrieved files. The number is taken as octal unless it starts with a 0x, in which case it's taken as hexadecimal. No matter what you set this to make sure you get write as well as read access to created files and directories.
Typical values are:
- 022
-
let everyone read the files (and directories), only you can change them.
- 027
-
you and everyone in the same file-group as you can read, only you can change them.
- 077
-
only you can read the files, only you can change them.
- 0
-
everyone can read, write and change everything.
The default is whatever was set when w3mir was invoked. 022 is a reasonable value.
This option has no meaning, or effect, on Win32 platforms.
- -P server:port
-
Use the given server and port is a HTTP proxy server. If no port is given port 80 is assumed (this is the normal HTTP port). This is useful if you are inside a firewall, or use a proxy server to save bandwidth.
- -pflush
-
Proxy flush, force the proxy server to flush it's cache and re-get the document from the source. The Pragma: no-cache HTTP/1.0 header is used to implement this.
- -ir referrer
-
Initial Referrer. Set the referrer of the first retrieved document. Some servers are reluctant to serve certain documents unless this is set right.
- -agent agent
-
Set the HTTP User-Agent fields value. Some servers will serve different documents according to the WWW browsers capabilities. w3mir normally has w3mir/version in this header field. Netscape uses things like Mozilla/3.01 (X11; I; Linux 2.0.30 i586) and MSIE uses things like Mozilla/2.0 (compatible; MSIE 3.02; Windows NT).
- -lc
-
Lower Case URLs. Some OSes, like W95 and NT, are not case sensitive when it comes to filenames. Thus web masters using such OSes can case filenames differently in different places (apps.html, Apps.html, APPS.HTML). If you mirror to a Unix machine this can result in one file on the server becoming many in the mirror. This option lowercases all filenames so the mirror corresponds better with the server.
If given it must be the first option on the command line.
This option does not work perfectly. Most especially for mixed case host-names.
- -d n
-
Set the debug level. A debug level higher than 0 will produce lots of extra output for debugging purposes.
- -abs
-
Force all URLs to be absolute. If http://www.ifi.uio.no/~janl/index.html references foo.html the referense is absolutified into http://www.ifi.uio.no/~janl/foo.html
CONFIGURATION-FILE
Most things can be mirrored with a (long) command line. But multi server mirroring, authentication and some other things are only available through a configuration file. The configuration file consists of lines of comments and directives. A directive consists of a keyword followed by a colon (:) and then one or several arguments.
# This is a comment. And the next line is a directive:
Options: recurse, remove
A comment can only start at the beginning of a line. The directive keywords are not case-sensitive, but the arguments might be.
- Options: recurse | no-date-check | only-nonexistent | list-urls | lowercase | remove | batch | input-urls
-
This must be the first directive in a configuration file.
- URL: HTTP-URL [target-directory]
-
The URL directive may only appear once in any configuration file.
Without the optional target directory argument it corresponds directly to the single-HTTP-URL argument on the command line.
If the optional target directory is given all documents from under the given URL will be stored in that directory, and under. The target directory is most likely only specified if the Also directive is also specified.
If the URL given refers to a directory it must end in a "/", otherwise you might get quite surprised at what gets retrieved.
Either one URL: directive or the single-HTTP-URL at the command-line must be given.
- Also: HTTP-URL directory
-
This directive is only meaningful if the recurse (or -r) option is given.
The directive enlarges the scope of a recursive retrieval to contain the given HTTP-URL and all documents in the same directory or under. Any documents retrieved because of this directive will be stored in the given directory of the mirror.
In practice this means that if the documents to be retrieved are stored on several servers, or in several hierarchies on one server or any combination of those. Then the Also directive ensures that we get everything into one single mirror.
This also means that if you're retrieving
URL: http://www.foo.org/gazonk/
but it has inline icons or images stored in http://www.foo.org/icons/ which you will also want to get, then that will be retrieved as well by entering
Also: http://www.foo.org/icons/ icons
As with the URL directive, if the URL refers to a directory it must end in a "/".
At this point in time w3mir has no mechanism to easily enlarge the scope of a mirror after it has been established. That means that you should survey the documents you are going to retrieve to find out what icons, graphics and other things they refer to that you want. And what other sites you might like to retrieve. If you find out that something is missing you will have to delete the whole mirror, add the needed Also directives and then reestablish the mirror. This lack of flexibility in what to retrieve will be addressed at a later date.
- Initial-referer: referer
-
see -ir option.
- Ignore: wildcard
- Fetch: wildcard
- Ignore-RE: regular-expression
- Fetch-RE: regular-expression
-
These four are used to set up rules about which documents, within the scope of retrieval, should be gotten and which not. The default is to get anything that is within the scope of retrieval. That may not be practical though. This especially goes for CGI scripts, server side image maps and other things that are executed/evaluated on the server. There might be other things you want unfetched as well.
w3mir stores the Ignore/Fetch rules in a list. When a document is considered for retrieval the URL is checked against the list in the same order that the rules appeared in the configuration file. If the URL matches any rule the search stops at once. If it matched a Ignore rule the document is not fetched and any URLs in other documents pointing to it will point to the document at the original server (not inside the mirror). If it matched a Fetch rule the document is gotten.
The wildcards are a very limited subset of Unix-wildcards. w3mir understands only '?', '*', and '[x-y]' ranges.
The perl-regular-expressions are perls superset of the normal Unix regular expression syntax. They must be completely specified, including the prefixed m, a delimiter of your choice (except the paired delimiters: parenthesis, brackets and braces), and any of the RE modifiers. I.e.,
Ignore-RE: m/.gif$/i
or
Ignore-RE: m~/.*/.*/.*/~
and so on. "#" cannot be used as delimiter as it is the comment character in the configuration file.
- Apply: regular-expression
-
This is used to change a URL into another URL. It is a potentially very powerful feature, but it is provided only because w3mir relies on the same kind of mechanism for some of its work and because it has a big potential. It has not been used extensively for any real work. Anyone using this feature should write to the w3mir authors if they find that it needs extentions.
The Apply expressions are applied, in sequence, to the URLs in their absolute form. I.e., with the whole http://host:port/dir/ec/tory/file URL. It is after this w3mir checks if a document is within the scope of retrieval or not. That means that Apply rules can be used to change certain URLs to fall inside the scope of retrieval, and vice versa.
The regular-expression is perls superset of the usual Unix regular expressions for substitution. As with Fetch and Ignore rules it must be specified fully, with the s and delimiting character. It has the same restrictions with regards to delimiters. E.g.,
Apply: s~/foo/~/bar/~i
to translate the path element foo to bar in all URLs.
"#" cannot be used as delimiter as it is the comment character in the configuration file.
- Agent: agent
-
see -agent option.
- Pause: n
-
see -p option.
- Retry-Pause: n
-
see -rp option.
- Retries: n
-
see -t option.
- debug: n
-
see -d option.
- umask n
-
see -umask option.
- Robot-Rules: on | off
-
Turn robot rules on of off. See -drr option.
- Remove-Nomirror: on | off
-
If this is enabled sections between two consecutive
<!--NO MIRROR-->
comments in a mirrored document will be removed. This editing is performed even if batch getting is specified.
- Header: html/text
-
Insert this complete html/text into the start of the document. This will be done even if batch is specified.
- File-Disposition: save | stdout | forget
-
What to do with a retrieved file. The save alternative is default. The two others correspond to the -s and -f options. Only one may be specified.
- Verbosity: quiet | brief | chatty
-
How much w3mir informs you of it's progress. Brief is the default. The two others correspond to the -q and -c switches.
- Cd: directory
-
Change to given directory before starting work. If it does not exist it will be quietly created.
- HTTP-Proxy: server:port
-
see the -P switch.
- Proxy-Options: no-pragma | revalidate | refresh | no-store
-
Set proxy options. There are two ways to pass proxy options, HTTP/1.0 compatible and HTTP/1.1 compatible. Newer proxy-servers will understand the 1.1 way as well as 1.0. With old proxy-servers only the 1.0 way will work. w3mir will prefer the 1.0 way.
The only 1.0 compatible proxy-option is refresh, it corresponds to the -pflush option and forces the proxy server to pass the request to a upstream server to retrieve a fresh copy of the document.
The no-pragma option forces w3mir to use the HTTP/1.1 proxy control header, use this only with servers you know to be new, otherwise it won't work at all. Use of any option but refresh will also cause HTTP/1.1 to be used.
revalidate forces the proxy server to contact the upstream server to validate that it has a fresh copy of the document. This is nicer to the net than refresh option which forces re-get of the document no matter if the server has a fresh copy already.
no-store forbids the proxy from storing the document in other than in transient storage. This can be used when transferring sensitive documents, but is by no means any warranty that the document can't be found on any storage device on the proxy-server after the transfer.
refresh corresponds to the HTTP/1.0 header Pragma: no-cache or the identical HTTP/1.1 Cache-control option. revalidate and no-store corresponds to max-age=0 and no-store respectively.
- Authorization
-
w3mir supports only the basic authentication of HTTP/1.0. This method can assign a password to a given user/server/realm. The "user" is your user-name on the server. The "server" is the server. The realm is a HTTP concept. It is simply a grouping of files and documents. One file or a whole directory hierarchy can belong to a realm. One server may have many realms. A user may have separate passwords for each realm, or the same password for all the realms the user has access to. A combination of a server and a realm is called a domain.
- Auth-Domain: server:port/realm
-
Give the server and port, and the belonging realm (making a domain) that the following authentication data holds for. You may specify "*" wildcard for either of server:port and realm.
- Auth-User: user
-
Your user-name.
- Auth-Passwd: password
-
Your password.
These three directives may be repeated, in clusters, as many times as needed to give the necessary authentication information
- Disable-Headers: referer | user
-
Stop w3mir from sending the given headers. This can be used for anonymity, making your retrievals harder to track, especially if you specify a generic Agent, like Netscape.
EXAMPLES
Just get the latest Dr-Fun if it has been changed since the last time
w3mir http://sunsite.unc.edu/Dave/Dr-Fun/latest.jpg
Recursively fetch everything on the Star Wars site, remove that are no longer at the server from the mirror
w3mir -R -r http://www.starwars.com/
Fetch the contents of the Sega site through a proxy, pausing for 0 seconds between each document
w3mir -r -p 0 -P www.foo.org:4321 http://www.sega.com
Do everything according to w3mir.cfg
w3mir -cfgfile w3mir.cfg
A simple configuration file
# Remember, options first, as many as you like, comma separated Options: recurse, remove # # Start here: URL: http://www.starwars.com/ # # Speed things up, not nice Pause: 0 # # Don't get junk Ignore: *.cgi Ignore: *-cgi Ignore: *.map # # Proxy: HTTP-Proxy: www.foo.org:4321 # # You _should_ cd away from the directory where the config file is. cd: starwars # # Authentication: Auth-domain: server:port/realm Auth-user: me Auth-passwd: my_password # # You can use '*' in place of server:port and/or realm: Auth-domain: */* Auth-user: otherme Auth-user: otherpassword
Also:
# Retrive all of janl's home pages: Options: recurse # # This is the two argument form of URL:. It fetches the first into the second URL: http://www.math.uio.no/~janl/ math/janl # # These says that any documents refered to that lives under these places # should be gotten too. Into the named directories. Two arguments are # required for 'Also:'. Also: http://www.math.uio.no/drift/personer/ math/drift Also: http://www.ifi.uio.no/~janl/ ifi/janl Also: http://www.mi.uib.no/~nicolai/ math-uib/nicolai # # The options above will result in this directory hierarchy under # where you started w3mir: # w3mir/math/janl files from http://www.math.uio.no/~janl # w3mir/math/drift from http://www.math.uio.no/drift/personer/ # w3mir/ifi/janl from http://www.ifi.uio.no/~janl/ # w3mir/math-uib/nicolai from http://www.mi.uib.no/~nicolai/
Ignore-RE and Fetch-RE
# Get only jpeg files, no gifs Fetch-RE: m/\.jp(e)?g$/ Ignore-RE: m/\.gif$/
Apply
As I said earlier, Apply has not been used for Real Work yet. But Apply could, be used to map all web servers at the university of Oslo inside the scope of retrieval very easily:
# Start at the main server URL: http://www.uio.no/ # Change http://*.uio.no and http://129.240.* to be a subdirectory # of http://www.uio.no/. Apply: s~^http://(.*\.uio\.no(?:\d+)?)/~http://www.uio.no/$1/~i Apply: s~^http://(129\.240\.[^:]*(?:\d+)?)/~http://www.uio.no/$1/~i
There are two rather extensive example files in the w3mir distribution.
AUTHORS
w3mirs authors can be reached at w3mir-core@usit.uio.no. w3mirs home page is at http://www.math.uio.no/~janl/w3mir/
6 POD Errors
The following errors were encountered while parsing the POD:
- Around line 2246:
Expected text after =item, not a number
- Around line 2251:
Expected text after =item, not a number
- Around line 2255:
Expected text after =item, not a number
- Around line 2695:
Expected '=item *'
- Around line 2717:
Expected '=item *'
- Around line 2723:
Expected '=item *'