Jim by Norwich Artist Charli Vince

James Seconde

Developer Advocate | Speaker | Writer | Podcast Host

A Guide on How to Develop a Shopify App with Laravel & PHP

Basic building blocks for an integration with Shopify's API using Laravel.

James Seconde

5-Minute Read

Shopify and Laravel logos on purple background

This article was originally written by me for Eastside Co's blog: you can find the original here

The Shopify platform contains a whole host of built in functionality. However, thanks to its fully featured REST and GraphQL API access, it also has a thriving app store with a huge range of plug-ins designed to enhance Shopify store functionality in many ways. I'll talk you through a Shopify app development tutorial to help you get started on making your own Shopify app, using the Laravel PHP framework.

What is a Shopify App?

A Shopify app is an externally-hosted service that has access to and can manipulate a Shopify store. For the most part, any feature you can see in the admin panel can be accessed and changed via the API - it can modify/create products, view or change orders and so on. Apps are a great way to automate common tasks such as bulk-editing collections or extending your store's functionality, like adding reviews to your products. The 2 Types of Shopify Apps

Public apps can be submitted to the app store and used by multiple stores. To create and submit normal apps to the Shopify App Store, you need to own a Shopify Partner account.

Private apps are usually used by a single store. In this article, we’ll be going through the steps for Shopify private app development, as they can be created by anyone with a Shopify store and require less steps to set up.

How to Create a Shopify App Using PHP

To follow this guide, you will need:

  • A Shopify store you want to make an app for.
  • PHP7.2 or higher and some familiarity with the language (https://www.php.net/supported-versions.php).
  • Some familiarity with a command line (cmd.exe/Powershell for Windows, bash/zsh/fish for MacOS and unix-like distributions).
  • Some familiarity with Composer.

API Keys

Let’s begin by creating a set of API keys for our app. Head to the Apps panel from the right hand navigation.


Private Apps Menu

Click ‘Create a new private app’ to get the prompt to name your app.

Create Private App

We'll leave the API dropdowns so that the app only has read access to your store.

Admin API

Make a note of your new credentials. And with that step, it’s time to set up a local Laravel & vue.js app.

Setting up a Laravel Skeleton

So, first we’re going to install a fresh Laravel skeleton app. You can do this via the Laravel installer (https://github.com/laravel/installer), but the quickest route is to use Composer’s create project. Open up your command line and create a new project:

composer create-project --prefer-dist laravel/laravel shopifyApp

We’re going to use Twig (https://twig.symfony.com/) instead of Laravel’s built-in Blade templating system for the front end, because the syntax Twig uses is based on Ruby’s Liquid templating system, used by Shopify on its platform. We’re going to be using Rob Crowe’s bridge connector for Laravel. Install Twig, following the instructions on the readme located here - https://github.com/rcrowe/TwigBridge

Now we have Twig, let’s get a page up and running by creating a new route, controller and Twig template. To create a new controller, in the command line run

php artisan make:controller shopifyController

Now we need to wire up a route, controller and view. Add a new route to routes/web.php:

Route::get('/index', 'ShopifyController@index');

Create the method in your controller, which will now be in /app/Http/Controllers/ShopifyController:


namespace App\Http\Controllers;

class ShopifyController extends Controller
  public function index()
     return view('index');

The last part is to create the ‘index’ view - create a new file in: /resources/views called index.twig.

Using Eastside Co’s API Wrapper

We now need to use the Eastside Co Shopify API wrapper to bring us back some data to render. Eastside Co have already got a PHP package on packagist - it’s an API code wrapper for common REST API tasks with Shopify. Navigate into the ShopifyApp directory in your command line and install the Eastside Co API:

composer require esc/shopify

To enable the installed package, we need to add it to services and install assets. You do this by doing the following:

Add \Esc\Shopify\Providers\APIServiceProvider::class into the providers array in /config/app.php.

Run php artisan vendor:publish in the command line to copy the package assets into Laravel.

We can now input the ShopifyAPI keys. Create a copy of your .env.dist and called it .env. In the .env file, add the keys that the API object will read in when the service is created in Laravel:

SHOPIFY_API_SECRET = <Shared Secret>

Final Render

Let’s get the data in the controller and pass it to the index Twig template we created. Change the controller’s index method to look like the following:

public function index() {
    $shopifyApi = app(‘ShopifyAPI’);
    $products = $shopifyApi->call('GET', 'admin/products.json&page=1');
    return view('index', (array) $products);

We’re now passing the first page of our store’s products to Twig, which we can now render out - open the resource/views/index.twig file we created. You can use a foreach loop in twig which operates the same as the php foreach function:

   <p>This is an example Shopify APP page!</p>
   {% for product in products %}
       This product is called: {{ product.title }}</br>
   {% endfor %}

That’s it! Navigate to your route and the product titles will be rendered out by Twig.

A repository of this basic scaffolding is available on our Github, at https://github.com/EastsideCo/blog-basic-laravel

Hopefully that helps give you some insight into the process behind creating a private Shopify app. If you have an idea for a private app but need developer support, get in touch - we have a whole team of developers dedicated to creating public and private Shopify apps for a whole range of functionality.

Recent Posts



Hi! I'm James. I do Developer Relations at Vonage.