wallet
Wallet-Api Server
How it works
- API server accepts json payload for the pass information.
- Upon receiving the payload:
- Google TicketClass/TicketObject are created and URL that can be saved by the user in Google Pay app is provided.
- Apple .pkpass file is created and is uploaded to the google drive (associated with the auth credentials of google service).
- 2 URLs are returned as response payload
apple_pass_url
andgoogle_pass_url
.apple_pass_url
is the url to the.pkpass
file uploaded to google drive.
Available EndPoints
- Requires authentication header
x-api-key
which must matchAPI_KEY
ENV VAR
1. POST /
BODY
{
"event_name": "My event",
"ticket_holder_name": "John Smith",
"location": {
"lat": 37.424299996,
"lon": -122.0925956000001,
"name": "Sydney International Convention Centre",
"address": "ICC Sydney"
},
"date_time": {
"start": "2023-04-12T11:20:50.52Z",
"end": "2023-04-12T16:20:50.52Z"
},
"qr_code": {
"value": "http://example.com/best_url",
"alt_text": "1234567890"
},
"logo": {
"image_uri": "https://example.com/logo.png",
"description": "Logo Desc"
},
"icon": { "image_uri": "https://example.com/icon.png" },
"event_details": { "header": "My header", "body": "BODY of the event" }
}
Required fields:
event_name
ticket_holder_name
location
date_time
qr_code
SUCCESS RESPONSE
status_code: 200
{
"apple_pass_url": "https://wallet-api-server.example.com/apple_pass_file_google_drive_file_id",
"google_pass_url": "https://pay.google.com/gp/v/save/SIGNED_ENCODED_PASS_INFORMATION"
}
RESPONSE WITH ERRORS
Occurs when all required fields are not provided in the request payload or Pass generation fails for either google or apple.
status_code: 422
{
"errors": { "event_name": "is required" }
}
2. GET /:apple_pass_file_google_drive_file_id
- Doesn't require authentication.
Response
Returns apple_pass_file_google_drive_file_id.pkpass
file
Considerations
- Currently all created apple
.pkpass
files are uploaded to the google drive. Which was chosen for the simplicity of implementation and for the fact that we already have access to the google drive due to google service account. - Uploaded
.pkpass
files are being proxied/served by the wallet api server. - Uploaded
.pkpass
files have format of#{uuid}.pkpass
, which avoids leaking of attendee name to users that might have access to the google drive folder. - We might want to consider, uploading the files to s3 to offload serving of files and probably for having the ability to prune files that haven't been accessed for a while.
ENV Variables
# Needed to be passed in headers for authentication with API server
API_KEY=SECURE_KEY
# APPLE PASS
# Data needed to create/sign pass
# Base64-encoded PEM Keys
SIGNING_CERT=<...>
PRIVATE_KEY=<...>
WWDR_CERT=<...>
PRIVATE_KEY_PASSWORD=12345
APPLE_TEAM_IDENTIFIER=8EZ6J123456
APPLE_PASS_TYPE_IDENTIFIER=pass.technology.place.dev
APPLE_ORGANIZATION_NAME='ACA Projects Australia Pty Ltd'
# Default data for pass, can be customized per request as well
APPLE_LOGO_PATH='/resources/logo.png'
APPLE_ICON_PATH='/resources/icon.png'
APPLE_LOGO_DESCRIPTION='PlaceOS Wallet'
# Customize pass design
APPLE_DESIGN_FOREGROUND_COLOR='rgb(255, 255, 255)'
APPLE_DESIGN_BACKGROUND_COLOR='rgb(66, 80, 112)'
APPLE_DESIGN_LABEL_COLOR='rgb(255, 255, 255)'
# GOOGLE PASS
GOOGLE_WALLET_ISSUER_ID=12345678890
GOOGLE_WALLET_ISSUER_NAME=PlaceOS
# Base64-encoded PEM Key
GOOGLE_PRIVATE_KEY=<...>
GOOGLE_CLIENT_EMAIL=admin@company.com
# Default data for pass, can be customized per request as well
GOOGLE_LOGO_IMAGE_URL='https://example.com/logo.png'
GOOGLE_LOGO_DESCRIPTION='PlaceOS Wallet'
# AWS Storage
AWS_REGION='us-east-1'
AWS_KEY=key
AWS_SECRET=secret
AWS_BUCKET=bucket
Testing
-
edit
.example.env
then run(set -a && source .example.env && crystal spec --error-trace)
-
to run in development mode
crystal ./src/app.cr
Compiling
crystal build ./src/app.cr
Deploying
Once compiled you are left with a binary ./app
- for help
./app --help
- viewing routes
./app --routes
- run on a different port or host
./app -b 0.0.0.0 -p 80
Repository
wallet
Owner
Statistic
- 4
- 0
- 0
- 0
- 7
- over 3 years ago
- August 17, 2020
License
MIT License
Links
Synced at
Sun, 22 Dec 2024 04:55:31 GMT
Languages