Skip to main content

A Loyalty Pass Journey

Today's post is going to serve as a bit of a journal, the pitfalls and triumphs I'm facing as I achieve a smooth user experience in the world of creating digital loyalty cards.  The main player I'm working with on this is with Airship (formally Urban Airship).  Their support has been fairly good, I personally had the most trouble in linking the template with Google Pay.  The best piece of advice I can give is, do not start creating the template until you have got the Merchant Centre all ready to go.

This is all going rather well at the moment, including using the Adaptive Link APIs which provides a simple query string approach which will redirect the request to either the iOS or Android pass depending on their device.  Ultimately though I would like to eventually call the Google and Apple API's directly so this has been a side project.

I'm starting with Google, and the main piece of documentation starts here. Straight away there is a missing, or at least missing from linked to this snippet they provide on how the classes
Google_Service_Walletobjects_* is defined.  Be sure to download this snippet and included in your project.

Next, there is nothing to say how they defined $assertObj in this snippet either, which is cruicial to produce the JWT of the created pass.  It took a few attempts to get through to their support that this was an outdated function library, and it was best to use this one.  Thankfully the rest was much like setting up any other kind of Google Cloud set up.  Here's how it goes.

Go ahead and create the service account that is going to be used with the Merchant Centre, and then enable the "Google Pay Passes API" service.  Be sure to get the copy of the service account JSON, you will need that.  Once this is all done, go in to the Merchant Centre and share the account with the service account email created by this process.

The Construct

Here is the general flow:


As you can see we have included the two missing scripts that we need to do the wallet objects and encryption.  That reminds me, you may also need to update your composer with these two packages:
This will certainly go hand in hand with the JWT encoding you'll need to do.  The documentation from Google isn't too bad from here, and I could write a hell of a lot covering every option.  Have a play, main thing to understand is that the classes are a collection of their respective objects.

One last thing, how they would advise you to use the encryption, unlike what is documented here, is I did something like the following:

Before you ask, the gpgp is defined in the construct above, and the _makeClass and _makeObject is part of my own definition.  I had also modified the construct of the GpapJwt to suit my way of incorporating the _jsonAuth from my own construct.

I really hope this helps! The encryption especially took days out of my life of searching and waiting for feedback from their support, let alone on how I can find the scripts necessary to create these classes.

Cheers!

Comments

Popular posts from this blog

Running NodeJS Serverless Locally

 So it's been a long time, but I thought this was a neat little trick so I thought I'd share it with the world - as little followers as I have.  In my spare time I've been writing up a new hobby project in Serverless , and while I do maintain a staging and production environment in AWS, it means I need to do a deployment every time I want to test all of the API's I've drafted for it. Not wanting to disturb the yaml configuration for running it locally, I've come up with a simple outline of a server which continues to use the same configuration.  Take the express driven server I first define here: And then put a index.js  in your routes folder to contain this code: Voila! This will take the request from your localhost and interpret the path against your serverless.yml and run the configured function.  Hope this helps someone!

question2answer Wordpress Integration

 Today I want to journal my implementation of a WordPress site with the package of "question2answer".  It comes as self-promoted as being able to integrate with WordPress "out of the box".  I'm going to vent a small amount of frustration here, because the only integration going on is the simplicity of configuration with using the same database, along with the user authentication of WordPress.  Otherwise they run as two separate sites/themes. This will not do. So let's get to some context.  I have a new hobby project in mind which requires a open source stack-overflow clone.  Enter question2answer .  Now I don't want to come across as completely ungrateful, this package - while old, ticks all the boxes and looks like it was well maintained, but I need every  page to look the same to have a seamless integration.  So, let's go through this step by step. Forum Index Update This step probably  doesn't need to be done, but I just wanted to mak...

Google Sheets Web App

 Greetings! Has been yet another long period since my last post, but hopefully the type of content makes up for it.  Today I'm writing about a need that I had to document my entire movie collection in Google Sheets, because some that were on my local network, some on DVD, some on my Playstation Video account and as well as my small collection in Google TV.  All in all there is currently over 500 movies, and growing. So the spreadsheet is fine on its own, but something nice and "pretty" was needed to list, search and filter by the movie's attributes.  I first got an API key to be used with  OMDB API .  This allows me to get a JSON of the movie's IMDB attributes with a search from the title.  I then added two functions in the "Apps Script" component of the sheet: From here, I could call the function to search (from a cell) with: =API(CONCAT("http://www.omdbapi.com/?apikey=*******&t=",ENCODEURL(A1))) That would return the JSON (assuming A1 is...