A Java based server for tracking and listing Newton Personal Data Sharing clients.
The NPDS Tracker Server was originally developed by Victor Rehorst and Paul Guyot.
Additional contributions and updates have been by generously provided and applied by Morgan Aldridge, Grant Hutchinson, Ron Parker, Manuel Probsthain, Peter Geremia, and Sylvain Pilet.
Many thanks to Matt Vaughn for developing NPDS in the first place.
Looking for support? Join the NPDS mailing list.
The current release of the NPDS Tracker Server has been tested with Java SE (Standard Edition) versions 1.4, 1.5, and 1.6. It will also work with versions earlier than 1.3, but it is not recommended. See the Basic Set Up section for more information.
The Java SE runtime can be downloaded from Oracle.
The NPDS Tracker Server listens for clients on TCP port 3680, as assigned by IANA. The tracker can also be configured to listen on multiple ports. See the Settings section for more information.
Required to edit the various configuration and template files.
Required to compile the Java source, install the compiled .jar file, and configuring the related files and components. A terminal program can also be used to remote administer the NPDS Tracker Server using Telnet. See the Remote Administration section for more information.
readme.md — You’re soaking in it
npdstracker.java — Java source code for the tracker
npdstracker.ini — Settings and configuration for the tracker
template.html — HTML page template used by the tracker
template.css — Stylesheet used in conjunction with the HTML page template
npdscmd.txt — Initial tracker commands. Registered servers are written to this file upon shutdown
startnpds.sh — An example shell script for Unix-like operating systems
manifest.mf — Information specific to the creation of the .jar file
First, determine whether Java is installed. Open a command line and type:
which javaThis command will return the path where Java is installed on your system.
For example:
/usr/bin/javaIf a path is not displayed after running this command, then Java is not currently installed on your system. You will need to download and install the Java SE software before proceeding.
To determine the version of Java installed, type the following:
java -versionThis command will return information about the current Java installation, including the version number and related software details.
For example:
java version "1.6.0_30"Download the latest version of the NPDS Tracker Server source. Decompress the archive and move the entire directory to an appropriate location on your system. Technically, you can install and run the tracker software anywhere on your system (providing you have adequate file permissions), with all of the components residing in the same directory. The Basic Set Up section describes this type of installation.
Assuming that Java 1.3 or later has been correctly installed, open a command line and compile the server source:
javac npdstracker.javaDepending on your system environment, you may see messages similar to the following. You can safely ignore them.
Note: npdstracker.java uses unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.If compiling was successful, a series of .class files will now reside in the source directory.
npdstracker.class
npdstracker$TConnection.class
npdstracker$THostInfo.class
npdstracker$TQueryException.class
npdstracker$TServer.class
npdstracker$TServerInfo.class
npdstracker$TValidator.classEdit npdstracker.ini and change the settings specific to your installation.
If all of the source files remain in the same directory, you will not need to change the defaults for the pageTemplate, cssTemplate, or logfile path settings.
See the Settings section for setting descriptions and syntax.
Start the server from the command line:
java npdstrackerFor Java 1.1 and 1.2 installations, the -Dsun.net.inetaddr.ttl=0 parameter must be added to the command line. This additional parameter compensates for DNS caching bugs that exist in these versions of the Java runtime.
java -Dsun.net.inetaddr.ttl=0 npdstrackerTest the connection to the tracker by launching your web browser using the following URL:
http://<ip/hostname>:3680/Configure an NPDS Tracker Client to point at the tracker, confirming that it registers properly.
The basic set up is great for development, testing, and Windows deployment. However, for those running Linux or Mac OS X, it may be preferable to install a tidier and more permanent version of the tracker. This involves creating a .jar (Java Archive) file, removing the post-compile .class files, and moving the various support files into their respective (and arguably more appropriate) directories.
Assuming that Java 1.3 or later has been correctly installed, open a command line and compile the server source:
javac npdstracker.javaIf compiling was successful, a series of .class files will now reside in the source directory.
npdstracker.class
npdstracker$TConnection.class
npdstracker$THostInfo.class
npdstracker$TQueryException.class
npdstracker$TServer.class
npdstracker$TServerInfo.class
npdstracker$TValidator.classWrap all those .class files into a single .jar file from the command line:
jar cvfm npdstracker.jar manifest.mf *.classAfter creating the .jar, you can safely delete the now redundant .class files:
rm *.classInstall the .jar file in /usr/local/bin from the command line:
[sudo] mkdir -p /usr/local/bin
[sudo] install npdstracker.jar /usr/local/binInstall the npdstracker.ini and npdscmd.txt files in /etc from the command line:
[sudo] mkdir -p /etc/npdstracker
[sudo] install npdstracker.ini npdscmd.txt /etc/npdstrackerInstall the template.html and template.css files in /usr/local/share from the command line:
[sudo] mkdir -p /usr/local/share/npdstracker
[sudo] install template.html template.css /usr/local/share/npdstrackerCreate the log file from the command line:
[sudo] touch /var/log/npdstracker.logEdit /etc/npdstracker/npdstracker.ini from the command line (or using an external text editor). Change the pageTemplate, cssTemplate, and logfile paths as per the installation commands.
pageTemplate = /usr/local/share/npdstracker/template.html
cssTemplate = /usr/local/share/npdstracker/template.css
logfile = /var/log/npdstracker.logSee the Settings section for more information on setting parameters and syntax.
Start the server from the command line:
java -jar /usr/local/bin/npdstracker.jar -c /etc/npdstracker/npdscmd.txt -o /etc/npdstracker/npdstracker.iniSee Command Line Usage for further details.
Test the connection to the tracker by launching your web browser using the following URL:
http://<ip/hostname>:3680/Configure an NPDS Tracker Client to point at the tracker, confirming that it registers properly.
On Darwin or Mac OS X, you can create a launch daemon to automatically launch the tracker on start up. Create a /Library/LaunchDaemons/fr.free.npds.npdstracker.plist file and paste in the following XML. This assumes that you have followed the steps for Advanced Set Up.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
    <dict>
        <key>Label</key>
        <string>fr.free.npds.npdstracker</string>
        <key>ProgramArguments</key>
        <array>
            <string>java</string>
            <string>-jar</string>
            <string>/usr/local/bin/npdstracker.jar</string>
            <string>-c</string>
            <string>/etc/npdstracker/npdscmd.txt</string>
            <string>-o</string>
            <string>/etc/npdstracker/npdstracker.ini</string>
        </array>
        <key>KeepAlive</key>
        <dict>
            <key>NetworkState</key>
            <true/>
        </dict>
        <key>RunAtLoad</key>
        <true/>
    </dict>
</plist>The launch daemon may be loaded immediately by running the following from the command line, or you can wait until the next boot cycle:
sudo launchctl load /Library/LaunchDaemons/fr.free.npds.npdstracker.plistOn Linux or BSD systems, you can create init.d or rc.d scripts, respectively, to automatically start the tracker on boot.
Configuration settings for the tracker are located in the npdstracker.ini file.
The following syntax must be followed when editing the configuration settings:
- Setting values cannot be enclosed in quotation marks
- Setting values cannot contain spaces (with the exception of shareServervalues)
- Spaces must appear on either side of the equal sign
- Setting parameter names are case sensitive
Configuration setting parameters are shown listed below, along with with their default values. Note that some parameter names have changed in current releases of the tracker and are not backwards compatible.
kPort = 3680Specifies the TCP listening port.
The default port is 3680, as assigned by IANA. However, port 8080 is commonly used for clients that reside behind a firewall. Multiple port numbers may be specified, separated by spaces.
trackerName = DefaultSpecifies the name of the site or tracker for use in the HTML template.
Refer to the Page Template Tag Syntax section for usage.
trackerHost = http://npds.free.fr/Specifies the URL of the site or server host for use in the HTML template.
Refer to the Page Template Tag Syntax section for usage.
adminPass = qwertySpecifies the password for the remote administration interface.
This parameter was named adminpasswd in NPDS Tracker Server 0.1.36 and earlier. Make sure that this parameter name is correct in the npdstracker.ini file.
validateTime = 30Specifies how often to validate clients in seconds.
validateTries = 3Specifies how many validation attempts will be made before clients are removed from the list.
shareEnabled = trueSpecifies whether other trackers may obtain SHARE’d records from this tracker.
Set to ‘true’ to allow sharing, set to anything else to disallow sharing.
shareServer = misato.chuma.org 3680
shareServer = www.unna.org 3680
shareServer = newtzilla.quadzilla.net 3680
shareServer = newton.tek-ed.com 3680Specifies servers to obtain SHARE’d records from.
Each shareServer entry consists of a tracker hostname or address and a port number. To stop obtaining SHARE’d records from a tracker, comment out or delete the tracker’s shareServer entry.
privateHostToAccept =Specifies a private hostname or address to register as a client.
Must be a public DNS entry.
pageTemplate = template.htmlSpecifies the path and name of the HTML template.
Refer to the Page Template Tag Syntax section for usage.
cssTemplate = template.cssSpecifies the path and name of the template stylesheet.
Used in conjunction with pageTemplate.
logFile = npdstracker.logSpecifies the path and name of the log file.
Log entries generated by the tracker are rather verbose and the log file can grow quite large over time. You can turn off logging altogether (redirecting to stdout) by commenting out the logFile setting once you are sure that the server is configured properly.
This parameter was named logfile in NPDS Tracker Server 0.1.36 and earlier. Make sure that this parameter name is correct in the npdstracker.ini file.
logVerbose = trueSpecifies whether messages should be written to the log file.
If set to ‘false’, the tracker will only create a log entry if it encounters a serious problem.
This parameter was named shouldIlog in NPDS Tracker Server 0.1.36 and earlier. Make sure that this parameter name is correct in the npdstracker.ini file.
java npdstracker [-h] [-c <cmdfile>] [-o <optionsfile>]-h — Display help
-c <cmdfile>  — Specifies the path of the npdscmd.txt file containing any commands to run at startup (defaults to none)
-o <optionsfile> — Specifies the path of the npdstracker.ini file containing configuration and option settings (defaults to settings at compile time)
To access the remote administration interface, you’ll need the following:
- A terminal program or standalone Telnet client
- The hostname and port of the tracker you wish to administer
- The password of the tracker you wish to administer
Any changes made using the administration interface are applied immediately to the tracker, but are not saved to the npdstracker.ini file. Changes are lost once the tracker is restarted.
This example assumes that the tracker is configured to use the default port number.
In your terminal program, open the Telnet connection to the tracker.
telnet tracker.example.com 3680Hit ‘Enter’
After you connect to the tracker, you have five seconds to enter the following:
ADMIN <password>Hit ‘Enter’
You will be presented with the following text:
Welcome to the NPDS Tracker Server administration interface!Next, type:
HELPHit ‘Enter’
This will display a list of available commands.
ABOUT — Display the current tracker settings
HALT — Stop the tracker (with confirmation)
HELP — Displays this list of commands
LOGS — Dumps the tracker log
SHARE — Change the tracker share settings
SLIST — View or modify the list of trackers to obtain shared records from
VTEST — Trigger a tracker validation
STATS — Display the tracker statistics (describe)
VERIFY — Change the tracker verification settings
QUIT — Exit the administration interface and close the connection
The HTML page template can be customized using the following pseudo-SGML tags to insert information into the page. Note that some tag names have changed in current releases of the tracker and are not backwards compatible.
<hit-counter/> — The number of page views since the tracker was restarted
<hit-counter-noun/> — Singular or plural noun based on the page views (“time” vs “times”)
<http-doc/> — What comes after the GET (usually “/”)
<last-validation/> — The date and time of the last validation or “Validation is in progress.”
<meta-refresh/> — The meta element containing the http-equiv="refresh" value
<servers/> — The list of registered NPDS clients formatted as a table
<server-counter/> — The number of registered NPDS clients
<server-noun/> — Singular or plural noun based on number of clients (“server” vs “servers”)
<server-verb/> — Singular or plural verb based on number of clients (“is” vs “are”)
<server-shares/> — A linked list of SHARE’d trackers formatted as an unordered list
<stylesheet/> — Inserts the stylesheet as specified in npdstracker.ini (default: template.css)
<tracker-host/> — The URL of the host site or tracker as specified in npdstracker.ini
<tracker-name/> — The name of the host site or tracker as specified in npdstracker.ini
<url/> — The URL of this tracker, obtained by reading the HTTP header
<validate-time/> — The time (in minutes) between validations
<validate-time-noun/> — Singular or plural noun based on the time period (“minute” vs “minutes”)
<version/> — The current version of the tracker software
Copyright © 2001–2017 Grant Hutchinson, Victor Rehorst, Paul Guyot, et al
This project is licensed under the short and sweet MIT License. This license allows you to do anything pretty much anything you want with the contents of the repository, as long as you provide proper attribution and don’t hold anyone liable.
See the license.txt file included in this repository for further details.
- [GH] New <server-noun/>and<server-verb/>template tags because grammar
- [GH] New <hit-counter-noun/>and<validate-time-noun/>template tags because grammar
- [GH] Standardized template tag naming for <tracker-host/>and<tracker-name/>
- [GH] Changed date formatting to use full day and month names
- [GH] Added initial media queries and responsive layout styles
- [GH] Simplified template and validation string markup
- [GH] Added MIT license
- [RP] New <server-shares/>template tag inserts a list of shared trackers
- [GH] Added command line usage information
- [GH] Added remote administration documentation
- [GH] Added getting started documentation
- [GH] Added configuration settings documentation
- [GH] Removed redundant configuration comments from the npdstracker.inifile
- [GH] Reinstated classes on unordered lists so they can be styled independently
- [GH] Wrapped link lists in <nav>elements
- [GH] Renamed several configuration parameters
- [GH] Previous npdstracker.inifiles are no longer compatible with this version of the tracker
- [MA] Split out display of HTML status into its own method
- [MA] Updated HTTP GET processing to support rendering the HTML status page
- [MA] Fixed stylesheet configuration and template insertion
- [RP] Added host name and link to the header and page title
- [MA] Removed rogue slash in npdstracker.java
- [MA] Added manifest file
- [MA] Added advanced set up documentation
- [GH] Added Java compatibility documentation
- [GH] Converted template to HTML5
- [GH] Removed deprecated elements and formatting attributes
- [GH] Minor formatting and nomenclature edits abound!
- [GH] Converted read me to Markdown format
- [GH] Moved source to GitHub
- [GH] Added user definable stylesheet template
- [GH] Moved stylesheet from template.html into its own file
- [GH] Moved version history from Java source file into read me
- [GH] Minor text formatting updates
- [GH] Changed all document encoding to UTF-8
- [VR] Added shouldIlogsetting in INI file to disable all logging
- [MP] Added SSI tag for displaying the number of registered clients in the template
- [MP] Made the <meta-refresh/>SSI XHTML-compatible
- [MP] Changed the default port number to 3680
- [MP] Refined the listing table elements for extensive use of CSS
- [MP] Added code to allow one hostname with a private IP to register
- [VR] Makes sure that the hostname isn’t empty on a REGUP command
- [VR] Changed kRTFMStrto reflect new NPDS website address
- [PG] The tracker can now listen on several ports
- [PG] Fixed the bug in 192.168.* address filtering
- [PG] Fixed the bug in processing of console commands, so now lowercase commands work
- [PG] The console now says “server validation test started” before it finishes the validation
- [PG] The tracker was waiting forever for an answer from fellow trackers, which was bad
- [PG] Added style information to colorize the table
- [PG] The tracker performs a verification on startup
- [PG] Vector copy constructor is no longer called, so this should compile on Java < 1.2 (but it will have problems because of bugs in the JVM)
- [PG] The tracker now checks the hosts passed as REGUP parameters to be correct (to resolve and to be not private)
- [PG] No longer dumps the shared trackers to npdscmd.txt
- [PG] Fixed the shareEnabled.ini read process (getBooleanis not what we want, it’svalueOf)
- [VR] Now saves registered client information for automatic reloading upon a crash or restart
- [PG] Fixed the java.lang.ArrayIndexOutOfBoundsExceptionbug introduced in version 0.1.24
- [PG] Fixed the java.lang.IllegalArgumentException: timeout value is negativebug (well, I think)
- [PG] Fixed the reload 0 bug
- [PG] Fixed the lock bug
- [PG] Set the timeout to 20 seconds (was 10 seconds) so my Newton is no longer considered as down
- [PG] Added last validation template element
- [VR] No actual code changes, but documented workaround for the JDK 1.1 bug
- [PG] Implemented the template stuff
- [PG] Reorganized the ProcessQuerymethod
- [PG] There is now a single class with embedded sub classes (so we’ll have a single .java binary)
- [PG] Improved answer to the GET request (with many headers now)
- [PG] No longer uses the bugged URL interface to check if Newton clients are up. Instead, I use a socket
- [PG] The REGUP command tokenizer now accepts any standard token (and no longer only spaces which wasn’t protocol-compliant)
- [PG] Added several syntax checking with an appropriate status message
- [VR] Retrieving SHARE records from other trackers now works!
- [VR] Will now read optionsfileandcmdfilefrom default location
- [VR] Fixed up options file parsing
- [VR] HTML now easily customizable using npdstracker.ini,header.html,footer.html
- [VR] Minor admin console fixes
- [VR] Implemented command-line arguments for logfile,cmdfile,optionsfile
- [VR] Now can specify files to log to, read options from, or read initial commands from
- [VR] Finally implemented LOGS command in admin console
- [VR] Code and syntax cleanups
- [PG] Use SimpleDateFormatin theReturnRFCTimefunction. (this also fixes the GMT bug)
- [PG] Fixed a little HTML bug
- [VR] VTEST command added to the admin console
- [VR] SHARE command is now actually sent (forgot to flush PrintWriter)
- [VR] Changed return code of SHARE command if sharing is disabled
- [PG] The tracker now only sleeps in the validator loop
- [PG] Now the tracker always uses CRLF except for the log
- [PG] Fixed a little bug in the validation date
- [PG] Now supports multiple connections
- [VR] Trying to fix intermittent bug in client validation code
- [VR] More bugs in client validation fixed
- [VR] Added more features to GET code
- [VR] Fixed up RFC times somewhat
- [VR] Fixed bug in validation code with “Connection Refused” socket exceptions
- [VR] Fixed bug with exception passing and tracker socket code
- [VR] Rewrote GET code to return a nice HTML 4.01 compliant table
- [VR] Admin console is now complete save for the LOGS command
- [VR] Now retrieves, updates, and properly handles records from other trackers via the SHARE command
- [VR] Added SHARE, ABOUT, VERIFY, and STATS command to admin console
- [VR] Fixed the problem with the verification code repeating many times per minute
- [VR] Added a REGUP counter for the STATS admin command
- [VR] Now accepts commands regardless of case
- [VR] Checks for an existing host entry before processing a REGUP
- [VR] Started implementing the ADMIN command for live configuration of the tracker
- [VR] First implementation of SHARE command
- [VR] Cleaned up some return codes
- [VR] Fixed some status handling and checking
- [VR] Client validation actually works! Woo hoo!
- [VR] Implemented a socket timeout so that the loop doesn’t get stuck
- [VR] Removed the QHTML extended command
- [VR] Implemented Return Codes
- [VR] Fixed GET method so it returns DTD HTML 2.0 compliant pages
- [VR] Rewrote internal storage of records for extensibility
- [VR] Now we store time client last checked and its status
- [VR] Implemented QueryMethodfunction for finding a record when we do a REGDN (could also use this method for an possible SRCH command later)
- [VR] Added QHTML method for returning HTML-ized results
- [VR] Added GET method support for returning a basic web page to web browsers