Agent skills for iOS, iPadOS, Swift, SwiftUI, and modern Apple framework development.
71
89%
Does it follow best practices?
Impact
—
No eval scenarios have been run
Advisory
Suggest reviewing before use
Overflow reference for the passkit skill. Contains advanced patterns that exceed the main skill file's scope.
Set up subscription-style recurring payments with PKRecurringPaymentRequest.
import PassKit
func createSubscriptionRequest() -> PKPaymentRequest {
let request = PKPaymentRequest()
request.merchantIdentifier = "merchant.com.example.app"
request.countryCode = "US"
request.currencyCode = "USD"
request.supportedNetworks = [.visa, .masterCard, .amex]
request.merchantCapabilities = .threeDSecure
let monthlyItem = PKRecurringPaymentSummaryItem(
label: "Monthly Subscription",
amount: 9.99
)
monthlyItem.intervalUnit = .month
monthlyItem.intervalCount = 1
request.paymentSummaryItems = [
monthlyItem,
PKPaymentSummaryItem(label: "My Service", amount: 9.99)
]
let recurringRequest = PKRecurringPaymentRequest(
paymentDescription: "Monthly Premium",
regularBilling: monthlyItem,
managementURL: URL(string: "https://example.com/manage")!
)
recurringRequest.billingAgreement = "You will be charged $9.99/month."
request.recurringPaymentRequest = recurringRequest
return request
}Enable coupon codes on the payment sheet and handle validation.
func createRequestWithCoupons() -> PKPaymentRequest {
let request = createPaymentRequest()
request.supportsCouponCode = true
request.couponCode = "" // pre-fill if known
return request
}
// Handle coupon code entry in the delegate
extension PaymentCoordinator: PKPaymentAuthorizationControllerDelegate {
func paymentAuthorizationController(
_ controller: PKPaymentAuthorizationController,
didChangeCouponCode couponCode: String,
handler completion: @escaping (PKPaymentRequestCouponCodeUpdate) -> Void
) {
Task {
do {
let discount = try await validateCoupon(couponCode)
let updatedItems = applyDiscount(discount)
completion(PKPaymentRequestCouponCodeUpdate(
paymentSummaryItems: updatedItems
))
} catch {
let couponError = PKPaymentRequest.paymentCouponCodeInvalidError(
localizedDescription: "Invalid coupon code."
)
completion(PKPaymentRequestCouponCodeUpdate(
errors: [couponError],
paymentSummaryItems: originalItems
))
}
}
}
}Request separate payment tokens for multiple merchants in one transaction using PKPaymentTokenContext.
func createMultiMerchantRequest() -> PKPaymentRequest {
let request = PKPaymentRequest()
request.merchantIdentifier = "merchant.com.example.platform"
request.countryCode = "US"
request.currencyCode = "USD"
request.supportedNetworks = [.visa, .masterCard, .amex]
request.merchantCapabilities = .threeDSecure
request.paymentSummaryItems = [
PKPaymentSummaryItem(label: "Hotel Stay", amount: 299.00),
PKPaymentSummaryItem(label: "Car Rental", amount: 89.00),
PKPaymentSummaryItem(label: "Travel Platform", amount: 388.00)
]
let hotelContext = PKPaymentTokenContext(
merchantIdentifier: "merchant.com.example.hotel",
externalIdentifier: "hotel-booking-123",
merchantName: "Example Hotel",
merchantDomain: "hotel.example.com",
amount: 299.00
)
let carContext = PKPaymentTokenContext(
merchantIdentifier: "merchant.com.example.carrental",
externalIdentifier: "car-rental-456",
merchantName: "Example Car Rental",
merchantDomain: "carrental.example.com",
amount: 89.00
)
request.multiTokenContexts = [hotelContext, carContext]
return request
}Set up payments that charge later, such as hotel bookings or pre-orders.
func createDeferredPaymentRequest() -> PKPaymentRequest {
let request = createPaymentRequest()
let deferredDate = Calendar.current.date(
byAdding: .day, value: 14, to: Date()
)!
let deferredRequest = PKDeferredPaymentRequest(
paymentDescription: "Hotel Booking - Check-in",
deferredBilling: PKDeferredPaymentSummaryItem(
label: "Hotel Stay (charged at check-in)",
amount: 299.00
),
managementURL: URL(string: "https://example.com/bookings")!
)
deferredRequest.freeCancellationDate = deferredDate
deferredRequest.freeCancellationDateTimeZone = .current
request.deferredPaymentRequest = deferredRequest
return request
}Passes in Wallet can receive push notifications to trigger an update. The flow:
webServiceURL and authenticationTokenwebServiceURL to fetch the updated .pkpass bundle| Method | Path | Purpose |
|---|---|---|
| POST | /v1/devices/{deviceId}/registrations/{passTypeId}/{serialNumber} | Register device for updates |
| DELETE | /v1/devices/{deviceId}/registrations/{passTypeId}/{serialNumber} | Unregister device |
| GET | /v1/devices/{deviceId}/registrations/{passTypeId} | Get serial numbers of updated passes |
| GET | /v1/passes/{passTypeId}/{serialNumber} | Download the latest pass |
import PassKit
let library = PKPassLibrary()
// Replace an existing pass with updated data
func updatePass(newPassData: Data) {
guard let updatedPass = try? PKPass(data: newPassData) else { return }
if library.containsPass(updatedPass) {
library.replacePass(with: updatedPass)
}
}A complete SwiftUI payment view with availability check, button, and processing.
import SwiftUI
import PassKit
struct PaymentView: View {
@State private var paymentStatus: PaymentStatus = .idle
private var canPay: Bool {
PKPaymentAuthorizationController.canMakePayments(
usingNetworks: [.visa, .masterCard, .amex],
capabilities: .threeDSecure
)
}
var body: some View {
VStack {
OrderSummaryView()
if canPay {
PayWithApplePayButton(.buy) {
processPayment()
}
.payWithApplePayButtonStyle(.black)
.frame(height: 48)
} else {
Button("Checkout with Card") {
// Fallback payment flow
}
.buttonStyle(.borderedProminent)
}
if case .error(let message) = paymentStatus {
Text(message)
.foregroundStyle(.red)
.font(.caption)
}
}
.padding()
}
@MainActor
private func processPayment() {
let coordinator = PaymentCoordinator { result in
paymentStatus = result
}
coordinator.startPayment()
}
}
enum PaymentStatus {
case idle
case processing
case success
case error(String)
}skills
accessorysetupkit
references
activitykit
references
adattributionkit
references
alarmkit
references
app-clips
app-intents
references
app-store-optimization
app-store-review
apple-on-device-ai
appmigrationkit
references
audioaccessorykit
references
authentication
references
avkit
references
background-processing
references
browserenginekit
references
callkit
references
carplay
references
cloudkit
references
contacts-framework
references
core-bluetooth
references
core-data
core-motion
references
core-nfc
references
coreml
references
cryptokit
references
cryptotokenkit
references
debugging-instruments
device-integrity
references
dockkit
references
energykit
references
eventkit
references
financekit
references
focus-engine
gamekit
references
healthkit
references
homekit
references
ios-accessibility
ios-localization
ios-networking
ios-simulator
references
mapkit
metrickit
references
musickit
references
natural-language
references
paperkit
references
passkit
references
pdfkit
references
pencilkit
references
permissionkit
references
photokit
push-notifications
realitykit
references
relevancekit
references
scenekit
references
sensorkit
references
speech-recognition
spritekit
references
storekit
swift-api-design-guidelines
swift-architecture
swift-charts
references
swift-codable
swift-concurrency
swift-formatstyle
swift-language
swift-security
references
swift-testing
swiftdata
swiftlint
swiftui-animation
swiftui-gestures
references
swiftui-layout-components
swiftui-liquid-glass
references
swiftui-patterns
swiftui-performance
swiftui-uikit-interop
swiftui-webkit
tabletopkit
references
tipkit
references
vision-framework
weatherkit
references
widgetkit
references