wallet

Wallet-Api Server

How it works

  • API server accepts json payload for the pass information.
  • Upon receiving the payload:
    1. Google TicketClass/TicketObject are created and URL that can be saved by the user in Google Pay app is provided.
    2. 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 and google_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 match API_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

Thu, 21 Nov 2024 05:52:22 GMT

Languages