nap(1) Linux Napster Client

Other Alias

napping

SYNTAX

nap <options>
napping

DESCRIPTION

Nap is a linux console napster client written by Kevin Sullivan and improved by Peter Selinger and others. The advantage of nap over other graphical clients like gnome-napster is that you can run it under screen(1) on a remote host and disconnect from your session while nap continues the downloads. You can later reconnect to your running client even from another host and do more commands.

Napping is a helper application required by nap to send and reveive ping packets. For napping to work it should be installed suid root.

For more information, please see the HTML documentation at http://nap.sourceforge.net/userguide.html.

OPTIONS

-h, --help
Output help information and exit
-v, --version
print version info and exit
-b, --build
build library of your shared files to send to server (obsolete, as nap will do this by default).
-B, --build-only
build library and exit
-N, --nobuild
do not build library, even if it is out of date
-m, --create
create a new account with the napster server (obsolete)
-r, --reconnect
keep reconnecting until server connection established
-a, --autorestart
automatically reconnect when connection to server lost
-q, --daemon
run without user interface; file sharing only
-t, --notitle
do not display the title bar (fixes messed-up displays)
-l, --nxterm
try using a terminal which is compatible with most systems (fixes some messed-up displays)
-T, --transparent
use the terminal's default background instead of black
-n, --noserver
start up without connecting to a server
-f <filename>, --config <filename>
specifies the config file to use (default ~/.nap/napconf)
-x <filename>, --log <filename>
log all transfers to a specific filename
-g <filename>, --logall <filename>
log everything to a specific filename
-s <server>, --server <server>
select a specific server (multiple -s opts possible)
-d <n>, --debug <n>
set debug level
-u <str>, --user <str>
specify napster username
-p <str>, --pass <str>
specify user's password
-e <str>, --email <str>
specify user's email address
-U <dir>, --upload <dir>
specify upload directory (multiple -U opts possible)
-D <dir>, --download <dir>
specify download directory
-I <dir>, --incomplete <dir>
specify directory for incomplete files
-P <n>[-<m>], --dataport <n>[-<m>]
specify port(s) to use for incoming upload requests
-C <n>, --connection <n>
specify connection speed number, according to the following chart:


 Connection | Number
 -------------------
 Unknown    |  0
 14.4       |  1
 28.8       |  2
 33.6       |  3
 56.7       |  4
 64K ISDN   |  5
 128K ISDN  |  6
 Cable      |  7
 DSL        |  8
 T1         |  9
 T3 or >    | 10

-M <n>, --maxuploads <n>
specify maximum number of simultaneous uploads
-o <var>=<value>, --option <var>=<value>
set user configuration variable

CONFIGURATION VARIABLES

Configuration variables can be set in the file ~/.nap/napconf, on the command line via the -o option, or interactively via the /set command. Here is an almost complete list of configuration variables:

user
your napster username
pass
your napster password - optional
email
your napster email address
upload
list of upload directories, separated by semicolons
download
your download directory
incomplete
your directory for incomplete files
connection
your connection speed (see -C option)
maxuploads
maximal number of simultaneous uploads allowed
maxupuser
maximum number of simultaneous uploads per user
maxdownloads
maximum number of simultaneous downloads allowed
maxdownuser
maximum number of simultaneous downloads per user
servers
list of servers, separated by semicolons (note: this is now ignored and overwritten unless nometa is set)
dataport
port or range of ports to use for client-client connections. Set this to 0 if you are behind a firewall
logfile
log file for transfer logs
logallfile
log file for logging everything
bandwidthdown
global bandwidth limit for downloads (in kB/s)
bandwidthdown1
download bandwidth limit per connection (in kB/s)
bandwidthup
global bandwidth limit for uploads (in kB/s)
bandwidthup1
upload bandwidth limit per connection (in kB/s)
announcepongs
should receipt of PONG packets be announced?
autopurge
time to delete stopped items from up- and download lists
autopurgeup
time to delete stopped items from upload list
autopurgedown
time to delete stopped items from download list
autoreply
a string to send as an automatic reply to incoming user messages
autorestart
automatically reconnect when connection to server lost?
connecttimeout
timeout after this many seconds while connecting to server
cursorfollowsscreen
should PgUp and PgDn move the screen, rather than the cursor, on the search result screen?
debug
debug level
identity
fake client id for fooling servers that refuse connections from nap client
hash
shall we calculate MD5 hashes? Note that most servers don't use them.
incompletesuffix
suffix to use for incomplete files
libraryfile
location of your library file
metaserver
URL of a napigator-style metaserver
metatimeout
timeout for connecting to metaserver
napping
relative or absolute filename of the napping program to use
newstimeout
timeout for retrieving news
noechosets
should the /set command be quiet?
nomasq
should filename masquerading be disabled?
nometa
skip connecting to metaserver on startup?
nonews
do you want to skip news about new releases on startup?
noping
do you want to disable pings?
noresultscreen
should search results be displayed on the main screen?
noscroll
should main screen not scroll to bottom automatically on output?
proxy
URL of http proxy, if needed to access www through firewall
savechannels
should your open channels to be saved between sessions?
savepass
should password be saved in config file?
scrollsize
limit on the number of lines in main screen, or 0 for no limit
sdefaults
default keystrokes for search result screen appearance
sharetypes
semicolon-separated list of file extensions to share in addition to mp3 files. Case insensitive. Use '*' for 'all files'.
showtoomanyuploads
display a message when upload limit is reached?
turdsize
size of the largest incomplete file which will be auto-removed

COMMANDS

Nap has an irc-like interface. Commands start with a slash "/". The two most important commands are /search to start a search, and /reconnect to cycle through the list of servers. Here is a complete list of commands:

/about - Shows credits

/alias [name] [args] - Creates an alias, or lists current aliases
/aliaslist - Shows current list of aliases
/announce msg - Broadcasts a message to all users
/ban [user/IP] - Bans the specified user or IP, or lists banned users
/banlist - Prints a list of the current bans on the server
/block [IP] [reason] - Blocks the specified IP, or lists blocked users
/blocklist - Gives a list of current blocked users
/break - Breaks out of a loop
/browse user - Browses user's files
/browse2 user - Directly browses user's files
/cban [user] [reason] - Bans a user from a channel, or lists banned users
/cbanlist - Returns a list of banned users in a channel
/chupload path - Changes your upload path (still need to /rebuild to update your files)
/clear - Clears your screen buffer
/clearalias - Clears all aliases
/clearhandler - Clears all handlers
/clist - Gets a list of channels
/clist2 - Gets a list of channels (includes user created)
/cloak - Cloaks yourself
/conf config-string - Request a change in server configuration variables
/cunban user [reason] - Unbans a user from a channel
/ddown number or range - Deletes downloads by number as returned from /pdown
/dec - Decreases the variable by one
/debug level - Sets debug level
/disconnect - Disconnects you from the server
/dlul - Switches to the download/upload monitor screen
/dns host/IP - Attempts to resolve the specified address
/done - Ends an alias
/dtimer [num] - Delete the timed event with the given number
/dup number or range - Deletes uploads by number as returned from /pup
/echo text - Echos text to the screen
/eval name - Returns the value of a variable
/exec [-o] command - Executes a command from a shell and redirects the input to the client
/fdown number or range - Gets information on the user as returned from /pdown
/finger user - Gets information on the specified user
/force number or range - Forces download of queued items, overriding download limit
/fup number or range - Gets information on the user as returned from /pup
/g number or range - Gets files by number as returned from /search
/get number or range - Gets files by number as returned from /search
/getservers - Read server list from napigator-style metaserver
/gusers - Gets a global list of users
/handler [code] [args] - Adds a handler, or lists current handlers
/handlerlist - Returns a list of handlers created
/help command - Returns help on the specified command
/hotlist [user] - Adds a user to your hotlist, or shows current hotlist
/if (val op val) cmd - Compares two values
/ignore [user] - Ignores a user, or lists all ignored users
/ignoreclear - Clears your ignore list
/ignorelist - Lists ignored users
/inc var - Increases the variable by 1
/irc - No help available
/join [chan] - Joins the specified channel, or lists all channels
/kick user [reason] - Kicks a user from a channel
/kickall user [reason] - Kicks a user from all channels you and the user are in
/kill user - Kills the specified user
/lastlog str - Returns all occurences of "str" that have been said or printed
/loadalias [filename] - Loads a list of aliases from a file
/loadchannels [filename] - Reads channels from a filename and joins them
/loadconfig [filename] - Loads a list of settings from a filename
/loadhandler [filename] - Loads a list of handlers from a filename
/me string - Does an emotion
/msg user msg - Sends the user the message specified
/muzzle user msg - Muzzles the user with the specified message
/names channel - Gets a list of channel users
/news - Checks for any news on the client
/noprint - Stops the client from echoing anything until the command returns
/notify [user] - Adds a user to your hotlist, or shows current hotlist
/opsay msg - Broadcasts a message to all moderators/admins/elite
/part [chan/user] - Parts the specified or current channel or query
/pchans - Shows which channels you are on
/pdown [dqsf] - Gives a listing of your current downloads. Optional flags select downloading, queued, succeeded, failed items.
/ping user - Pings a user
/psocks - Print the socket list (for debugging purposes)
/pup - Gives a listing of your current uploads
/purge - Removes all stopped items from upload and download lists
/purgedown - Removes all stopped items from download list
/purgeup - Removes all stopped items from upload list
/pvars - Prints the values of all variables currently set
/query user - Queries a user
/q - Closes the program
/quit - Closes the program
/rebuild - Rebuilds your library unconditionally. See also /update
/reconnect - Reconnects you to the next available server on the list
/reloadconfig-variable - Resets server configuration parameter to its default value
/reloadm - Reloads the user command module (only if supported)
/repeat [min:sec] [cmd] - Initiates a timed event which repeats every <min:sec> interval
/results - Switches to the search results screen
/retry number or range - Puts stopped downloads back in the download queue
/retryall - Puts all stopped downloads back in the download queue
/savealias [filename] - Saves current aliases
/savechannels [filename] - Saves current channels to a filename
/saveconfig [filename] - Saves current settings to a filename
/savehandler [filename] - Saves current handlers to a filename
/say msg - Sends msg to the current channel
/search [-b>bitrate] [-c>speed] [-r>freq] [-s>size] [-d>duration] [-x exclude]... [-t filetype] [-mmaxresults] [-l] [-p] [-f] query - Searches the napster database
/serv [IP:port] - Connects to the specificed server and port, or shows current server and port
/server [IP:port] - Connects to the specificed server and port, or shows current server and port
/set [name] [value] - Sets a user variable, or prints current values
/setdataport user port - Sets a user's data port
/setlevel channel level - ?
/setlinespeed user speed - Changes a user's linespeed
/setpassword user password - Sets a user's password
/setuserlevel user level - Changes a user's userlevel
/sraw type string - Send raw command to the server
/stop - Returns from the current command and stops all processing on it
/sver - Returns the server version
/tell user msg - Sends the user the message specified
/timer min:sec cmd - Initiates a timer to execute in the specified time
/tlist - Prints out a list of the current timers
/topic channel topic - Changes a channel's topic
/tquit - Quits when all remaining transfers have completed. Can be canceled with /unquit
/unalias name - Removes an alias
/unban IP - Unbans the specified IP
/unblock IP - Unblocks the specified IP
/unhandler code - Removes a handler
/unhotlist user - Removes a user from your hotlist
/unignore user - Unignores a user
/unmuzzle user - Unmuzzles the user
/unnotify user - Removes a user from your hotlist
/unquit - Cancels the effect of /tquit
/unset name - Unsets a variable
/update - Rebuilds your library if necessary. See also /rebuild
/while (val op val) cmd - Keeps executing cmd while the comparison is true
/whois user - Gets information on the specified user
/window - Enables/disables window mode
/wstats - No help available

SIGNALS

When nap receives a USR1 signal, it reconnects to a server. The behavior is the same as if a /reconnect command had been issued.

FILES

/etc/naprc
$HOME/.nap/napconf
$HOME/.nap/aliases

AUTHORS

Nap was originally written by Kevin Sullivan <[email protected]>. It is currently maintained by Peter Selinger <[email protected]>. For the complete list of contributors, see the file AUTHORS.

LICENSE

Copyright (c) 2000 Kevin Sullivan. All rights reserved.

Permission is granted to anyone to use this software for any purpose on any computer system, and to alter it and redistribute it, subject to the following restrictions:

1. The origin of this software must not be misrepresented, either by explicit claim or by omission. Since few users ever read sources, credits must also appear in the documentation.

2. Altered versions must be plainly marked as such, and must not be misrepresented as being the original software. Since few users ever read sources, credits must also appear in the documentation.

3. All advertising materials mentioning features or use of this software must display the following acknowledgement: This product includes software developed by Kevin Sullivan.

4. The name of the Author may not be used to endorse or promote products derived from this software without specific prior written permission.

5. This notice, and any references to this notice in the source, documentation, or binary, may not be removed or altered.

THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.