gOSWI (Go OpenSimulator Web Interface) is a Web-based, backend administration console for virtual world grids running the OpenSimulator software.
Note: if you don't know what OpenSimulator is, then very likely you won't need this package ever!
Note: Some knowledge of the Go programming language is definitely required; a working Go environment is an absolute necessity!
- Make sure you have a fairly recent version of the Go environment installed for your system; use your operating system's favourite package manager or follow the instructions
- Install the developer version of ImageMagick, preferably version 7, according to the GoGraphics
imagick
instructions - Make sure you have a working, command-line C/C++ compiler installed on your system (e.g.,
clang
, GCC, Roslyn, mingw, Xcode for macOS...); if you're on Unix or any of its variants, you should be good to go - Run (under an unprivileged user) the following command on your local shell:
If this is the first time compiling anything in Go, this step will populate your home directory with quite a lot of files (under
export CGO_CFLAGS_ALLOW='-Xpreprocessor' go build github.com/GwynethLlewelyn/goswi
~/go
), and the overall compilation may take some time to complete. The Go toolchain is notoriously silent, so you might wish to append a-v
for some additional verbosity. - If all went well, you should have an executable file called
goswi
on the same directory (possiblygoswi.exe
if you've attempted to compile it under Windows) - Note that you can run it from the console, but it's much more likely that you wish to set it up as a proper service (running in the background); also note that
goswi
will need some directories to be present - Now skip the next chapter and go straight to the Configuration section!
While OpenSimulator adds a lot of base functionality to pretty much run everything 'out of the box', historically, a handful of functions were deliberately left out of the 'core' system, and left to third-party modules in C#, or, through a few APIs (mostly using XML-RPC, but not all), delegated to external systems (thus allowing a distributed approach in terms of deployment of a 'whole' grid). Relatively simple things (such as the 'splash screen' — what is shown when you select a grid on Firestorm and other OpenSimulator-compatible viewers) as well as much complex ones (such as running the economy system) have been pushed out of the core code, for several reasons, including ideological/theological ones (i.e. the concept that OpenSimulator-based grids should not have an economy because the love of money is the root of all evil — defended both by extreme-left, atheist, progressive activists, as well as right-wing, conservative Christians), legal ones (running a virtual economy might be illegal in several jurisdictions, or at least require a special license to do so), and practical ones (the 'splash screen' is often used to convey information about the grid which may rely upon statistics processed 'outside' the core OpenSimulator code).
Another area that is underdeveloped is the management of local grid users. Although OpenSimulator includes some console commands to do some user management — basically, creating users, changing their passwords, or email addresses — which is more than enough for a small grid of close-knit developers and content creators, running a large grid, with hundreds of thousands of users, each being able to have multiple 'alts', belonging to different groups, etc. is far beyond the purpose of the 'simple' console commands. Similarly, OpenSimulator doesn't even come with tools to do estate management — although it's fully supported (newly created regions, for instance, must be assigned to an existing estate), the whole backoffice mechanisms to deal with them are left for third-party developers to do. You can always do everything manually, using phpMyAdmin and doing the changes directly on the database, but this approach, again, is just meaningful for managing a handful of estates.
Thus, since OpenSimulator's inception, several 'grid management solutions' have been around, many of which free and open-source. Some are merely plugins for larger content management systems (such as jOpensim for Joomla, Xoopensim for XOOPS, d4os for Drupal); others are standalone (see a 'complete' list on http://opensimulator.org/wiki/Webinterface); most, unfortunately, have stopped their development ages ago. This is especially true of PHP administration tools which relied on pre-PHP PDO functions to connect to the database; unfortunately, such functions have been deprecated and require a lot of time to rewrite... I tried to do that with Xoopensim, but after two weeks of making change after change, and stumbling over and over again on deprecated usage of old PHP functions, I gave up.
Therefore, this project was born — not in PHP, not in C# (which I hate with passion), but in Go — because it's easy to compile in pretty much everything out there (and I revere the creators of Go with all my heart!). If you're not really willing to learn how to do Go programming and/or basic installation, no worries, you will just need to get the appropriate binaries (once I compile them, of course).
-
Because Second Life® and OpenSimulator internally use JPEG2000 for all images (including raw map tiles), we have to convert those to browser-friendly images, which we'll do with ImageMagick 7 — so make sure you are correctly set up to use the Cgo-based ImageMagick wrapper:
- Install ImageMagick according to https://github.com/gographics/imagick (choose version 7)
- If you're on Ubuntu/Debian Linux, which are still mostly stuck with ImageMagick 6.9, you might be able to install all required dependencies from the Debian repositories. Take a peek at the GitHub action to compile the code to get a list of the fundamental packages that are needed. Note that GitHub, when running this action, will essentially start with a fresh, clean container, and has to install everything it needs; your mileage may vary (an 'unclean' environment might either not require so many things to be installed, or, worse, get blocked with some dependency conflicts)
- Make sure that your particular version of ImageMagick supports
JP2
(that's JPEG2000) - Don't forget to set
export CGO_CFLAGS_ALLOW='-Xpreprocessor'
in your shell. My apologies for having to resort to ImageMagick, but there is no native Go library to decode JPEG2000 images; believe me, I've tried a lot of alternatives (including several kinds of external applications/commands). Decoding JPEG2000 is immensely complex (even if the code to do so in C is open source) and way, way, way beyond my abilities as a programmer
-
Copy
config.sample.ini
toconfig.ini
and adjust for your system (namely, adding the DSN to connect to your database) -
To get a fully-functional map, adjust
assets/js/leaflet-gridmap.js
with your system's configuration -
Do not forget to set
cookieStore
to a randomly generated password! -
Note that by default
gOSWI
will try to loadconfig.ini
from the directory where you've got your sources (e.g. if you usedgo get -u github.com/GwynethLlewelyn/goswi
, then the path will be set to~/go/src/github.com/GwynethLlewelyn/goswi
); the same applies to the static files under./templates/
,./lib
, and./assets/
— no matter where you actually place the compiled binary. You can change that behaviour by changing thetemplatePath
(which actually changes more than that) and passing the-config
parameter directly to the compiled binary (or, at best, have theconfig.ini
in the same directory as the executable) -
I had to move from session storage in cookies to a memory-based approach, simply because the session data stored in cookies was growing and growing until it blew the established 4K limit. Now, if the application is not running, all the stored session data is lost. I've been toying around the following possibilities:
- Using either Redis/memcached as permanent KV storage for the session data; this, however, requires that people configure one of those servers, and I'd have to offer several possibilities: check if either Redis/memcached is running and call the appropriate library (but all would have to be compiled into the code — or offer a tag-based approach for compiling with one or the other option), and, if not, fall back to the memory store
- Adapt Gin-Gonic to use the Gorilla FileSystem storage (Gin-Gonic sessions use Gorilla sessions underneath)
- Adapt Gin-Gonic to use one of the embedded KV stores I'm already using for persisting data (e.g. the image cache)
- Use browser-based local storage to replace cookies (which I wasn't originally aware of)
I haven't still decided what I'll do...
If you wish to use TLS (i.e. HTTPS), just add the full path to your certificate file (tlsCRT
) and private key (tlsKEY
). Obviously you can use self-signed certificates if you wish — the main advantage is not only privacy, but also getting HTTP/2 support, PageSpeed support, and everything you can get these days over TLS which you cannot get over an unencrypted HTTP/1.1 connection.
The latest versions come with (experimental) support for New Relic instrumentation (embedded Go agent). Setting it up is as easy as registering for the free version of New Relic, adding a new (Go) app and grabbing your license key. You'll only need to add the app name and the license key to config.ini
, and, in theory at least, you'll be getting data on your New Relic console. Instrumentation is done via middleware, which is only active if gOSWI manages to get a valid connection to New Relic (thus, if you see any problems or slowdown, you can just remove the configuration, and no extra code will be running).
Second Life® is a registered trademark of Linden Lab.
OpenSimulator is a trademark of the The OpenSimulator Project.
Redis, memcached, New Relic, Go are trademarks of their respecive owners.
JPEG2000 is a registered trademark of the Joint Photographic Experts Group (JPEG) committee.
The gopher (the Go mascot) is an original design created by renowned illustrator Renne French and released with a Creative Commons Attribution 3.0 (Unported) License, to be used on Go-related projects, but is not the official logo.
Parts of the OpenSimulator logo, released under a Creative Commons Attribution 2.5 Australia (CC BY 2.5 AU) were shamelessly scavenged and ravaged by yours truly.
The fonts used are, per Google's v.1.9.5 guidelines for Go-related things, Work Sans, licensed under Open Font License, and Roboto, licensed under an Apache 2.0 License.
The template used, SB Admin 2, has been developed by Start Bootstrap — created and maintained by David Miller — and is based on the Bootstrap framework created by Mark Otto and Jacob Thorton. It is released under a MIT license.
I've tried to stick to their original files for as long as I could (merely linking to them), but, over time, I had to make more and more changes to them. CSS was getting so many exceptions that I had to create my own file. It's not minified, since I use all sorts of caches and proxies in front of my setup — namely Cloudflare and Google's PageSpeed module for nginx
— so I don't worry a lot about 'minification'.
Most colours come from the awesome Nord colour palette, released under a MIT license. I have to admit that I'm in love with that colour scheme, and abuse and overuse it pretty much everywhere. Fortunately, if you hate it, it should be quite easy to change to something else!
Some code was inspired on OpenSim Web Interface Redux (OpenSimWIRedux) as well as the connection to the Remote Admin XML-RPC as provided by Marcel Edward. At the time of writing this, OpenSimWIRedux is currently going through a code rewrite and not fully operational, but you can still look at its files.
The grid map also requires mentioning its own licensing. It uses various sources: the actual component that displays map tiles is Leaflet. The overall inspiration also comes from OpenSimWIRedux, but they never adopted Leaflet — but stick to the Google Maps API. Because the Google Maps API has been so widely abused, Google has placed very harsh restrictions on its usage. You need to register for a key (or your tiles will have watermarks — even if they are your tiles...). You cannot include the Google APIs in anything remotely 'commercial' (not even if you have, say, a website for a non-profit which 'sells' a product for a fee to raise funds) — to do so, you need to purchase a commercial license. Even though 'personal use' is allowed and even encouraged, it requires publishing your key to anyone who downloads your software (this is exactly what OpenSimWIRedux does — who knows which key they're using...), which, IMHO, is not a good idea.
Other OpenSimulator Web Interfaces, such as MWI by Myopengrid — which I used profusely for many years — have their own solution for tile visualisation (MWI has not been updated since 2014 and uses a version of Laravel which is so ancient that it's not even referred to on the official website). By contrast, Linden Lab switched from their own in-house solution, which worked reasonably well in the olden times, then to the Google Maps API, and finally to Leaflet, which works far better. After much digging around, you can see that the page for https://maps.secondlife.com/ includes a full version of Leaflet (1.4.0 at the time of writing), to which, after line 8600 or so, Linden Lab has added their own code to use Leaflet. This code is preceded by a MIT-like license, which means that I'm able to reuse it and modify it, so long as I retain their copyright notice from 2016. There have been many changes and simplifications to LL's original code. I'm happy to report that it works flawlessly :-)
The Libravatar code is partially inspired on Surrogator, written in PHP by Christian Weiske ([email protected]) and licensed under the AGPL v3 or later.
All favicons were generated by RealFaviconGenerator.
Some packages imported by this application include different licenses, which may or may not be relevant if you wish to freely distribute a version of my code; you might require either to comply with their own licensing terms, or replace them with alternatives:
-
The go-sql-driver package, which allows direct connection to a MySQL server using native Go code (i.e. without requiring linking to an external C library):
This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with this file, you can obtain one at http://mozilla.org/MPL/2.0/.
Drop-in replacements exist (namely, those using a C library!), since the code accesses the database via the standard
database/sql
module. -
The gokv module, a simple key-value store abstraction and implementations for Go, which serves as a front-end to a lot of different possible implementations. It uses the Mozilla Public License Version 2.0 as well.
It can, if needed, be fully replaced by any other key-value store module (especially one that might be less abstract); however, it will require some code rewriting.
-
The New Relic Go Agent. While most software provided by New Relic is encumbered by some licensing restrictions, their Go Agent, used for instrumenting this package, is fully open-sourced under the Apache 2.0 License.
If you do not wish to abide by the Apache 2.0 License in your own code, the simplest solution is to remove all references to the New Relic instrumentation, and/or replace it by a different solution. This is not required in the least to get gOSWI working.
In case you need it to send me encrypted emails: