|
1 |
| -# passkit-python-quickstart |
2 |
| -Python Quickstart to create, distribute, analyse and manage your Digital Coupons / Membership / Boarding Passes for Apple Wallet and Google Pay |
| 1 | +PassKit Python Quickstart |
| 2 | +======================= |
| 3 | + |
| 4 | +[](https://opensource.org/licenses/MIT) |
| 5 | +[](https://pypi.org/project/passkit-python-grpc-sdk/) |
| 6 | + |
| 7 | +### Overview |
| 8 | + |
| 9 | +This quickstart aims to help get Python developers up and running with the PassKit SDK as quickly as possible. |
| 10 | + |
| 11 | +### Prerequisites |
| 12 | + |
| 13 | +You will need the following: |
| 14 | + |
| 15 | +- A PassKit account (signup for free at https://app.passkit.com) |
| 16 | +- Your PassKit SDK Credentials (available from the https://app.passkit.com/app/account/developer-tools) |
| 17 | +- Python 3.7 or above from https://www.oracle.com/java/technologies/downloads/ (https://docs.oracle.com/en/java/javase/18/install/overview-jdk-installation.html - guide on how to download) |
| 18 | +- Gradle Build Tool from https://gradle.org/install/ with guide on how to install |
| 19 | +- Apple wallet certificate id (for flights only, https://app.passkit.com/app/account/certificates) |
| 20 | +  |
| 21 | + |
| 22 | +### Configuration |
| 23 | + |
| 24 | +1. Download or clone this quickstart repository, create a folder `certs` in the resources folder of the repository and add the following three PassKit credential files: |
| 25 | + - certificate.pem |
| 26 | + - ca-chain.pem |
| 27 | + - key.pem |
| 28 | + |
| 29 | + You can disregard the key-java.pem credentials file as it is not compatible with Python. |
| 30 | +2. Use `pip install passkit-python-grpc-sdk` to download the latest sdk from python. |
| 31 | + |
| 32 | +### Membership Cards |
| 33 | +In the membership folder the methods there are: |
| 34 | +- create-program.py - takes a new program name and creates a new program |
| 35 | +- create-tier.py - takes the programId of the program just created in the above program, creates a new template (based of default template), creates a tier, and links this tier to the program |
| 36 | +- enrol-member.py - takes programId and tierId created by the above methods, and memberDetails, creates a new member record, and sends a welcome email to deliver membership card url |
| 37 | +- update-member.py - takes memberId and memberDetails, and updates existing member record |
| 38 | +- check-in-member.py - takes memberId and location details and checks in the selected member |
| 39 | +- check-out-member.py - takes memberId and location details and checks out the selected member |
| 40 | +- earn-points.py - takes a programId of an existing program and memberId of existing member to add points to chosen member |
| 41 | +- burn-points.py - takes a programId of an existing program and memberId of existing member to use points from a chosen member |
| 42 | +- delete-member.py - takes programId, tierId, memberId and memberDetails, deletes an existing member record |
| 43 | + |
| 44 | +### Coupons |
| 45 | +In the coupons folder the methods are: |
| 46 | +- create-campaign.py - takes a new campaign name and creates a new campaign |
| 47 | +- create-offer.py - takes a campaignId of the campaign you just created and creates a new template (based of default template), creates an offer, and links this offer to the campaign |
| 48 | +- create-coupon.py - takes campaignId and offerId created by the above methods, and couponDetails, creates a new coupon record, and sends a welcome email to deliver coupon card url |
| 49 | +- list-coupons.py - takes campaignId and returns list of coupon records under that campaign |
| 50 | +- update-coupon.py - takes a campaignId of an existing campaign and couponId of existing coupon to update that coupon |
| 51 | +- redeem-coupon.py - takes a campaignId of an existing campaign and couponId of existing coupon to redeem that coupon |
| 52 | +- void-coupon.py - takes the couponId, offerId and campaignId to void an existing coupon |
| 53 | + |
| 54 | +### Boarding Passes |
| 55 | +#### Issue A Boarding Pass. |
| 56 | +In the flights folder the methods are: |
| 57 | +- create-template.py - creates the pass template for flights and boarding passes |
| 58 | +- create-carrier.py - takes a new carrier code and creates a new carrier |
| 59 | +- create-airport.py - takes a new airport code and creates a new airport. |
| 60 | +- create-flight.py - takes templateId , from previous method, to use as base template and uses a carrier code, created from previous method, and creates a new flight |
| 61 | +- create-flight-designator.py - creates flight designator using flight code |
| 62 | +- create-boarding-pass.py - takes templateId, from previous method, and customer details creates a new boarding pass, and sends a welcome email to deliver boarding pass url |
| 63 | +- delete-flight.py - takes an existing flight number as well as other details and deletes the flight associated with it |
| 64 | +- delete-flight-designator.py - takes an existing flight designation and deletes the flight designator associated with it |
| 65 | +- delete-airports.py - takes an existing airport code and deletes the airport associated with it |
| 66 | +- delete-carrier.py - takes an existing carrier code and deletes the carrier associated with it |
| 67 | + |
| 68 | + |
| 69 | +## Documentation |
| 70 | +* [PassKit Membership Official Documentation](https://docs.passkit.io/protocols/member) |
| 71 | +* [PassKit Coupons Official Documentation](https://docs.passkit.io/protocols/coupon) |
| 72 | +* [PassKit Boarding Passes Official Documentation](https://docs.passkit.io/protocols/boarding) |
| 73 | +* [PassKit Events Official Documentation](https://docs.passkit.io/protocols/event-tickets/) |
| 74 | + |
| 75 | + |
| 76 | + |
0 commit comments