Tiptop is an alternate reader for the top content in your TypePad dashboard. Rather than a stream of all of the events generated by people you follow (posts, favorites, comments, &c), tiptop gives you a couple of views into that content:
- A list of posts, photos, videos, &c created by the people you follow
- A leaderboard of the most-favorited posts, photos, videos, &c
And, in the future, maybe more. Its aim is to serve both as a reference application for building upon the TypePad platform, as well as a genuinely useful reader for the content you should be reading from people you follow.
Tiptop itself is pure Perl, but it has a number of dependencies beyond core
Perl. You can guarantee that those dependencies are installed by running the
Makefile.PL, which will complain for all dependencies that aren't installed.
Tiptop also requires a MySQL database to store post & user content locally.
The schema for that database is in
mysql -u username tiptop < tiptop.sql
Tiptop's configuration is stored in the
tiptop.cfg file. At a minimum,
the database, application, and user configuration (information about the
user whose followers you'd like to track, which is probably you) is required.
Here's a sample configuration file, which should live in
tiptop.cfg in your
[database] dsn=dbi:mysql:database=tiptop username=username password=password [user] xid=6p00d83455876069e2 [app] consumer_key=... consumer_secret=...
Your consumer key and consumer secret can be obtained from your TypePad account.
Tiptop is composed of a couple of components:
- Command-line tools (
- A PSGI-based web application
To test your configuration, you can first start up the web application:
Then navigate to the webserver in your browser (it runs on port 5000 by default):
tiptop-web is simply a wrapper around the
plackup tool, so you can use
any of the command-line options supported by that tool when running
tiptop-web, as well.
To load content into your database, run
load-events.pl: this will poll
TypePad for new events created by your followers, and will create local copies
of the user and asset objects for fast access in the future:
This could take a little while the first time it runs, if you have a lot of
events in your dashboard history (the maximum number of events is 1,000); on
future invocations, though,
load-events.pl will only look back through
your events until it finds events that it's previously processed, so it'll
load-events.pl will only load favorites and assets by people that you
follow. You might also want to factor in favorites from users that you don't
follow when they happen to favorite assets from people you follow (or assets
favorited by people that you follow). To backfill favorites from all users
for the assets that
load-events.pl has discovered, you can run
For each asset in your local database, this will query the list of favorites for that asset and backfill them in your database, giving you a complete list of users that have favorited each asset.
Tiptop is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
Benjamin Trott / email@example.com