JustFans - Premium content subscription platform | Docs

1. Introduction

Hey, thanks for purchasing "JustFans - Premium content subscription platform". Here you'll find about everything you need in order to get started with launching your app. If you have any questions, don't hesitate do contact us.

2. Requirements

2.1.Webserver requirements
  • Apache webserver with mod_rewrite or nginx webserver
  • A Mysql 5.7.7+ or Mariadb 10.3.17+ database server
  • PHP >= 7.2.5 preferably ran under php-fpm
2.2. PHP required extensions:
  • BCMath
  • Ctype
  • Fileinfo
  • JSON
  • Mbstring
  • OpenSSL
  • PDO
  • Tokenizer
  • XML
  • cURL
  • exif
  • GD
2.3. Other, optional requirements:
  • FFMpeg (Optional, if not provided, only mp4 videos will be allowed)
  • AWS S3 for files storage
  • AWS CloudFront for secure assets access
  • Stripe & Paypal seller accounts & API Keys

3. Files Setup

Before proceeding with the actual installation, we need to make sure that you unzip the script content onto the directory that is going to serve your domain. This can be either done via cPanel or command line.

3.1. Upload the script directory onto your server.

Locate the file manager and upload the Script folder onto your web serving directory

3.2. Extract archive contents.
3.3. Configure files permissions

In order for the script to work properly, you will need to configure the right permissions some of the files & folders you've just extracted. Set the access permissions (CHMOD) to 755 for the following folders:

  • vendor
  • storage
  • bootstrap

You can find more info on how to update access permissions, depending on your setup, at:

3.4. Changing the public directory Important

Configure your web server's document / web root to point to the public directory of the software. For example, if you've uploaded the software in example.com folder, your web directory should be changed to example.com/public folder.

You can find more info an how to change your site Document root over at:

If your hosting provider doesn't allow changing your DocumentRoot, you can temporarily use this .htaccess file, placing it just above the script public directory. Use this just as a temporary solution.

4. Database Setup

4.1. Create a new database
4.2. Create a new mysql user
4.3. Add the user to the database

You can find additional info on how to create databases and users, depending on your setup over at:

5. Installation via the GUI installer

The script comes with a ready to go web installer that you can access on the /install path, as in https://your-domain.com/install.

Once there, you should be able to see a panel like this, which will guide you through a simple, 3 steps installation process.

  • 6.1. Checking requirements. If minimum requirements are not met, script will not be installable.
  • 6.2. In this form, please enter the database host, name, user and password that you've created on step 3.
  • 6.3. In this form you'll be able to set up site's name, your admin user and validate your script license.

Once you're done with the installation, you'll be able to customize the rest of your site's aspects via the admin panel.

  • composer install
  • php artisan npm:install
  • npm run prod
  • php artisan storage:link
  • php artisan key:generate
  • php artisan migrate
  • php artisan db:seed
  • php artisan activate:product code={license_code}
  • 6. Setting up the payments providers

    In order to be able to receive payments, you'll need to set up at least one payment provider for your app.

    Navigating to Admin > Settings > Payments area, you will be able fetch your site's webhook endpoints to be used with Paypal and Stripe, and fields to fill in their Secret & Public keys.

    Stripe:
    • Login into your Stripe dashboard.
    • From the secondary sidebar, please go to Developers > API Keys.
    • Copy the Publishable key and Secret key in the admin panel, over at Admin > Settings > Payments, as in the screenshot above.
    • Next up, from the Developers tab, go to Webhooks and click on Add endpoint
    • For the Endpoint URL, please copy the webhook endpoint located at Admin > Settings > Payments..
    • For the Version field, select the latest version.
    • Then, for the Select events to listen to, go with the Select all events.
    Paypal:
    • Login into your Paypal account, using the Paypal developer dasboard.
    • Go to the My apps & credentials area, select the Live switch button and then hit Create app button to create a Paypal app.
    • Copy the Paypal's ClientID & Paypal Secret Key and add them into the admin into the Settings > Payments area.
    • Go to the My apps & credentials area, select the Live switch button and then select your freshly created app.
    • Scroll down the page until you reach the SANDBOX WEBHOOKS area, where you'll need to click on the Add Webhook button.
    • On the Webhook URL field paste your webhook URL. This can be found, as shown in the first screenshoot, over at Admin > Settings > Payments.
    • For the Event types, select All Events and hit Save
    Coinbase:
    • Login into your Coinbase Commerce account, using coinbase commerce sign in.
    • Go to Settings section.
    • Search for API keys
    • Click on Create an API key, copy the key and add it into the admin panel into Setting > Payments area.
    • Search for Webhook subscriptions
    • Click on Add an endpoint. The webhook url can be found over at Admin > Settings > Payments section.
    • Then, click on Show shared secret and add that secret into the admin panel, over at Admin > Settings > Payments
    NowPayments (Adult content allowed):
    • Login into your NowPayments account, using NowPayments sign in.
    • Go to Store settings section.
    • Add a new API Key
    • Copy the key and add it into the admin panel into Setting > Payments area as NowPayments Api Key.
    • Go back to your NowPayments account over Store settings and generate an IPN secret key
    • Add secret into the admin panel, over at Admin > Settings > Payments as NowPayments IPN Secret Key
    • The next step is to add crypto wallets into your NowPayments account.
    • We recommend adding as many wallets as possible with different crypto currencies so the conversion rate will be lower.
    • We recommend adding a payment covering percentage into your NowPayments account representing percentage of the payment that needs to be paid to be considered completed.

      Example: If set to 5%, an item priced at $100 will be considered fully paid for if the customer transfers cryptocurrency worth 95$.

    • Payment covering percentage is useful for the case where customer accidentally paid a lower amount with a few cents so payment is treated as completed instead of partially paid. In case payment is partially paid admins will receive an email notification that will require manually processing (either refunding the credit to the customer or approve it manually from the admin panel)

    7. Setting up the cron jobs Important

    7.1 Crons setup

    In order to get the platform fully functional, including the payment system, emails, offers and more, you will need to set up the following cronjob.

    * * * * * cd /path-to-your-project && php artisan schedule:run >> /dev/null 2>&1
    
    7.1 Ensure crons are running

    Crons plays an important role in the payment system so please ensure the crons are not returning any fatal error when running them (eg:cd /path-to-your-project && php artisan schedule:run). You can also make sure there are no errors under the crons log file @ storage/logs/crons.log.

    You can find more info an how to set up crons over at:

    8. Setting up the emailing driver

    For the mailing driver you can mainly choose between three main options, which are Mailgun via API, SMTP or PHP mail() function, if available. You also have the logging option, in case you're just debugging things.

    The emailing settings can be found over at Admin > Settings > Emails. Here's a short description over the settings.

    1. Mail from name - Name in which the emails are sent, also attached to email footers.
    2. Mail from address - Email address sending from. EG: no-reply@domain.com
    8.1 Log driver

    The logging driver has mainly debugging purposes. Logged emails can be found under the storage/logs/laravel.log log file.

    8.1 Sendmail driver

    The sendmail driver can be used if the PHP mail() function is configured on the server. Most of cPanel shared hosting providers has it enabled.

    8.3 Mailgun driver
    1. Mailgun domain - The domain/subdomain you've set up to use with mailgun. Must have valid DNS records set up priorly.
    2. Mailgun secret - The domain API key
    3. Mailgun endpoint - api.mailgun.net for US or api.eu.mailgun.net for EU instances
    8.4 SMTP driver
    1. SMTP Host - Your SMTP server host name / IP.
    2. SMTP Port - Generally 587 for TLS and 465 for SSL. Can be different based on the email provider.
    3. SMTP Encryption - TLS / SSL
    4. SMTP Username - Your SMTP username
    5. SMTP Password - Your SMTP password

    Notes

    • To test if emails are properly set up, you can create a new account, if misconfigured, you will get a 500 error, while the account should still be created.
    • Generally all drivers are good if running properly, but mailgun API seems to be the fastest.

    9. Setting up storage driver

    9.1 Setting up AWS S3 hosting & CloudFront

    If you dont want to use your server as hosting for your application files you have the option to use AWS S3 (including CloudFront and CloudFront Signed Url's) which is more faster and secure.

    S3:

    To upload your data to Amazon S3, you must first create an Amazon S3 bucket in one of the AWS Regions.

    1. Go to AWS Console and login or create an account.
    2. After you successfully login into your account go to Search for services area and search for S3.
    3. Next up, you should be redirected to S3 page, click on Buckets > Create bucket.
    4. Set up your bucket name and region.
    5. Disable Block all public access checkbox.
    6. Enable I acknowledge that the current settings might result in this bucket and the objects within becoming public checkbox.
    7. The other options stay as default.
    8. Click on Create bucket after you make sure all the details are correct.
    9. After you successfully create the bucket, you need to generate the AWS access keys by going again to Search for services area and search for IAM (Identity and Access Management).
    10. Next up, go to Access management > Users and click on Add users.
    11. Set an username under user details area and enable Access key - Programmatic access under AWS access type area then click on Next.
    12. Click on Attach existing policies directly under Set permissions area then search for AmazonS3FullAccess and enable this policy (or you can add a custom policy) then click Next.
    13. Add a tag if you want or leave it default and finish up the create user process.
    14. After you successfully generate the user make sure you save the AWS Access Key ID and Secret access key.
    15. Save bucket name, AWS Access Key ID and AWS Secret access key to the admin panel, over at Admin > Settings > Storage.
    CloudFront:

    When you want to use CloudFront to distribute your content, you create a distribution and choose the configuration settings you want.

    1. Follow steps from S3 section from above to create bucket.
    2. Go to Search for services area and search for CloudFront.
    3. Next up, you should be redirected to CloudFront page, click on Distributions > Create distribution.
    4. Set your bucket origin under Origin > Origin Domain area by searching for previously created bucket.
    5. The other options can stay as default as long as you don't want something custom.
    6. After you successfully create distribution, save Distribution domain name to the admin panel, over at Admin > Settings > Storage and enable CloudFront.
    7. Check Steps for Creating a Distribution for more details about how to create and setup a CloudFront distribution.
    S3 & CloudFront & Signed Url's:

    To use signed URLs, you need a signer. A signer is a trusted key group that you create in CloudFront.

    1. Create a key pair for a trusted key group:
        The following steps use OpenSSL as an example of one way to create a key pair. There are many other ways to create an RSA key pair.
      • Run openssl genrsa -out private_key.pem 2048 command to generate the private key.
      • Use the following command openssl rsa -pubout -in private_key.pem -out public_key.pem to extract the public key from the file named private_key.pem.
    2. To upload the public key to CloudFront:
      • Sign in to the AWS Management Console and open the CloudFront console.
      • In the navigation menu, choose Key management > Public keys > Create public key.
      • For Name, type a name to identify the public key.
      • For Key, paste the public key. If you followed the steps in the preceding procedure, the public key is in the file named public_key.pem.
      • To copy and paste the contents of the public key, you can:
        • Use the cat command on the macOS or Linux command line, like this: cat public_key.pem. Copy the output of that command, then paste it into the Key value field.
        • Open the public_key.pem file with a plaintext editor like Notepad (on Windows) or TextEdit (on macOS). Copy the contents of the file, then paste it into the Key value field.
      • Click add and record the public key ID. You use it later when you create signed URLs, as the value of the Key-Pair-Id field.
    3. To add the public key to a key group:
      • In the navigation menu, choose Key management > Key groups > Create key group.
      • For Name, type a name to identify the key group.
      • For Public keys, select the public key to add to the key group, then choose Add.
      • Choose Create key group.
    4. Adding a signer to a distribution:
      • Record the key group ID of the key group that you want to use as a trusted signer.
      • Open CloudFront console and choose the distribution whose files you want to protect with signed URLs or signed cookies.
      • Choose the Behaviors tab.
      • Select the cache behavior whose path pattern matches the files that you want to protect with signed URLs or signed cookies, and then choose Edit.
      • For Restrict Viewer Access (Use Signed URLs or Signed Cookies), choose Yes.
      • For Trusted Key Groups or Trusted Signer, choose Trusted Key Groups.
      • For Trusted Key Groups, choose the key group to add, and then choose Add. Repeat if you want to add more than one key group.
      • Choose Save changes to update the cache behavior.
    5. Save previously created public Key-Pair-Id to the admin panel, over at Admin > Settings > Storage.
    6. Copy previously created private key pair RSA file into project root by following steps:
      • Copy private_key.pem file into project root.
      • Add private key file path to the admin panel, over at Admin > Settings > Storage and enable CloudFront Signed Url's. (If you followed previously steps this path should look like this private_key.pem)
    7. At this point you can disable the public access for your S3 bucket.
    8. Check Serving private content with signed URLs for more details about CloudFront Signed Url's.
    9.2 Setting up Wasabi storage driver

    If you like to use Wasabi instead of S3 for file storage, that can be set by changing the storage driver, out of the Admin > Settings > Storage > Driver.

    Once you've done that, you wil have to add your credentials which are available over the Wasabi website. Please make sure you account is validated, so buckets can be available to the public.

    You will also need to add the following policy to your bucket:

    {
      "Version": "2012-10-17",
      "Statement": [
        {
          "Sid": "AllowPublicRead",
          "Effect": "Allow",
          "Action": "s3:GetObject",
          "Resource": [
            "arn:aws:s3:::your-bucket-name",
            "arn:aws:s3:::your-bucket-name/*"
          ]
        }
      ]
    }
    
    9.3 Setting up Digital Ocean Spaces storage driver

    If you like to use Digital Ocean Spaces storage, that can be set by changing the storage driver, out of the Admin > Settings > Storage > Driver. Once you selected the new driver, proceed with the following steps:

    1. Create a new Spaces access key and copy the key and secret.
    2. Go to Admin > Settings > Storage and add your newly created keys into the DO Access Key and DO Secret Key
    3. Go to Spaces area and create a new space. Default settings should be just fine.
    4. Select the new bucket. You will then see a link of this format https://{bucket-name}.{region}.digitaloceanspaces.com
    5. For the DO Bucket, insert the {bucket-name} url section.
    6. For the DO Region, insert the {region} url section.

    10. Setting up Websockets

    In order give the app realtime capabilities, used for User messenger & User notifications you will need a Pusher account. Once you got that, follow the steps below:

    1. Go to Pusher dashboard and go to the Channels category.
    2. Click on Create app. Select a name and cluster region at your preference.
    3. Next up, you should be redirected to your new app page. If not, head over Apps and select your app.
    4. Copy over the app_id, key, secret and cluster and add save them to the admin panel, over at Admin > Settings > Messenger & Notifications area.

    11. Setting up FFMpeg

    In order to allow your users to upload all types of video formats, you will need to install FFMPEG on your server, if it doesn't have it already. If FFMPEG is not available, the allowed video extensions will fallback to .mp4 only.

    11.1 FFMPEG on shared hosting

    There are numerous shared hosting providers offering FFMPEG available hosting. Please check with your provider if FFMPEG is available.

    11.2 Installing FFMPEG on Windows

    In order to run FFMPEG on windows, head over this github page, download the latest win64 build and unzip it on your drive. Make sure FFMPEG is running under the same drive as the web server.

    11.3 Installing FFMPEG on Ubuntu
    sudo apt update
    sudo apt install ffmpeg
    
    11.4 Installing FFMPEG on Rhel/Centos

    Before proceeding with the installation, we'll need to set up some missing repositories, based on the OS version.

    Centos 6
    $ sudo yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm
    $ sudo yum install https://download1.rpmfusion.org/free/el/rpmfusion-free-release-8.noarch.rpm https://download1.rpmfusion.org/nonfree/el/rpmfusion-nonfree-release-8.noarch.rpm
    $ sudo yum install http://rpmfind.net/linux/centos/8-stream/PowerTools/x86_64/os/Packages/SDL2-2.0.10-2.el8.x86_64.rpm
    
    Centos 7
    $ sudo rpm --import http://li.nux.ro/download/nux/RPM-GPG-KEY-nux.ro
    $ sudo rpm -Uvh http://li.nux.ro/download/nux/dextop/el7/x86_64/nux-dextop-release-0-5.el7.nux.noarch.rpm
    
    Centos 8
    $ sudo dnf install https://dl.fedoraproject.org/pub/epel/
    $ sudo dnf install https://download1.rpmfusion.org/free/el/rpmfusion-free-release-8.noarch.rpm
    $ sudo yum-config-manager --enable powertools
    $ sudo dnf install ffmpeg ffmpeg-devel
    

    After the repos were added, continue with the installation by running the following command:

    sudo yum install ffmpeg ffmpeg-devel
    11.5 Adding the FFMPEG path to the admin

    Copy the (full path) of the bin/ffmpeg and bin/ffprobe executables and copy them over the admin panel, at Admin > Settings > Media.

    You can also test your FFMPEG set up & get full executables paths by running the following commands

    ffmpeg -version # To test installation
    which ffmpeg && which ffprobe # To get full exec paths
    

    12. Live streaming

    In order to get going with live streaming configuration, you will need to create a PushrCDN account. Once logged in, you will need to verify your account by filling in your personal information and payments info Once your account is ready, you can
    • Go to CDN > Push zones > Create push zone
    • Copy the CDN Push zone ID and add it to Admin > Streaming > Pushr Zone Id field
    • Copy the Profile > Personal information > API Key, out of this page and add it to Admin > Streaming > Pushr Key field.
    Once you filled in your PushrCDN Zone ID & API Key, your platform then should support live streaming. Out of the admin panel, you can also set your other settings, like VODs, encoders or bitrates.

    13. Admin panel

    13.1 General info & how to add new users

    If everything went fine, the Admin panel will be available at http://your-domain.com/admin. The credentials are set during the installation / user creation.

    Once you got your main admin account set up, you can then manage your roles and other admins users from the admin panel itself.

    If for some reason you lost access to the account, you can either reset the password of the user or create another and make it an admin using following command or SQL query:

    • php artisan voyager:admin your@email.com
    • UPDATE users SET `role_id` = 1 WHERE `email` = 'your@email.com'
    13.2 Available admin settings

    Over the Admin > Settings area, you can view and manage your website content and customize different aspects of it. Here's a quick description of the main settings available in the admin area.

    • Dashboard - View quick info about your platform
    • Media manager - Browse and manage all site's media
    • Users management - Browse and manage all users and their associated data
      1. Process users identity checks based on uploaded IDs
      2. Manage user roles
      3. Manage user wallets
      4. Manage user notifications
      5. Manage user messages
      6. Manage user reactions
      7. Manage user lists
      8. Manage user lists members
      9. Manage user reports
      10. Manage homepage featured users
    • Posts management - Browse and manage all posts and their associated data
      1. Manage post attachments
      2. Manage post comments
      3. Manage post bookmarks
    • Money management - View and manage subscriptions and payments related data
      1. Manage subscriptions
      2. Manage transactions
      3. Manage withdrawals
    • Taxes - Manage taxes, countries and regions
    • Pages - Create and manage public pages
    • Settings - Change a wide variety of site settings
    • Site settings
      1. Site title
      2. Site description
      3. Google Analytics Tracking ID
      4. Light site logo
      5. Dark site logo
      6. Site favicon
      7. Enable cookies box
      8. Allow (users to) switch to dark mode
      9. Allow (users to) change site direction (RTL-LTR)
      10. Allow (users to) switch languages
      11. Default site language
      12. Hide identity checks menu - Either show or hide the "Verify" setting category for users
      13. Enforce User Identity Check - If set to on, users will be required to complete an identity check upon posting content.
      14. Allow PWA Installs
      15. Allow QR code generate on profiles
      16. Allow gender pronouns
      17. Enable email 2FA on logins
      18. Default 2FA setting on user register
      19. Default profile type on user register
      20. Default user privacy setting on user register
      21. Enforce platform SSL usage
    • Admin settings
      1. Admin Title
      2. Admin Description
      3. Admin Loading spinner image
      4. Admin Icon Image
      5. Admin Background Image
    • Feed settings
      1. Posts per page
      2. Suggestion box total cards
      3. Suggestion box cards per page
      4. Autoplay suggestions box slides
      5. Disable right click on media & view page source
      6. Allow post galleries Zoom in
    • Media settings (See 7.4. Setting up FFMpeg)
      1. FFMpeg Path
      2. FFProbe Path
      3. Allowed file extensions
      4. Max file uploads size (MB) Do not exceed PHP limits
      5. Max videos length (In seconds)
      6. Apply watermark over uploaded assets
      7. Watermark image
      8. Use profile url watermark - Adds user site profile url as a wattermark
    • Websockets settings (See 7.3. Setting up Pusher)
    • Invoices settings - Set payment receiver invoice details & Invoices Prefix
    • Payments settings (See 7.1. Setting up the payment )
      1. View stripe & paypal & coinbase webhooks links
      2. NowPayments API Key (If not provided, NowPayments payments are disabled)
      3. NowPayments IPN Secret (If not provided, NowPayments payments are not working properly)
      4. Coinbase API Key (If not provided, Coinbase payments are disabled)
      5. Coinbase Webhooks Secret
      6. Stripe Public Key (If not provided, Stripe payments are disabled)
      7. Stripe Secret Key (If not provided, Stripe payments are disabled)
      8. Stripe Webhooks Secret
      9. Paypal Client Id
      10. Paypal Secret (If not provided, Paypal payments are disabled)
      11. Paypal Secret (If not provided, Paypal payments are disabled)
      12. Paypal Live Mode ( Must be enabled to receive payments, otherwise, sandbox environment will be used.
      13. Site Currency Code
      14. Site Currency Symbol
    • Emails settings
      1. Email driver - Choose between Log/SMTP/Mailgun. We recommend mailgun via API.
      2. Mail from name
      3. Mail from address
      4. Additionally, each email driver comes with it's configuration fields that must be filled in properly.
    • Storage settings (See 7.2. Setting up AWS & CF for advanced configs)
      1. Storage driver (Choose between locally hosted files, S3, Wasabi or DO SPaces ones)
    • Social login
      1. Set your social login clientIDs & secrets for Facebook, Twitter & Google.
    • Social media
      1. Set your social media footer links.
    • Withdrawals and Deposit
      1. Set your deposit and withdrawal minimum and maximum constrains.
    • Custom Code / Ads
      1. Sidebar Ad - Ad to show in feed & profile right sidebars.
      2. Custom CSS Code - Custom code to inject in the platform
      3. Custom JS Code - Custom code to inject in the platform
    Settings recommendations
    • For the email driver, we recommend going with the mailgun API Key based method, not the SMTP one, which can slow down the request time.
    • For the assets hosting, we strongly recommend using AWS S3 & CloudFront with Presigned URLs. This is the only way you can protect your users assets, meaning the images and video links are served via CloudFront and links are temporary & IP locked.

    14. How to update

    Before making an update, always remember to do a complete backup of your website.
    If you've made any modifications to the software's files, your changes will be lost.
    1. Make a backup of the .env config file located on your server.
    2. Upload and replace all the files on your server with what's inside the Script folder.
    3. Restore your .env config file on your server.
    4. Go to https://example.com/update and follow the update wizard.1
    1. Updates that do not have database changes, will not show up in the update wizard.

    15. FAQ

    • I have a support inquiry, a question or a problem, how can I contact you?
      You can contact us by sending us a private message over our Codecanyon profile.
    • What hosting do you recommend?
      We recommend using DigitalOcean, as they offer great performance and flexibility at an affordable price.
    • Is installation included in the price?
      No, installation is not included. We offer installation services for an extra fee, for which you can send us a message.
    • My website returns a Not Found message, why?
      Please ensure that you have mod_rewrite enabled on your server.
    • How can I translate my website?
      Make a copy of the default en.json language file found in /resources/lang folder, and change it according to your needs.
      Note* The json language file must follow iso format, eg: es.json, ro.json, en.json.
    • How can I reskin my website?
      1. You need to Have node installed on the server
      2. Update the colors over at following files resources/sass/_variables.scss and resources/sass/_variables-dark.scss
      3. Run npm run prod over the script directory

      You new theme will be generated under the public/theme directory. You will have to make sure you don’t override it during updates.

    • How can I edit my homepage?

      Generally, for each page, including homepage, you will have a skeleton like this one:

      1. Controllers are found in the app/Http/Controllers directory
      2. resources/viewspage.blade.php view file (for HTML)
      3. public/js/pagespage.js (For Javascript changes)
      4. public/css/pagespage.css (For CSS changes)

      So for the homepage, you would have home.css, home.js, home.blade.php, etc. However, you will have to back up and replace your updated files after each update you do on the instance.

    • How can update my custom modified version of the script?

      Our recommendation regarding maintaining custom modified version of the platform is the following:

      1. Create your own (private) github/gitlab repository
      2. Host your custom code changes on a separate branch
      3. Update the main branch with the new update
      4. Merge the updated version onto your branch (resolve any conflicts if that’s the case)
      5. Release your (custom) updated version of the script
      6. Update the platform, as per How to update section
    • Assets are not uploaded or shown on local storage, why?
      First off check if the Admin > Settings > Site url field is containing an invalid value. Secondly, you can check if the storage symlink is created properly. If not, please re-create it yourself using the following CLI commands:
      1. rm -rf public/storage
      2. ln -s storage/app/public public/storage
    • Site throwing 500 error after changing file storage driver, why?
      This generally happens when the storage driver credentials or configurations are wrong. If you can't access the admin panel either, you can reset the storage driver by running this query in phpMyAdmin or your DB client UPDATE `settings` SET `value`='public' WHERE `id`=95;.
    • My website returns a blank page, why?
      This generally happens when one of the server requirements is not met, please ensure your server meets the software's requirements.

    16. Contact us

    For questions, do not hesitate to contact us by sending us a private message over our CodeCanyon profile page.