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. Our resident Developer Relations guru Jim Seconde talks you through a Shopify app development tutorial to help you get started on making your own Shopify app, using the Laravel PHP framework.


Learn More About our Development Services


Let’s work together to build your store

We are one of the world’s most trusted and experienced Shopify Plus Partners.

Get in touch

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.

Let’s work together to build your store

We are one of the world’s most trusted and experienced Shopify Plus Partners.

Get in touch

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.
Let’s work together to build your store

We are one of the world’s most trusted and experienced Shopify Plus Partners.

Get in touch

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.

apps panel

creating a private app

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

private app creation panel

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

admin api panel

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

Let’s work together to build your store

We are one of the world’s most trusted and experienced Shopify Plus Partners.

Get in touch

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:

<?php

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.

Let’s work together to build your store

We are one of the world’s most trusted and experienced Shopify Plus Partners.

Get in touch

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

  1. 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_KEY = <API Key>

SHOPIFY_API_SECRET = <Shared Secret>

SHOPIFY_ACCESS_TOKEN = <Password>

SHOPIFY_SHOP_DOMAIN=<my-store-domain.myshopify.com>
Let’s work together to build your store

We are one of the world’s most trusted and experienced Shopify Plus Partners.

Get in touch

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:

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

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.