After Authentication Job - gnikyt/laravel-shopify GitHub Wiki

For some apps, you may want something to fire after installation or authentication of a shop to the app. Some usecases:

  • Sending a welcome email to the shop owner
  • Configuring some extra database needs
  • Uploading assets to a theme on install

Setup

First, open config/shopify-app.php in your Laravel directory and search for After Authenticate Job in that file so you're at the right location.

Creating a job

php artisan make:job {YourJobName}

Example:

php artisan make:job AfterAuthenticateJob

Adding the job

In config/shopify-app.php you'll find something like:

    'after_authenticate_job' => [
        'job' => '',
        'inline' => false,
    ],

Simply replace job with the namespace to your job class. Example: \App\Jobs\AfterAuthenticateJob::class.

Inline Option

The inline option is for running the job immediately (inline) or dispatching it to a queue to run later. Most use cases you will leave this as false to dispatch to a queue. If you need to run something before the user accesses your app (like database setup, asset installs) that simply can't wait before the screen loads, then set inline to be true to run immediately.

Notes

The job you configure will run every time a shop installs the app and it will run every time they access the app through Shopify in a new session. If you wish this job to run only once on install, then you will need to track this on your own in the job, through something like the database to keep track if the job ran for that specific shop.