The following are instructions for installing the software on your own web server.
The community map has been designed to be relatively easy to install on standard "vanilla" hardware and software platforms. We recommend using a standard "LAMP" stack that integrates support for Apache, SQL, and PHP. To set up your own instance, you will need the following items:
Sharedigm uses Laravel10 which relies upon PHP 8.1 or later.
This application requires Apache or another similar web server.
The data science map uses SQL for storing user, authentication, and academic information. You can use any of a number of SQL databases including MySQL, MariaDB, SQLite, PostgreSQL, Microsoft SQL Server and others.
Move or copy the files located in "src/" directory into the document root of your web server.
The application may sometimes have a need to write out temporary files, for example, log files or session files. It does this in the "services/storage" directory. Make sure that this directory is writable by your web server. On a unix system, make sure that the files in the web server folder are owned by the web server process (usually "apache") and set the permissions to make the directory writeable by the web server.
chown -R apache:apache /var/www/html
chmod -R 755 /var/www/html
Once you have copied the files into your web server's document root folder, verify that your web server can access the files by typing "localhost" into your web browser. You should see the user interface and map.
The community map uses a standard SQL database. To set up your database, perform the following steps:
Inside of the /databases directory, you should see the two subdirectories containing SQL database files.
Using a database editor of your choice, create a two new databases:
- campus_map
- community_map
Next, create the required database tables. To do this, open your new database and execute the SQL script: "structure.sql". You should see a list of tables that have been created.
- Create "campus_map" database.
- Run the .SQL file "database/campus_map/_structure.sql".
- Create "community_map" database.
- Run the .SQL file "database/community_map/_structure.sql".
Next, we'll initialize the database with the data describing the campus and community.
- Open the "campus_map" database.
- Run the .SQL files in the "database/campus_map" (except for "_structure.sql") to populate this database with the campus buildings.
- Open the "community_map" database.
- Run the .SQL files in the "database/community_map" (except for "_structure.sql") to populate this database with the community members.
The client is the "front end" or "user interface" portion of the software that the user interacts with. The client needs to be able to talk to the "back end" where data is stored and managed. Make sure that the servers defined in the file "config/config.json" are pointing to the directory where your web application is located.
"servers": {
"authentication": "/services/public",
"web": "/services/public"
}
To configure the server software, go to the "services" folder where you copied the web server files. Inside of this directory you will find two servers:
- campus-map
- community-map
Inside of each of these directories, your will see a file called ".env". This defines the server configuration for each of your back end web servers.
- Set environment (optional) Set the variable "APP_ENV" to either "dev" for development or "prod" for production.
APP_ENV=prod
The database is where your user account information and other data is stored. Follow these steps to make sure that the application can communicate to the database properly.
-
Set database name (optional) Set the variable "DB_DATABASE" to the name of your database, which is most likely "biodata". If you selected a different name for the database, then enter that name here.
-
Set database username Set the variable "DB_USERNAME" to your database username. By default, databases are created with the username 'root'.
DB_USERNAME=root
- Set database password Set the variable "DB_PASSWORD" to your database password. By default, database passwords are set to 'root'.
DB_PASSWORD=root
Once you have configured the database, you should be able to log in to the "admin" user account. To test whether the database has been properly configured, open up the application in your web browser. You should see "SignIn" and "SignUp" button in the upper right hand corner.
To sign in to the default "admin" account, click the "Sign In" button. You should see a "Sign In" dialog box. For the username, enter "admin". For the password, also enter "admin".
If you do not see the "Sign In" button when you load up the application in your web browser, then that means that something is not working with the back end server configuration. To see what the error is, either look in your web browser's debugger or go to the logs folder. The logs folder is located in:
services/storage/logs
This application uses email to verify users when they register for new accounts and to reset passwords. It also uses email as a mechanism for sharing files and to allow user feeback.
- Set mail host Set the variable "MAIL_HOST" to the host name of your mail server.
MAIL_HOST=mail.mydomain.com
- Set mail username Set the variable "MAIL_USERNAME" to the user to use for sending email messages.
MAIL_USERNAME=myusername
- Set mail password Set the variable "MAIL_PASSWORD" to the password of the user to use for sending email messages.
MAIL_PASSWORD=mypassword
To test whether the mail configuration is functioning properly, we'll send a test email using the following steps:
-
Log in to the admin user account Log in to the default admin user account as before - username: root, password: root.
-
Open Settings Once you have logged in, click the "Settings" icon (the gears icon) on the top nav bar.
-
Open Account Settings Click the "Account" icon on the left sidebar.
-
Enter Your Email Address. Click the "Edit Account" button and enter your email address.
-
Send a Test Email Log out and click the "Sign In" button on the top nav bar. On the "Sign In" dialog box, click the "Request My Username" link underneath "Username". Enter your email address. It should send an email to your email account.
Once you have the software up and running, you will need to make sure that your web server has the appropriate multimedia support to take advantage of the application's image and video capabilities.
The application uses the Image Magick library to perform image manipulation and scaling. This is used to generate image thumbnails. Most recent version of PHP already have ImageMagick pre-installed and configured so you may not need to perform this step. To check if ImageMagick is already installed, take a look at phpinfo.php to see if ImageMagick is listed.
-
Install the ImageMagick library If ImageMagick is not installed on your system, follow the instructions on imagemagick.org to install ImageMagick on your particular platform.
-
Install ImageMagick PHP library You will also need to install support for PHP to access the ImageMagick library. You will need to find directions for your particular platform to do this. On CentOS / Linux, you would execute the following command, where XX is the major/minor version of PHP that you have installed:
yum install phpXX-imagick
yum install php-pecl-imagick
- Configure PHP to use ImageMagick If your PHP is not configured to use ImageMagick and you have just installed the library using the instructions above, you will then need to configure PHP to know about ImageMagick. To configure your PHP installation to use ImageMagick, open up your php.ini file and under the list of extensions, add the following line:
extension=imagick.so