JustJobs - Remote Job Listings SaaS platform

1. Introduction

Hey, thanks for purchasing "JustJobs - Remote Job Listings SaaS 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, nginx or Litespeed
  • Mysql 5.7.7+ or Mariadb 10.3.17+, and PHP-PDO (nd_pdo_mysql) driver
  • PHP >= 8.0.2
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. You can then even move the contents of the newly extracted Script folder onto the side main public directory, but make sure you also copy any hidden files.

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 rename the .htaccess.sample to .htaccess. 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. Installing the script

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.

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 > Processors > Stripe.
  • 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 > Processors > Stripe..
  • For the Version field, select the latest version.
  • Then, for the Select events to listen to, go with the Select all events.
  • Once done with creating the webhook, you will get a Webhook secret, which will need to be added in the Admin > Settings > Payments > Stripe Webhooks Secret field.
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 Production 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)
CCBill (Adult content allowed):
  • Login into your CCBill account, using CCBill sign in.
  • Go to FlexForms Systems and check for Flex ID.
  • Copy the Flex ID and add it into the admin panel over at Settings > Payments > Payment processors > CCBill > CCBill FlexForm Id.
  • Add your CCBill Account Number over admin settings.
  • Login into your CCBill one time payments sub account and go to Account Info > Sub Account Admin
  • Under left navigation go to Basic and set your approval & denial URL's by getting them from the admin panel over at Admin > Settings > Payments section
  • Then select Webhooks from the left navigation and add your webhook (choose JSON as Webhook Format). You can find the CCBill Webhook URL over the admin settings section.
  • Add your sub account number for one time payments into the admin panel, over at Settings > Payments > Payment Processors > CCBill > CCBill SubAccount One Time Payments
  • Repeat the above steps for your sub account for recurring payments.
  • The last step is to ask CCBill about your Salt key and fill that into the admin panel.
  • In order to be able to programmatically cancel CCBill subscriptions you need to set up a DataLink API user.
  • Login into your CCBill recurring payments sub account and from the top navigation go to Account info > DataLink Services Suite
  • From the left navigation click on Add user and fill in the username and password.
  • For Subsystem tick on all the checkboxes then add your VPC ip address on the Valid Ips field
  • Click on store user and add the accounts details into the admin panel, over at Settings > Payments > Payment processors > CCBill as CCBill DataLink Username / Password
Paystack:
  • Login into your Paystack account, using paystack sign in.
  • Go to Settings section.
  • Check API Keys & Webhooks tab
  • Copy the Secret key and add it into the admin panel into Setting > Payments > Payment processors > Paystack.
  • Go into the admin panel and copy Webook & Callback URL's and add them into Paystack

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

Some custom web-hosting panels might require the cron task to be set in a different manner. If needed, you could also run the task with absolute paths (or different PHP versions), like this:

* * * * * php /path-to-your-project/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/cronjobs.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. Enable Make public using ACL option.
  6. Disable Block all public access checkbox.
  7. Enable I acknowledge that the current settings might result in this bucket and the objects within becoming public checkbox.
  8. The other options stay as default.
  9. Click on Create bucket after you make sure all the details are correct.
  10. 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).
  11. Next up, go to Access management > Users and click on Add users.
  12. Set an username under user details area and enable Provide user access to the AWS Management Console - optional.
  13. Under Set permissions area, click on Attach policies directly and then search for AmazonS3FullAccess and enable this policy (or you can add a custom policy) then click Next.
  14. Review the settings, add a tag if you want or leave it default, and then click on Create user.
  15. After the user is created, click on the user name in the list to open the user details.
  16. Under Security credentials, click on Create access key.
  17. In the Create access key dialog, choose the option that best fits your needs and click Create access key.
  18. Make sure you save the AWS Access Key ID and Secret access key securely as you won't be able to view the secret access key again after this dialog.
  19. 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 > Aws CloudFront Domain Name (remove https:// part from the domain name) 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 copy the public key ID. You use it later when you create signed URLs, as the value of the Key-Pair-Id field. (this is also the Aws CloudFront Key Pair Id that must be set in admin panel)
  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 > Aws CloudFront Key Pair Id.
  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. Make sure your S3 bucket permissions are set to public.
  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/*"
      ]
    }
  ]
}

Note, that the Wasabi bucket can not have any dots inside it.

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.
9.4 Setting up Minio storage driver

Once you got your minio instance ready, you can then proceed with 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 set of keys and copy the key and secret.
  2. Go to Admin > Settings > Storage and add your newly created keys into the Minio Access Key and Minio Secret Key
  3. Create a new bucket and fill in the Admin > Settings > Storage > Minio bucket For the Minio Bucket field.
  4. For the Admin > Settings > Storage > Minio Region, insert the region your instance is using.
  5. For the Admin > Settings > Storage > Minio Endpoint, insert the endpoint your instance is using.
9.5 Setting up PushrCDN storage

Once you got a pushrcdn account, you can then proceed with changing the storage driver, out of the Admin > Settings > Storage > Driver. Once you selected the new driver, proceed with the following steps:

  1. Go go the CDN page and create a new Push zone
  2. Set a zone label, and for Sonic Storage Type set the AWS S3-compatible.
  3. Select the new zone you've created and then click on Storage and Hostnames area.
  4. Fill in the pushr storage admin setting fields with the keys, bucketname, S3 endpoint and CDN Hostname values.

10. Google reCAPTCHA

In order to enable Google reCAPTCHA for public forms (like register page, contact page, etc), you will need to:

  • You can get your API Keys from this link.
  • Create a new app and use reCAPTCHA v2 > "I'm not a robot" Checkbox type of keys.
  • Copy your Site Key and Key secret and add them into the Admin > Settings > Security > Recaptcha fields.

11. Social login(s)

11.1 Overview

Though the social login providers UI can change, the general steps that must be taken in order to allow social logins is:

  • Get an approved app on the social login provider
  • Get the ClientID & Client Secret keys
  • Add the keys within the Admin > Settings > Social media category
  • Within the Admin > Settings > Social media copy the Callback url for the provider
  • Add the Callback url for the respective provider, back on their page over the CallbackUrl/Authorized urls section.
11.2 Social providers info
Twitter
  • Go to https://developer.twitter.com and create a new app
  • Get elevated access to Twitter api over at this link
  • Select the Application Environment (dev or prod), name your app, then you will get the API Key and API Key secret which you need to copy and add them into Admin > Settings > Social media section.
  • Once the app is created, go to app settings & click on Setup button from user authentication settings menu.
  • Enable the checkbox for OAuth 1.0a in users authentication settings.
  • For "App permissions" select "Read".
  • Enable the "Request email address from users" option.
  • Copy admin Callback url and add it to Callback URLs field, over twitter app's settings.
Google Facebook
  • Go to https://developers.facebook.com/apps and create a new app > Consumer and fill in your details.
  • Go to your App settings > Basic, then copy the App ID & App secret and add them in the Admin > Settings > Social media section.
  • Go to App > Facebook Login > Settings
  • Copy admin Callback url and add it to Valid OAuth Redirect URIs

12. OpenAI

The AI-suggestions feature can be enabled via the Admin > Settings > AI area, where you can enable or disable the feature, which can offer OpenAI based suggestions for users posts and bio descriptions.

The other setting you need to fill in is the OpenAI Api Key, alongside other prediction settings. You can get your API key by registering an account over at Open-AI site and get your key over this link OpenAI API Keys.

13. Slack Webhook Configuration

13.1 Steps to Create Slack Webhook URL
  • Sign in to your Slack workspace.
  • Go to Slack API: Apps and click "Create New App".
  • Select "From scratch", name your app, and choose your workspace.
  • In the app settings, select "Incoming Webhooks" from the left sidebar.
  • Switch the toggle to "On" to activate Incoming Webhooks.
  • Click "Add New Webhook to Workspace".
  • Select the channel where you want to post messages and click "Allow".
  • Copy the generated webhook URL.
  • Go to Admin > Settings > Slack and add the webhook URL in the Slack webhook URL field.

14. Localization

In order to translate your site in any language, you will need to make a copy of the default en.json language file found in lang folder, and change it according to your needs.

  • The json language file must follow iso format, eg: es.json, ro.json, en.json.
  • If you need to overwrite the validation rules messages or other libraries, the en folder can be copied and renamed to the new language code.
Though not enforced, having the PHP intl extension available will improve the localization experience and avoid issues with custom, un-common languages.

15. Admin panel

15.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'
15.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
  • Jobs management - Browse and manage all jobs and their associated data
    1. Manage skills
    2. Manage categories
    3. Manage job applicants ranges
    4. Manage job salary ranges
    5. Manage job types
    6. Manage job skills
  • Companies management - Browse and manage all companies and their associated data
  • 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 reports
  • Money management - View and manage subscriptions and payments related data
    1. Manage subscriptions
    2. Manage transactions
    3. Manage manual payment requests
    4. Manage invoices
  • Taxes - Manage taxes, countries and regions
  • Plans - Create and manage the available subscription packages
  • Pages - Create and manage public pages
  • Contact messages - Preview received contact messages
  • Featured clients - Manage clients to be featured on the homepage
  • Featured categories - Manage categories to be featured on the homepage
  • Newsletter - Manage newsletter subscribers
  • Settings - Change a wide variety of site settings
  • Site settings
    1. Site title
    2. Site description
    3. Site slogan
    4. Light site logo
    5. Dark site logo
    6. Site favicon
    7. Share:og image
    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. Allow PWA Installs
    14. Newsletter box homepage position
    15. Display featured clients area on the homepage
    16. Display popular tags box on the homepage
  • Media settings (See 7.4. Setting up FFMpeg)
    1. Allowed file extensions
    2. Max file uploads size (MB) Do not exceed PHP limits
    3. Use chunked uploads
    4. Chunks size
    5. Max avatar&cover file size
  • Payments settings (See 7.1. Setting up the payment )
    1. Manage general settings
    2. Manage individual payment processors
    3. Manage invoices data
  • 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, Minio, PushrCDN 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.
  • Custom Code / Ads
    1. Job page sidebar ad - Will be shown on the listing page right sidebar.
    2. Custom CSS Code - Custom code to inject in the platform
    3. Custom JS Code - Custom code to inject in the platform
  • Admin settings
    1. Admin Title
    2. Admin Description
    3. Admin Loading spinner image
    4. Admin Icon Image
    5. Admin Background Image
    6. Admin notifications for contact messages
  • Compliance settings
    1. Enable cookies box.
    2. Enable age verification dialog.
    3. Age verification box cancel url.
  • Security settings
    1. Manage 2fa, recaptcha and more.
  • AI Settings
    1. Open-AI based suggestions settings.
  • Colors
    1. Generate your own custom theme.
  • License
    1. Your product license settings.
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.

16. 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.

17. 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.
  • 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/views/page.blade.php view file (for HTML)
    3. public/js/pages/page.js (For Javascript changes)
    4. public/css/pages/page.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. For the footer, you would have to edit the resources/views/template/footer.blade.php file.

  • In order to change your PWA app icon and splash screen assets, you will need to replace the existing ones within the public/img/pwa folder.

    Usually, after replacing the assets, the browser cache must be cleaned in order to see the new icon and splash screen in action.

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

    1. Create your own (private) 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

18. Contact us

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