Skip to content

OokTech/TW5-Bob

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TW5-Bob

BIG DISCLAMER OF DOOM - Back up your data. Do it. This has been tested but there may be bugs that I don't know about. Also see notes below.

What does it do?

  • Multi-User support for using/editing the same wiki(s) simultaneously
  • Multi-Wiki support - run it once and serve multiple wikis
  • Create and configure new wikis from inside the root wiki
  • Export single file wikis in a variety of ways
  • Two-way real-time syncing between the browser and file system
  • All configuration can be done from inside the wiki
  • Serve external files (like images) so you can include them in your wikis
  • Allows you to run shell scripts and commands from inside the wiki
  • Can be used as a plugin library to make plugins available to other wikis (requires the TWederBob plugin on the other wikis to connect)
  • Inter-server federation. Different Bob servers can communicate to share tiddlers and as chat servers/relays
  • HTTP API for interacting with the server

A lot of the documentation is in the tiddler files in the Documentation folder of the plugin, or in the wiki in the plugin information on the control panel.

How do I set it up?

Easiest Version (Bundled Application)

To make this more accessible to people I made it so you can download a single file and then run it and everything should work. When you run it it should even open the wiki in your default browser.

To do use this go here (https://github.com/OokTech/TW5-BobEXE) and download the file for your system (BobLinux for linux, BobWin.exe for windows and BobOSX for mac). Then run the file.

  • On windows it may ask if you want to allow node through your firewall. Say yes. If you have anti-virus software it will probably say that it is from an untrusted developer and suggest that you don't use it.

It will create an index wiki in the same folder where you run the file, so if you want you can copy the file somewhere else. If you want to move it after you have run it the first time just be sure to copy the IndexWiki folder to the same location or it will create a new one without any changes you have made.

Manual Version

If you are familiar with using tiddlywiki on node than you just need to put the plugin into your plugins folder and include it in your tiddlywiki.info file. For the moment this plugin must be located in the OokTech/Bob subfolder of your plugins folder and listed as OokTech/Bob in the tiddlywiki.info file. You start the server using the wsserver command instead of the server command.

Also see Configuration.md.

Step by step instructions (using Node)

If you want to use a fresh local install of tiddlywiki here are command line instructions:

Clone the tiddlywiki repo and get the plugin (Only do this the first time to install everything):

git clone --depth=1 --branch v5.1.22 https://github.com/Jermolene/TiddlyWiki5.git
git clone --depth=1 https://github.com/OokTech/TW5-Bob.git TiddlyWiki5/plugins/OokTech/Bob
mkdir TiddlyWiki5/Wikis
cp -r TiddlyWiki5/plugins/OokTech/Bob/MultiUserWiki TiddlyWiki5/Wikis/BobWiki/

After that is finished, and to start up tiddlywiki later type:

cd TiddlyWiki5
node ./tiddlywiki.js Wikis/BobWiki  --wsserver

In a browser go to 127.0.0.1:8080 and the wiki should load. From here any tiddlers you create should have .tid files created in the Wikis/BobWiki/tiddlers folder, any edits you do to those files should be immediately reflected in the browser. Open the tiddler called $:/ServerIP, if you go to the ip address listed there on port 8080 (on mine right now the tiddler says 192.168.0.15, so I put 192.168.0.15:8080 in the browser of another computer on the same network to access the wiki). Now any changes you make to tiddlers on one computer will be reflected almost immediately on the other, and any changes you make to tiddlers or the file system will be almost immediately reflected in all connected wikis.

If you want to use the global tiddlywiki install you have to set the environment variable TIDDLYWIKI_PLUGIN_PATH and TIDDLYWIKI_EDITION_PATH to the folder where you have your plugins. On OSX or Linux you open a terminal and type these commands:

export TIDDLYWIKI_PLUGIN_PATH="/path/to/your/plugins"
export TIDDLYWIKI_EDITION_PATH="/path/to/your/editions"
tiddlywiki editions/BobWiki  --wsserver

If you want to change settings see Configuration.md for information.

Updating Bob on a manual install

When a new version of Bob is released you can update your plugin like this. If you followed the instructions above exactly than you use this. If you cloned the repo elsewhere than you need to cd into the folder where you cloned the plugin.

You can do this to make sure you have the most recent version, running this command when you already have the newest version does nothing and won't break anything so you can try it if you are not sure without worrying.

In a terminal type these commands:

cd TiddlyWiki5
cd plugins/OokTech/Bob
git pull

Updating TiddlyWiki on a manual install

This is to update your version of tiddlywiki, not Bob.

When TiddlyWiki release a new version you need to update your TiddlyWiki version also. This assumes that you followed the above instructions exactly. If you cloned the TiddlyWiki repo somewhere else than you have to cd into that folder instead.

In a terminal type these commands:

cd TiddlyWiki5
git fetch --all --tags --prune
git checkout tags/v5.1.22

To use future or previous versions you would change the 5.1.22 in the last command to match the version number you want to use.

Notes

NOTE 1 - .meta files: there isn't full support for .meta files. The only currently known limitation is that when you rename either the .meta file or the file it describes the changes aren't correctly reflected in the browsers. Renaming in the browser works as expected. Also empty .tid files are created for any tiddler with a _canonical_uri field in addition to the .meta file. This has no effect on the wiki.

NOTE 2 - command line arguments and configuration: I am terrible with command line arguments. To prevent the need to have 10 or 15 command line arguments in order to fully configure a wiki I instead added a settings folder in the same folder that holds the tiddlers folder and the tiddlywiki.info file. Inside this folder there is a settings.json file that you can use the configure the wiki. This also lets you change the wiki's settings from within the wiki. Most of the settings wouldn't take effect until the wiki server is reset, so I made a way to reset the wiki server from inside the wiki. You can also shutdown the wiki server from inside the wiki.


More Details

Here is a more detailed list of things added or changed by this plugin

  • Create new wikis from an interface inside the wiki
    • Create wikis using editions
    • Create wikis from existing single html file wikis
    • Create wikis using tiddlers drawn from other existing wikis
    • Add existing node wikis so that they are served by Bob
  • Serve normal node wikis with all the features of Bob
  • Two-way real-time syncing between the browser and file system
    • Updates the wiki in the browser immediately when any changes are made to the file system
    • Immediately save changes to tiddlers made in the browser to the file system
    • Syncing can ignore tiddlers based on an editable exclude filter
    • If the browser is disconnected from the server it can reconnect when the server is accessible again and sync the changes that happened. The syncing is two-way so the browser gets any changes from the server and the server gets changes from the browser.
      • Conflicts are displayed for you to handle.
  • Multi-User support
    • Allows any number of people/computers/browser tabs to connect to the wiki server and use or edit the same wiki(s) simultaneously.
    • Prevents multiple people from editing the same tiddler at the same time by disabling the edit button for tiddlers currently being edited
  • Multi-Wiki support, the plugin can serve multiple wikis at once, each served wiki has all the features listed here.
  • Websockets!! (used on the back-end, can be used by other plugins in the future)
    • Adds a websocket interface to tiddlywiki (currently only used by this plugin, a git plugin is currently being developed)
    • Adds an action widget that allows you to send arbitrary websocket messages to the server. This can be used to do things like trigger shell scripts from inside the wiki.
  • Adds a new command wsserver that starts up a minimal http and websocket server used for the real-time communication between the browser and server.
  • Adds a new command externalserver which starts up the wiki without a server so that you can use an external server, like an expressjs server.
  • Allows you to shutdown the tiddlywiki server from the browser using a websocket message.
  • Lets you run shell scripts from inside the wiki
  • Everything is configurable from inside the wiki
  • Your connection to the server is monitored and you are warned if there is a problem
    • If the browser disconnects from the server you can reconnect.
    • If the server was shutdown/restarted than you need to reload the page to reconnect.
  • Serve files from the local file system (like images) so that they can be used in the wiki.
  • Build a single file version of any served wikis from within the wiki.
  • Share tiddlers between the wikis using the internalFetch mechanism
  • Build single file wikis that take tiddlers from different wikis
  • Inter-server federation
    • Chat (see below)
    • Wiki syncing
      • optionally using a filter to limit which tiddlers are synced
    • fetch/push tiddlers from/to other servers
  • Chat
    • Local chat works between different wikis/connections to the same Bob server
    • Federated chat works between different Bob servers.
  • Plugin library
    • The server can act as a plugin library for other wikis
    • The library can be updated by plugin authors without having to have access to the server
    • The library can be updated directly from github/gitlab/other git server
  • coming soon Exclude lists on a per-wiki and per-user basis
  • under consideration Security and authentication to limit access and editing