Wifi

From OpenSimulator

(Difference between revisions)
Jump to: navigation, search
(Remove specific licence text, as its now included in the Wifi distributions as of 9-Aug-2010)
m
 
(101 intermediate revisions by 12 users not shown)
Line 1: Line 1:
 +
{{quicklinks|Wifi}}
 +
{{thirdparty}}
 
'''Wifi - A Simple Account Management Front-end'''
 
'''Wifi - A Simple Account Management Front-end'''
  
"Wifi" stands for "Web Interface For... I" and is an '''add-on''' module that '''IS NOT IN THE CORE''' of OpenSim. It is provided by Diva Canto and can be added to OpenSim 0.7 onwards.  Please do not ask the core OpenSim team for support.
+
"Wifi" stands for "Web Interface For... I", and is an '''add-on''' module which is not a standard part of OpenSimulator. It is provided by Diva Canto and can be added to OpenSimulator 0.7 onwards.  It is also part of the Diva distribution (D2).
  
== Introduction ==
+
== WiFi Module for OpenSim 0.9.1.* Onwards==
  
Initial information is available from http://www.metaverseink.com/blog/?p=37 and is taken here pretty much verbatim for now...
+
OpenSim 0.9.1.0 onwards uses .NET 4.6. Diva's Wifi Module was updated for this on 17-Nov-2019...
  
Wifi provides an embedded Web application for handling user registrations. Wifi is a set of components that can be loaded up by both standalone simulators and Robust servers. It's features include:
+
d2: https://github.com/diva/d2
  
* Account creation, optionally controlled by the administrator
+
diva-distribution: https://github.com/diva/diva-distribution
* Configurable default avatars for new accounts
+
* Account updates by both users and administrator
+
* Account deletion by administrator
+
* Password recovery via email
+
* Simple user inventory management
+
* Welcome page which can be used as viewer -loginpage
+
  
Wifi has a few interesting properties that make it a good fit for small-to-medium OpenSimulator-based virtual worlds.
+
Additional post for Windows Wifi build updating for 0.9.1.* (based on .NET Framework 4.6)...
 +
[http://blog.inf.ed.ac.uk/atate/2018/12/12/diva-wifi/ Austin Tate Blog Post – Diva Wifi on Windows – 12-Dec-2018]
  
* First of all, it doesn’t require the installation of Apache or other Web servers; it’s all done within the OpenSimulator code base.
+
== WiFi Module for OpenSim 0.8.1 to 0.9.0.1 ==
* Second, using the OpenSimulator code base brings many technical benefits. This isn’t an immediate benefit, but it is a benefit in the long run. Unlike the Apache-based Web apps that interface with the DB directly, Wifi interfaces with the OpenSimulator services layer using the core code, and therefore it is isolated from future changes to the OpenSimulator DB schema.
+
* Third, technically, Wifi is a set of components that can be loaded up by both standalone simulators and Robust servers.
+
  
== Diva Distribution ==
+
Up to OpenSim 0.8.0, Wifi was available as an add on module via compiled .DLL libraries which could be enabled for Standalone and Grid setups. From OpenSim 0.8.1 onwards, a more flexible “add-in” library mechanism that was already in OpenSim has been improved and Wifi now is provided as an add-in under that mechanism. This does mean that the build and configuration process is different.
  
[[Image:Diva-Tagus-Wifi-Example.jpg|400px|right|Example Wifi Entry Page]]
+
Diva Canto has provided a blog post which describes the new Wifi mechanism and how to build and configure it, mostly geared at Unix/Linux users.
  
Wifi is included and enabled by default in the Diva Distribution:
+
[http://metaverseink.com/blog/?p=592 Diva Canto Blog Post – Wifi and Other Diva Addons – 5-Apr-2015]
  
* Documentation: http://wiki.github.com/diva/d2/wifi
+
Additional post for Windows Wifi build from 0.8.1 up to 0.9.0 (based on .NET Framework 4.0)... [http://blog.inf.ed.ac.uk/atate/2015/04/06/diva-wifi-on-windows/ Austin Tate Blog Post – Diva Wifi on Windows – 6-Apr-2015]
* Blog Description: http://www.metaverseink.com/blog/
+
* Downloads and binary distribution: http://github.com/diva/d2/downloads
+
* Source Code: http://github.com/diva/diva-distribution/
+
<br style="clear: both" />
+
== Adding Wifi to your OpenSim Setup ==
+
  
'''Additions to Standard OpenSim Distribution (from 0.7 onwards)'''
+
Additional Testing VS2017 (Win10) + Mono 5.18 Xamarin msbuild (Ubuntu 18)
  
=== Binary Approach ===
+
== Introduction ==
 +
'''
  
Obtain the latest Wifi module distribution zip from
+
<!-- Initial information is available from http://www.metaverseink.com/blog/?p=37 and is taken here pretty much verbatim for now... -->
http://github.com/diva/d2/downloads
+
Wifi provides an embedded Web application for handling user registrations. Wifi is a set of components that can be loaded up by both standalone simulators and [[ROBUST]] servers.  
and place the files as instructed in the equivalent locations in your OpenSim directory.
+
  
bin directory
+
Its features include:
* add bin/Diva.Wifi.dll
+
* add bin/Diva.Wifi.ScriptEngine.dll
+
* add bin/Diva.OpenSimServices.dll
+
  
Copy WifiPages directory and its contents to OpenSim top level directory.
+
* Account creation, optionally controlled by the administrator
 +
* Configurable default avatars for new accounts
 +
* Account updates by both users and administrator
 +
* Account deletion by administrator
 +
* Password recovery via email
 +
* Simple management of user inventory <!-- What does this mean? Do admins get to go through a user's inventory at will? Or does it simply mean that a user can empty his/her trash folder through the web interface? -->
 +
* A welcome page which can be used as login page for the user's viewer.
  
doc directory
+
Wifi has a few interesting properties that make it a good fit for small-to-medium OpenSimulator-based virtual worlds.
* add in doc/WIFI.txt
+
  
Copy over the WIFI releated readme, release notes and licence.
+
# It doesn’t require an additional web server; it’s all done with built-in OpenSimulator features.
 
+
# Using OpenSimulator features bring many technical benefits. These benefits aren't visible immediately, but it will show its value in the future. Unlike other Web apps that access the database directly, Wifi works by communicating with OpenSimulator directly. This means that any future changes to the OpenSimulator database structure, will not affect Wifi.
Modify the [Services] section of OpenSim.ini (for Standalones) or Robust(.HG).ini for Grids
+
# Technically speaking, Wifi is a set of components that can be used by both standalone sims, as well as [[ROBUST]] (Grid) servers.
* in [Startup] section add 8002/Diva.Wifi.dll:WifiServerConnector to service connectors
+
* add [WifiService] section from example at: http://github.com/diva/diva-distribution/blob/master/addon-modules/Wifi/Wifi.ini.example
+
 
+
=== Source Code Approach ===
+
 
+
Get Diva Distribution which contains the Wifi modules from
+
http://github.com/diva/diva-distribution/
+
 
+
== Setting Configuration Parameters ==
+
 
+
The complete example file is here:
+
http://github.com/diva/diva-distribution/blob/master/addon-modules/Wifi/Wifi.ini.example
+
 
+
'''Additions to Robust.ini or Robust.HG.ini for Grids'''
+
 
+
  [Startup]
+
    ServiceConnectors = "8002/Diva.Wifi.dll:WifiServerConnector"
+
 
+
Note that it will be usual to specify the port number to be accessible outside your firewall (normally port 8002) rather than the default Network Port for internalinter-component OpenSim traffic (normally port 8003) which can be set to only be accessible within a firewall.
+
 
+
'''OR Additions to OpenSim.ini for Standalones'''
+
 
+
  [Startup]
+
    ServiceConnectors = "Diva.Wifi.dll:WifiServerConnector"
+
  [Network]
+
    port = 9000
+
 
+
'''Additions to OpenSim.ini or in separate addon-modules/Wifi/config/Wifi.ini'''
+
 
+
  [WifiService]
+
    GridName = "grid name"
+
    LoginURL = "[http://<hostname>:9000|http://<hotsname>:9000]"
+
    WebAddress = "[http://<hostname>:9000|http://<hostname>:9000]"
+
     
+
    ;; The Wifi Administrator account
+
    AdminFirst = "Wifi"
+
    AdminLast = "Admin"
+
    AdminEmail = "you@example.com"
+
   
+
    ;; Do you want to be able to control grid registrations?
+
    AccountConfirmationRequired = false
+
   
+
    FemaleAvatarAccount = "Female Avatar"
+
    MaleAvatarAccount = "Male Avatar"
+
    NeutralAvatarAccount = "Neutral Avatar"
+
   
+
    ;; Variables for your mail server
+
    ;; Users will get email notifications from this account.
+
    SmtpHost = "mail.example.com"
+
    SmtpPort = "587"
+
    SmtpUsername = "your_account_in_this_mail_server"
+
    SmtpPassword = "your_password_in_this_mail_server"
+
  
 
== Configurable Default Avatars ==
 
== Configurable Default Avatars ==
 
+
[[Image:Openvue-avatars-male-female-neutral-2010-08-27.jpg|300px|right|Example Avatars]]
When users sign up, they can choose between 3 avatars: male, female and neutral. It's up to you to decide what these 3 default avatars loolike. Here is how you can configure them.
+
When users sign up for an avatar account vua WiFi, they can choose between default avatars. It's up to you to decide what these default avatars look like. Here is how you can configure them... Once your OpenSimulator is up and running, create accounts (using Wifi) with the names given in your configuration. These might be:
 
+
Once your OpenSim is up and running, create 3 accounts (using Wifi) with the following names:
+
 
* Male Avatar
 
* Male Avatar
 
* Female Avatar
 
* Female Avatar
Line 121: Line 59:
 
Then login to the world under each of those accounts, and set their appearances however you like. You can add prim attachments.
 
Then login to the world under each of those accounts, and set their appearances however you like. You can add prim attachments.
  
== Problems with HTTP ports ==
+
== Wifi URLs When Operational ==
  
The port used for the Wifi HTTP service is configurable. Usually this will be 8002 for a grid and 9000 for a standalone unless you use custom ports.
+
* Sample grid: <nowiki>http://yourgridhostname:8002/wifi</nowiki>
 +
* Sample standalone: <nowiki>http://yourstandalonehostname:9000/wifi</nowiki>
 +
* Local standalone: <nowiki>http://localhost:9000/wifi</nowiki>
  
For a standalone you can do this by adding the "port" line for the port to use for Wifi and other services to the [Network] section of OpenSim.ini
+
You can see if the Wifi endpoints have been made available by executing the console command "show http-handlers" in the Robust or standalone simulator console as appropriate. If it is active you should see a bunch of endpoints such as
  
  [Startup]
+
<pre>
    ServiceConnectors = "Diva.Wifi.dll:WifiServerConnector"
+
* StreamHandlers (31):
  [Network]
+
        ...
    port = 9000
+
GET:/wifi
 +
HEAD:/wifi
 +
POST:/wifi/notify
 +
GET:/wifi/install
 +
POST:/wifi/install
 +
POST:/wifi/login
 +
GET:/wifi/logout
 +
GET:/wifi/forgotpassword
 +
POST:/wifi/forgotpassword
 +
GET:/wifi/recover
 +
POST:/wifi/recover
 +
GET:/wifi/user/account
 +
POST:/wifi/user/account
 +
GET:/wifi/admin/users
 +
POST:/wifi/admin/users
 +
GET:/wifi/admin/console
 +
GET:/wifi/user/loadinventory
 +
GET:/wifi/user/inventory
 +
POST:/wifi/user/inventory
 +
GET:/wifi/linkregion
 +
POST:/wifi/linkregion
 +
GET:/wifi/tos
 +
POST:/wifi/tos
 +
GET:/wifi/admin/groups
 +
POST:/wifi/admin/groups
 +
</pre>
  
Or for a Grid specify a specific port (usually 8002) for the WifiServiceConnector in the ServiceConnectors list in the [Startup] section Robust(.HG).ini
+
== Wifi Administrator Functions ==
  
  [Startup]
+
=== Manage Users ===
    ServiceConnectors="............,8002/Diva.Wifi.dll:WifiServerConnector"
+
[[Image:Openvue-Wifi-Example.jpg|300px|right|Example Wifi Entry Page]]
 +
If authorisation is set to be on, you will receive an e-mail to the nominated admin account e-mail address if a user requests a new account and avatar creation. You can activate or delete new user creation requests. Users are notified of the activation via an e-mail to their nominated address.
  
In either case, define the equivalent WebAddress in the [WifiService] section of your Opensim.ini (or addon-modules/Wifi/config/Wifi.ini if used in future).  
+
You can also search for users and change their details. Give a space as a search term to select all avatars. Available are fields for "Level", "Flags" and "Title".
 +
* Level = 0 is a normal user
 +
* Level = 50 (or a level you set) is used to indicate a privileged user (e.g. who can set up new hypergrid linked regions)
 +
* Level = 100 is a Wifi admin account user
  
  [WifiService]
+
You can manually reset a user's password by typing into the password box and the hitting the "Reset" button. Note that the user is '''NOT''' infromed of this password reset, so you must manually contact the user to communicate such a password change.
    WebAddress = "http://hostname:8002"
+
  
If you do not use the usual Opensim service ports, please note that some network setups and ISPs will not allow HTTP to be served on port 80. It is usual to use an alternative port such as 8080 or a custom port in that case.
+
Note that the Wifi admin username/avatar is set in the Wifi configuration, and can be changed there. BUT.. '''once an admin always an admin'''. Well almost. If you change from one admin to another, the previous avatar still has administrator rights. You can remove Wifi administrator rights from an avatar by changing the "Level" of the user from 100 to the normal avatar level of 0 using the Manage Users facility in Wifi.
  
== Wifi URLs When Operational ==
+
You can set an intermediate level for a '''privileged''' user which can be used to allow certain types of Wifi menu that a normal user will not see, but that are less than full admin user rights. A configurable parameter sets the '''Level''' above which this functions for a user (default 50).
  
* Sample Grid: http://yourgridhostname:8002/wifi
+
=== Manage Regions ===
* Sample Standalone: http://yourstandalonehostname:9000/wifi
+
* Local Standalone: http://localhost:9000/wifi
+
  
'''Examples'''
+
A facility to add '''LINK REGIONS''' is available in Wifi versions for OpenSimulator 0.7.1 onwards.
  
* Diva Tagus Test World (temporary August 2010): http://tagus.ics.uci.edu:9000/wifi
+
Administrators and other '''privileged''' users can also view the current set of '''LINKED REGIONS'''
  
== Wifi Administrator Functions ==
+
=== Remote Console ===
  
=== Manage Users ===
+
A feature in Wifi versions for 0.7.1 onwards and available to administrators via the '''CONSOLE''' link if suitably enabled.
  
If authorisation is set to be on, you will receive an e-mail to the nominated admin account e-mail address if users request a new account and avatar creation. You can activate or remove new user creation requests. Users are notified of the activation via an e-mail to their nominated address.
+
The WifiConsole uses OpenSim's REST console and thus the Robust server and any simulators must be started with parameter "-console rest". Furthermore, the configuration options "ConsoleUser" and "ConsolePass" must be set in section [Network] and the values of these options must match across all instances. Finally, for all region simulators (i.e. except for the Robust server), option "ConsoleAllowedOrigin" must be set to the same value as option "WebAddress" in section [WifiService] of the Robust configuration.
  
You can also search for users and change their details. Give a space as a search term to select all avatars. Available are fields for "Level", "Flags" and "Title".
+
Please note that as at February 2011 the console in Wifi is not much more than a proof on concept in its current state. It has been tested on web browsers based on Mozilla (i.e. the Gecko Engine) only. Browsers using the WebKit engine do work somewhat, too, and IE has its own issues. The console also does not yet work with any interactive input, as necessary for creating a new region with "create region", for example.
* Level = 0 is a normal user
+
* Level = 100 is a Wifi admin account user
+
  
Note that the Wifi admin username/avatar is set in the Wifi configuration, and can be changed there.  BUT.. '''once an admin always an admin'''. Well almost. If you change from one admin to another, the previous avatar still has administrator rights. You can remove Wifi administrator rights from an avatar by chnaging the "Level" of the user from 100 to 0 using the Manage Users facility in Wifi.
+
Right now, there is no way to use this feature in a secure way because the values for "ConsoleUser" and "ConsolePass" are transmitted as clear text over the network. Please keep this in mind when using the console in Wifi.
  
=== Manage Regions ===
+
== Diva Distribution ==
  
Future functionality.
+
[[Image:Diva-Tagus-Wifi-Example-v2.jpg|300px|right|Example Wifi Entry Page]]
  
<br style="clear: both" />
+
Wifi is included and enabled by default in the [[Diva Distribution]]:
[[Image:Openvue-Wifi-Example.jpg|400px|right|Example Wifi Entry Page]]
+
 
<br style="clear: both" />
+
* Documentation: http://wiki.github.com/diva/d2/wifi
 +
* Blog Description: http://www.metaverseink.com/blog/
 +
* Downloads and binary distribution: http://metaverseink.com/Downloads.html
 +
* Source Code: http://github.com/diva/diva-distribution/

Latest revision as of 07:33, 20 July 2024


Wifi - A Simple Account Management Front-end

"Wifi" stands for "Web Interface For... I", and is an add-on module which is not a standard part of OpenSimulator. It is provided by Diva Canto and can be added to OpenSimulator 0.7 onwards. It is also part of the Diva distribution (D2).

Contents

[edit] WiFi Module for OpenSim 0.9.1.* Onwards

OpenSim 0.9.1.0 onwards uses .NET 4.6. Diva's Wifi Module was updated for this on 17-Nov-2019...

d2: https://github.com/diva/d2

diva-distribution: https://github.com/diva/diva-distribution

Additional post for Windows Wifi build updating for 0.9.1.* (based on .NET Framework 4.6)... Austin Tate Blog Post – Diva Wifi on Windows – 12-Dec-2018

[edit] WiFi Module for OpenSim 0.8.1 to 0.9.0.1

Up to OpenSim 0.8.0, Wifi was available as an add on module via compiled .DLL libraries which could be enabled for Standalone and Grid setups. From OpenSim 0.8.1 onwards, a more flexible “add-in” library mechanism that was already in OpenSim has been improved and Wifi now is provided as an add-in under that mechanism. This does mean that the build and configuration process is different.

Diva Canto has provided a blog post which describes the new Wifi mechanism and how to build and configure it, mostly geared at Unix/Linux users.

Diva Canto Blog Post – Wifi and Other Diva Addons – 5-Apr-2015

Additional post for Windows Wifi build from 0.8.1 up to 0.9.0 (based on .NET Framework 4.0)... Austin Tate Blog Post – Diva Wifi on Windows – 6-Apr-2015

Additional Testing VS2017 (Win10) + Mono 5.18 Xamarin msbuild (Ubuntu 18)

[edit] Introduction

Wifi provides an embedded Web application for handling user registrations. Wifi is a set of components that can be loaded up by both standalone simulators and ROBUST servers.

Its features include:

  • Account creation, optionally controlled by the administrator
  • Configurable default avatars for new accounts
  • Account updates by both users and administrator
  • Account deletion by administrator
  • Password recovery via email
  • Simple management of user inventory
  • A welcome page which can be used as login page for the user's viewer.

Wifi has a few interesting properties that make it a good fit for small-to-medium OpenSimulator-based virtual worlds.

  1. It doesn’t require an additional web server; it’s all done with built-in OpenSimulator features.
  2. Using OpenSimulator features bring many technical benefits. These benefits aren't visible immediately, but it will show its value in the future. Unlike other Web apps that access the database directly, Wifi works by communicating with OpenSimulator directly. This means that any future changes to the OpenSimulator database structure, will not affect Wifi.
  3. Technically speaking, Wifi is a set of components that can be used by both standalone sims, as well as ROBUST (Grid) servers.

[edit] Configurable Default Avatars

Example Avatars

When users sign up for an avatar account vua WiFi, they can choose between default avatars. It's up to you to decide what these default avatars look like. Here is how you can configure them... Once your OpenSimulator is up and running, create accounts (using Wifi) with the names given in your configuration. These might be:

  • Male Avatar
  • Female Avatar
  • Neutral Avatar

Then login to the world under each of those accounts, and set their appearances however you like. You can add prim attachments.

[edit] Wifi URLs When Operational

  • Sample grid: http://yourgridhostname:8002/wifi
  • Sample standalone: http://yourstandalonehostname:9000/wifi
  • Local standalone: http://localhost:9000/wifi

You can see if the Wifi endpoints have been made available by executing the console command "show http-handlers" in the Robust or standalone simulator console as appropriate. If it is active you should see a bunch of endpoints such as

* StreamHandlers (31):
        ...
	GET:/wifi
	HEAD:/wifi
	POST:/wifi/notify
	GET:/wifi/install
	POST:/wifi/install
	POST:/wifi/login
	GET:/wifi/logout
	GET:/wifi/forgotpassword
	POST:/wifi/forgotpassword
	GET:/wifi/recover
	POST:/wifi/recover
	GET:/wifi/user/account
	POST:/wifi/user/account
	GET:/wifi/admin/users
	POST:/wifi/admin/users
	GET:/wifi/admin/console
	GET:/wifi/user/loadinventory
	GET:/wifi/user/inventory
	POST:/wifi/user/inventory
	GET:/wifi/linkregion
	POST:/wifi/linkregion
	GET:/wifi/tos
	POST:/wifi/tos
	GET:/wifi/admin/groups
	POST:/wifi/admin/groups

[edit] Wifi Administrator Functions

[edit] Manage Users

Example Wifi Entry Page

If authorisation is set to be on, you will receive an e-mail to the nominated admin account e-mail address if a user requests a new account and avatar creation. You can activate or delete new user creation requests. Users are notified of the activation via an e-mail to their nominated address.

You can also search for users and change their details. Give a space as a search term to select all avatars. Available are fields for "Level", "Flags" and "Title".

  • Level = 0 is a normal user
  • Level = 50 (or a level you set) is used to indicate a privileged user (e.g. who can set up new hypergrid linked regions)
  • Level = 100 is a Wifi admin account user

You can manually reset a user's password by typing into the password box and the hitting the "Reset" button. Note that the user is NOT infromed of this password reset, so you must manually contact the user to communicate such a password change.

Note that the Wifi admin username/avatar is set in the Wifi configuration, and can be changed there. BUT.. once an admin always an admin. Well almost. If you change from one admin to another, the previous avatar still has administrator rights. You can remove Wifi administrator rights from an avatar by changing the "Level" of the user from 100 to the normal avatar level of 0 using the Manage Users facility in Wifi.

You can set an intermediate level for a privileged user which can be used to allow certain types of Wifi menu that a normal user will not see, but that are less than full admin user rights. A configurable parameter sets the Level above which this functions for a user (default 50).

[edit] Manage Regions

A facility to add LINK REGIONS is available in Wifi versions for OpenSimulator 0.7.1 onwards.

Administrators and other privileged users can also view the current set of LINKED REGIONS

[edit] Remote Console

A feature in Wifi versions for 0.7.1 onwards and available to administrators via the CONSOLE link if suitably enabled.

The WifiConsole uses OpenSim's REST console and thus the Robust server and any simulators must be started with parameter "-console rest". Furthermore, the configuration options "ConsoleUser" and "ConsolePass" must be set in section [Network] and the values of these options must match across all instances. Finally, for all region simulators (i.e. except for the Robust server), option "ConsoleAllowedOrigin" must be set to the same value as option "WebAddress" in section [WifiService] of the Robust configuration.

Please note that as at February 2011 the console in Wifi is not much more than a proof on concept in its current state. It has been tested on web browsers based on Mozilla (i.e. the Gecko Engine) only. Browsers using the WebKit engine do work somewhat, too, and IE has its own issues. The console also does not yet work with any interactive input, as necessary for creating a new region with "create region", for example.

Right now, there is no way to use this feature in a secure way because the values for "ConsoleUser" and "ConsolePass" are transmitted as clear text over the network. Please keep this in mind when using the console in Wifi.

[edit] Diva Distribution

Example Wifi Entry Page

Wifi is included and enabled by default in the Diva Distribution:

Personal tools
General
About This Wiki