Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/bigcommerce/hello-world-app-php-silex

Hello World sample app in PHP and Silex
https://github.com/bigcommerce/hello-world-app-php-silex

bigcommerce oauth-application php silex

Last synced: 3 days ago
JSON representation

Hello World sample app in PHP and Silex

Awesome Lists containing this project

README

        

# BigCommerce Sample App: PHP

This is a small Silex application that implements the OAuth callback flow for BigCommerce [Single Click Apps][single_click_apps]
and uses the [BigCommerce API][api_client] to pull a list of products on a BigCommerce store. For information on how to develop apps
for BigCommerce stores, see our [Developer Portal][devdocs].

We hope this sample gives you a good starting point for building your next killer app! What follows are steps specific
to running and installing this sample application.

## Prerequisites
* A web server such as MAMP or Apache. A localhost address will work fine for the hello world app.
* PHP
* [Composer](https://getcomposer.org/doc/00-intro.md "Composer")

### Registering the app with BigCommerce
1. Create a trial store on [BigCommerce](https://www.bigcommerce.com/)
2. Go to the [Developer Portal][devportal] and log in by going to "My Apps"
3. Click the button "Create an app", enter a name for the new app, and then click "Create"
4. You don't have to fill out all the details for your app right away, but you do need
to provide some core details in section 4 (Technical). Note that if you are just getting
started, you can use `localhost` for your hostname, but ultimately you'll need to host your
app on the public Internet.
* _Auth Callback URL_: `https:///bigcommerce/callback`
* _Load Callback URL_: `https:///bigcommerce/load`
* _Uninstall Callback URL_: `https:///bigcommerce/uninstall`
* _Remove User Callback URL_: `https:///bigcommerce/remove-user` (if enabling your app for multiple users)
5. Enable the _Products - Read Only_ scope under _OAuth scopes_, which is what this sample app needs.
**Note:** If you are managing customer information through the API (such as with the _Recently Purchased Products Block_ example below) then you will need to also enable the _Customers_ scope to at least read data.
below) then you will need to also enable the _Customers_ scope to at least read.
6. Click `Save & Close` on the top right of the dialog.
7. You'll now see your app in a list in the _My Apps_ section of Developer Portal. Hover over it and click
_View Client ID_. You'll need these values in the next step.

### Getting Started
1. Fork the repo (optional).
2. Clone the repo.

git clone https://github.com/bigcommerce/hello-world-app-php-silex
3. Use Composer to install the dependencies.

php composer.phar install
4. Copy `.env-example` to `.env` and set the following environment variables in it.

BC_AUTH_SERVICE=https://login.bigcommerce.com
BC_CLIENT_ID=
BC_CLIENT_SECRET=
BC_CALLBACK_URL=
4. Restart the software or the entire host as needed to set the environment variables.

### Hosting the app
In order to install this app in a BigCommerce store, it must be hosted on the public Internet. You can get started in development and use `localhost` in your URLs, but ultimately you will need to host it somewhere to use the app anywhere other than your development system. One easy option is to put it on Heroku.

#### Heroku
_Note: It is assumed that you already have a Heroku account, have the Heroku toolbelt installed, and have authenticated with
the toolbelt. See [Heroku][toolbelt] for details._

* Create a new Heroku app: `heroku create `
* Push the project to Heroku: `git push heroku master -u`
* Set `APP_URL` in .env to `https://.herokuapp.com`
* Add the `heroku-config` plugin: `heroku plugins:install heroku-config`
* Push the local environment variables to heroku: `heroku config:push`

In the [BigCommerce Developer Portal][devportal], you'll need to update the app's callback URLs:

* _Auth Callback URL_: `https://.herokuapp.com/auth/callback`
* _Load Callback URL_: `https://.herokuapp.com/load`
* _Uninstall Callback URL_: `https://.herokuapp.com/uninstall`

### Installing the app in your trial store
* Login to your trial store
* Go to the Marketplace and click _My Drafts_. Find the app you just created and click it.
* A details dialog will open. Click _Install_ and the draft app will be installed in your store.

## Showing the Recently Purchased Products Block with JWT
This example repo contains the ability to securely show recently purchased products. This is how it looks:

![](http://monosnap.com/image/iuFxhuS8havstVdzNHQGjz2aDmzDwO.png)

### Adding the block to your theme
1. Edit your `Footer.html` file in blueprint or Footer Scripts if you're using Stencil and add:
```javascript

var appClientId = "**BC_CLIENT_ID**"; // TODO: Fill this in with your app's client ID.
var storeHash = "**TEST_STORE_HASH**"; // TODO: Fill this in wit the test store's store hash (found in base url before the `store-` part)
var appUrl = "**APP_URL**"; // TODO: Replace this with the URL to your app.

// Get the JWT token from the BC server signed first.
$.get('/customer/current.jwt?app_client_id='+appClientId, function(jwtToken) {
// Now that we have the JWT token, use it to get the recent purchases block.
$.get(appUrl+'/storefront/'+storeHash+'/customers/'+jwtToken+'/recently_purchased.html', function(htmlContent) {
$('#recent_purchases_block').html(htmlContent, true);
});
});

```
2. Put `

` wherever you want the block to appear. If you're using blueprint it is recommended that you put it in default.html right before `%%Panel.SideTopSellers%%`.
3. Log in as a customer in your store's frontend (or create a customer account if one doesn't exist yet), place an order then go to the section where you added the `
`. You should see the Recently Purchased Products block appear.

[single_click_apps]: https://developer.bigcommerce.com/api/#building-oauth-apps
[api_client]: https://github.com/bigcommerce/bigcommerce-api-php
[devdocs]: https://developer.bigcommerce.com
[devportal]: https://devtools.bigcommerce.com
[toolbelt]: https://toolbelt.heroku.com