Created by Daniel Gacitua
NEURONE (oNlinE inqUiRy experimentatiON systEm) is a software platform for simulating an isolated web searching environment and collecting usage information from registered users using the platform. The collected data can be used for building profiles or patterns of user navigation behaviors related to its online inquiry skills.
Some of the statistics that are captured (for each user) with NEURONE are: Login attempts, visited pages, relevant pages for the user (bookmarks), relevant text fragments for the user (snippets), questionnaire responses, task synthesis, mouse movements, click positions and keystrokes.
The web search engine shows only results from a local (thus limited) web page dataset, removing all links. These documents can be customized by the researcher, providing a customized flow of tasks for its simulation.
All NEURONE functionality is described in these manuals:
- NEURONE's Researcher Manual (Explains the simulation aspects, asset generation, study flow building and final data parsing)
- NEURONE's Sysadmin Manual (Describes installation steps in order to deploy NEURONE in a server)
- NEURONE's Developer Manual (General notes for developing new extensions for NEURONE)
Manuals can be downloaded on the "Releases" section of this repository.
NOTE: A Linux development machine is highly recommended.
- In your development machine: Install Meteor 1.6+ and Solr 6.5+ (see instructions below)
- In Solr, create a core (or collection) called
neurone
- Clone this repository (or download as ZIP)
- Open a terminal in NEURONE's source code directory, run
meteor npm install
(this is needed only once) - Now run
meteor npm start
. Edit any files you need, they will be live-reloaded in your local web browser - When you are done, just abort the terminal (i.e.
CTRL+C
)
Run the following command to install Meteor on Linux distributions:
$ curl https://install.meteor.com/ | sh
-
Solr requires Java 8 JDK or greater to run. Run the following commands to install Solr on Linux distributions:
$ cd /tmp $ wget https://archive.apache.org/dist/lucene/solr/8.4.1/solr-8.4.1.tgz $ tar xzf solr-8.4.1.tgz solr-8.4.1/bin/install_solr_service.sh --strip-components=2 $ sudo bash ./install_solr_service.sh solr-8.4.1.tgz
-
Create a new core (collection) in Solr for NEURONE:
$ sudo su - solr -c "/opt/solr/bin/solr create -c neurone -n data_driven_schema_configs"
NOTE: A Linux Virtual Private Server (VPS) or a Linux local machine with SSH access is needed to run this project in production mode. At least 2GB of RAM is required for building Docker images.
The following instructions are for Ubuntu Server, adapt them if another distribution is used:
-
Install required dependencies for Docker
$ sudo apt-get update $ sudo apt-get install ca-certificates curl gnupg lsb-release
-
Add Docker's GPG key
$ sudo mkdir -p /etc/apt/keyrings $ curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
-
Set up Docker's repository
$ echo \ "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \ $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
-
Install Docker and Docker Compose
$ sudo apt-get update $ sudo apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin
-
Enable using Docker for current user (without requiring
sudo
):$ sudo usermod -aG docker $(whoami) $ logout
-
Copy NEURONE's source code into a folder on your home (for this example,
neurone-master
will be assumed as your source code folder) -
You can set some of the following Environment Variables on your production machine to customize deployment, although NEURONE can run perfectly with its default values (take note of those values whether you use the default ones or not):
Env Variable Name Default Value Description NEURONE_ASSET_PATH
~/neuroneAssets
NEURONE asset folder location in your production machine NEURONE_MONGO_PATH
~/neuroneDatabase
MongoDB raw data folder storage in your production machine NEURONE_HOST
localhost
IP or DNS domain where NEURONE is hosted NEURONE_ADMIN_DB_USER
admin
MongoDB Admin username NEURONE_ADMIN_DB_PASS
neurone2017
MongoDB Admin password NEURONE_DB
neurone
MongoDB database name NEURONE_DB_USER
neurone
MongoDB database username NEURONE_DB_PASS
neurone
MongoDB database password MAPTILER_KEY
XNctrGMVMOj0xErblNkx
Maptiler API key (get one for free on https://www.maptiler.com/) To override a default value through an environment variable, use the following command as an example:
$ export NEURONE_HOST=123.45.67.89
Alternatively, you can customize these environment variables by editing the
dotenv
file in the project's root directory. -
Create your asset and raw data folder at the locations defined on Step 5, also copy your assets (example will assume
myAssets.zip
as source) to your NEURONE asset folder$ mkdir -p ~/neuroneAssets $ mkdir -p ~/neuroneDatabase $ unzip myAssets.zip -d ~/neuroneAssets
-
Run bundled scripts for building and deploying NEURONE:
$ cd ~/neurone-master $ ./neurone-build.sh $ ./neurone-start.sh
All required project dependencies will be downloaded automatically. Depending on internet connection, the build process could take between 15 and 30 minutes. To undeploy NEURONE, run the following commands:
$ cd ~/neurone-master $ ./neurone-stop.sh
-
You can access your NEURONE simulation instance through a web browser by entering your IP or DNS address or use the following ports to access and configure NEURONE when deployed:
Application Port Description NEURONE 80
NEURONE Simulation Module (access through web browser) MongoDB 1313
NEURONE Database Module (access through a MongoDB client) Solr 1314
NEURONE Information Retrieval Module (access through web browser or REST requests) -
You can further customize NEURONE by setting the language for the Solr core and/or configuring a firewall. See the Appendix section of this README for more information.
Check NEURONE's Sysadmin Manual for complete instructions for a custom deploy using Node.js, Nginx and PM2.
In case you find a bug or have a suggestion, please send an Issue on this repo. Pull Requests are welcome.
NEURONE's Source Code is released under the GNU Affero General Public License (Version 3), meaning that:
- NEURONE is free to use, analyze, distribute and modify by anyone
- In case of using a modified version of NEURONE, all changes must be released under the same license and must be clearly stated
- The NEURONE Development Team is not responsible for any problems or damages generated by the use of this software (or its derivated forms)
In case of using NEURONE as part of a scientific publication, you must acknowledge the NEURONE Development Team by adding the following text (or a variation of it) in your published results:
"This study uses the NEURONE Platform (developed in the context of the iFuCo Project funded by the Academy of Finland and CONICYT, Chile) as part of the research tools"
And also referencing the following publications:
- González‐Ibáñez, R., Gacitúa, D., Sormunen, E., & Kiili, C. (2017). NEURONE: oNlinE inqUiRy experimentatiON systEm. Proceedings of the Association for Information Science and Technology, 54(1), 687-689.
- Sormunen, E., González-Ibáñez, R., Kiili, C., Leppänen, P. H., Mikkilä-Erdmann, M., Erdmann, N., & Escobar-Macaya, M. (2017, September). A Performance-based Test for Assessing Students’ Online Inquiry Competences in Schools. In European Conference on Information Literacy (pp. 673-682). Springer, Cham.
It is important to block all ports on the server that are not used to interact with the platform in order to avoid malicious attacks. In Ubuntu Server, UFW is the default firewall for this purpose. Follow these steps to enable UFW for NEURONE:
-
Set all UFW policies to default values
$ sudo ufw default deny incoming $ sudo ufw default allow outgoing
-
Allow rules for SSH connections
$ sudo ufw allow ssh
-
Enable UFW
$ sudo ufw enable
-
Allow rules for NEURONE This example assumes that port 80 is being used for the main NEURONE application and port 81 for the fallback NEURONE application. Notice that database and inverted index services must be kept behind the firewall.
$ sudo ufw allow 80 $ sudo ufw allow 81 $ sudo ufw reload
Source: https://www.digitalocean.com/community/tutorials/how-to-set-up-a-firewall-with-ufw-on-ubuntu-22-04
In order to access NEURONE modules from a developer or sysadmin machine protected by a firewall, it is possible to deploy a SSH Tunnel to temporary bypass it. The following bash script shows an example on how to do this (from a local machine):
#!/bin/bash
# Customize the following variables
REMOTE_USERNAME="neurone" # NEURONE server username
REMOTE_HOST="neurone.myschool.info" # NEURONE server domain or IP address
REMOTE_PORT=1313 # NEURONE server port to redirect
LOCAL_PORT=3000 # Local machine port where the NEURONE server port is redirected
echo -e "Tunneling to $REMOTE_HOST from remote port $REMOTE_PORT to local port $LOCAL_PORT"
ssh $REMOTE_USERNAME@$REMOTE_HOST -p 22 -L $LOCAL_PORT:localhost:$REMOTE_PORT
It is possible to change the language of the Solr core to take advantage of language-specific autoindexing techniques (like stopwords and stemming), therefore making the search experience more similar to commercial search engines. After NEURONE is deployed in the server and before loading any documents, customize the following snippet and run it (as a single command) from the terminal:
curl --location 'http://localhost:1314/solr/neurone/schema/fields?wt=json' \
--header 'Content-Type: application/json' \
--data '{
"add-field": [
{
"name": "title_t",
"type": "text_es",
"indexed": true,
"stored": true,
"termVectors": true,
"termPositions": true
},
{
"name": "indexedBody_t",
"type": "text_es",
"indexed": true,
"stored": true,
"termVectors": true,
"termPositions": true
},
{
"name": "keywords_t",
"type": "text_es",
"indexed": true,
"stored": true,
"multiValued": true,
"termVectors": true,
"termPositions": true
}
]
}'
This command requires curl
to run. The following parameters of the command above can be customized:
localhost:1314
: Replace this with the proper domain/IP address and port of the deployed NEURONE Solr module."add-field"
: If the command is going to be run before adding documents, leave it like it is. If there are documents already loaded to NEURONE, replace it with"replace-field"
, run the command, and then reload the inverted index from the NEURONE's Admin Panel."type": "text_es"
: Thetext_es
part changes the Solr core autoindexing to Spanish language. This can be modified for other languages too, liketext_en
(for English),text_fi
(for Finnish), or any other language compatible with Solr (see here for more information). Remember to change all coincidences of this value to the desired language to work properly.