What’s New in v3.1.1
Guest Mode & Easier Widget Init — v3.1.1 makes
ShowProfileRequest non-throwing, allows customerId to be optional (guest mode), and keeps all v3+ code compatible.Highlights in v3.1.1
- Guest Mode Fix: Profile widget works without a customer ID.
- Non-Throwing ShowProfileRequest: Remove the
trykeyword when creating the request. - Optional customerId: Omit for guest experiences.
- Session Tokens: Still supported for secure routing to v4.1.
Migrate v3.1.0 → v3.1.1 (Non-Breaking)
- Update SPM dependency to
from: "3.1.1". - Drop
trywhen creatingShowProfileRequest(initializer is non-throwing). - Use guest mode when
customerIdis not available: - Authenticated mode stays the same:
What’s New in v3.0.0
Modern Swift API
Native Swift API with improved type safety and better Swift idioms
Async/Await Support
Full async/await support alongside traditional callback-based APIs
Enhanced Type Safety
Stronger typing and better compile-time checks with Swift generics
Improved Performance
Optimized SDK initialization and reduced memory footprint
Breaking Changes
1. SDK Initialization
v2:2. Customer Registration
v2:3. Event Tracking
v2:4. Method Name Changes
| v2 | v3.1.x |
|---|---|
Gameball.configure() | GameballApp.getInstance().init(config:) |
Gameball.registerPlayer() | GameballApp.getInstance().initializeCustomer(_:completion:) |
Gameball.sendEvent() | GameballApp.getInstance().sendEvent(_:completion:) |
PlayerAttributes | CustomerAttributes |
PlayerRegisterResponse | InitializeCustomerResponse |
5. Show Profile Widget
v2:6. Error Handling
v2:7. Session Token Authentication (New in v3.1.x)
Session tokens enable automatic v4.1 endpoint routing and enhanced security. The token is stored in memory with thread-safe access.
8. Async/Await Support (New in v3.0.0)
Migration Steps
From v3.0.0 to v3.1.x (No Breaking Changes)
v3.1.x is fully backward compatible. Simply update the dependency version. Session Token support is optional.
1
Update Dependency
Update your Swift Package Manager dependency to 3.1.1.
2
(Optional) Add Session Token
If you need enhanced security, add a session token to your configuration:
3
Test
Test your integration. All existing v3.0.0 code should work without changes.
From v2.x to v3.1.x
1
Update Dependency
Update your Swift Package Manager dependency to 3.1.1.
2
Update Initialization
Replace
Gameball.configure() with GameballConfig + GameballApp.getInstance().init(config:).3
Update Customer Registration
Replace
registerPlayer() with initializeCustomer() using the new request type InitializeCustomerRequest.4
Update Event Tracking
Update event creation to use the
Event model and pass it to sendEvent.5
Update Error Handling
Replace boolean success handlers with Result-based completion handlers to access detailed error information.
6
Update Show Profile
Use the non-throwing
ShowProfileRequest (guest mode optional) for displaying the profile widget.7
Test Thoroughly
Test all Gameball functionality (registration, events, profile, notifications, etc.) to ensure the migration is successful.
Compatibility
- Minimum iOS: iOS 12.0+
- Xcode: 12.0+
- Swift: 5.0+
Additional Resources
- GitHub Repository: https://github.com/gameballers/gameball-ios
- Changelog: https://github.com/gameballers/gameball-ios/blob/main/CHANGELOG.md
- Release Notes: https://github.com/gameballers/gameball-ios/blob/main/RELEASE_NOTES.md
- Developer Docs: https://developer.gameball.co