GoToSocial is an open-source social network platform developed by Super Serious Business. In this tutorial, we will guide you through the process of installing GoToSocial on Manjaro.
The first step in installing GoToSocial is to clone the project repository from GitHub. Open a terminal window and run the following command:
git clone https://github.com/superseriousbusiness/gotosocial.git
This will download the GoToSocial source code to your current directory.
To install GoToSocial's dependencies, navigate to the project directory and run the following command:
composer install
GoToSocial uses environment variables to store sensitive information such as database credentials and API keys. Create a .env file in the project directory and set the appropriate values for your environment:
APP_ENV=local
APP_DEBUG=true
APP_URL=http://localhost:8080
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=gotosocial
DB_USERNAME=root
DB_PASSWORD=
ADMIN_EMAIL=admin@example.com
ADMIN_PASSWORD=secret
Be sure to fill in the correct values for your database and admin account.
GoToSocial requires an application key to encrypt and decrypt data. Generate a key by running the following command:
php artisan key:generate
GoToSocial uses a MySQL database to store data. You will need to run the database migrations to create the required tables. Run the following command to run the migrations:
php artisan migrate
GoToSocial uses npm to manage client-side dependencies. Install them by navigating to the project directory and running the following command:
npm install
Once the frontend dependencies are installed, you can compile the assets by running:
npm run dev
GoToSocial requires a web server to serve the application. You will need to configure your server to point to the public directory of the GoToSocial installation.
For Apache, add the following VirtualHost block to your configuration file:
<VirtualHost *:80>
    ServerName example.com
    DocumentRoot /path/to/gotosocial/public
    <Directory /path/to/gotosocial/public>
        Options Indexes FollowSymLinks
        AllowOverride All
        Require all granted
    </Directory>
</VirtualHost>
For Nginx, add the following server block to your configuration file:
server {
    listen 80;
    server_name example.com;
    root /path/to/gotosocial/public;
    index index.php index.html index.htm;
    location / {
        try_files $uri $uri/ /index.php$is_args$args;
    }
    location ~ \.php$ {
        fastcgi_pass unix:/run/php-fpm/php-fpm.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;
        include fastcgi_params;
    }
}
Be sure to replace example.com and /path/to/gotosocial with the correct values for your server.
With your web server configured, you can start the application by running the following command:
php artisan serve
This will start a development server at http://localhost:8000. Navigate to this URL in your web browser to access GoToSocial.
In this tutorial, we walked you through the process of installing GoToSocial on Manjaro. By following these steps, you should now have a working instance of GoToSocial up and running.
If you want to self-host in an easy, hands free way, need an external IP address, or simply want your data in your own hands, give IPv6.rs a try!
Alternatively, for the best virtual desktop, try Shells!