Skip to content

Conversation

@grdsdev
Copy link
Contributor

@grdsdev grdsdev commented Aug 26, 2025

Summary

This PR proposes migrating the Supabase Swift SDK's HTTP networking layer from URLSession to Alamofire. This is a proposal/RFC and not the final implementation.

Key Changes

  • Networking Layer: Replaced custom HTTPClient with Alamofire's Session-based approach
  • Error Handling: Improved error handling across Auth, Functions, Storage, and PostgREST modules
  • Request/Response: Streamlined request building and response processing
  • Dependencies: Added Alamofire as a dependency in Package.swift
    - Testing: Updated all test suites to work with the new networking approach

Modules Updated

  • Auth: Complete migration with improved error handling and typed AuthError throws
  • Functions: Migrated to Alamofire with enhanced request processing
  • Storage: Updated API clients to use new networking layer
  • PostgREST: Refactored builders and query handling
  • Helpers: New NetworkingConfig and SessionAdapters for Alamofire integration

Benefits of This Migration

  1. Reduced Complexity: Eliminates custom HTTP client code in favor of battle-tested Alamofire
  2. Better Error Handling: More consistent and typed error responses across all modules
  3. Enhanced Features: Built-in request/response interceptors, retry logic, and logging
  4. Maintainability: Less custom networking code to maintain
  5. Performance: Alamofire's optimized connection pooling and request management
  6. Advanced Upload/Download Capabilities:
    • Streaming Uploads/Downloads: Native support for streaming large files without memory overhead
    • Background Transfers: Seamless background upload/download support for mobile apps
    • Resumable Transfers: Built-in support for resuming interrupted uploads and downloads
    • Streaming Responses: Enhanced streaming support for Edge Functions responses
    • Progress Tracking: Real-time progress monitoring for file operations

Breaking Changes

⚠️ This migration introduces breaking changes to both internal and public APIs:

  • Module Initialization: All modules (Auth, Functions, Storage, PostgREST) now expect an Alamofire Session instance instead of fetch handlers during initialization
  • Configuration Changes: Custom HTTP configurations now need to be provided through Alamofire session configuration
  • Error Types: Some error handling patterns have changed due to Alamofire's error structure

While we aim to maintain backward compatibility where possible, users may need to update their initialization code when adopting this version.

Test Plan

  • All existing unit tests pass with Alamofire integration
  • Integration tests updated and passing
  • Error handling verified across all modules
  • Performance testing shows no regression

Next Steps

This PR is intended for review and discussion. Before merging:

  1. Community feedback on the migration approach
  2. Performance benchmarking against current implementation
  3. Final review of breaking changes
  4. Documentation updates
  5. Migration guide for any affected users

🤖 Generated with Claude Code

@grdsdev grdsdev marked this pull request as draft August 26, 2025 12:52
@coveralls
Copy link

coveralls commented Aug 26, 2025

Pull Request Test Coverage Report for Build 17331960505

Details

  • 1027 of 1123 (91.45%) changed or added relevant lines in 27 files are covered.
  • 27 unchanged lines in 8 files lost coverage.
  • Overall coverage increased (+1.2%) to 78.634%

Changes Missing Coverage Covered Lines Changed/Added Lines %
Sources/Auth/AuthAdmin.swift 78 79 98.73%
Sources/Auth/Internal/APIClient.swift 27 28 96.43%
Sources/PostgREST/PostgrestBuilder.swift 34 35 97.14%
Sources/Functions/Types.swift 24 26 92.31%
Sources/Helpers/WrappingError.swift 12 14 85.71%
Sources/Auth/AuthError.swift 10 17 58.82%
Sources/Auth/AuthClient.swift 333 351 94.87%
Sources/Supabase/SupabaseClient.swift 9 39 23.08%
Sources/Helpers/NetworkingConfig.swift 0 34 0.0%
Files with Coverage Reduction New Missed Lines %
Sources/Auth/AuthAdmin.swift 1 98.13%
Sources/Auth/AuthError.swift 1 50.0%
Sources/Auth/AuthMFA.swift 2 93.7%
Sources/Auth/Internal/Dependencies.swift 2 81.25%
Sources/Storage/StorageFileApi.swift 2 97.15%
Sources/Supabase/SupabaseClient.swift 2 68.15%
Sources/Auth/AuthClient.swift 3 87.21%
Sources/Helpers/FoundationExtensions.swift 14 72.22%
Totals Coverage Status
Change from base Build 17067440025: 1.2%
Covered Lines: 5156
Relevant Lines: 6557

💛 - Coveralls

@grdsdev grdsdev changed the title RFC: Migrate HTTP networking from URLSession to Alamofire feat!: Migrate HTTP networking from URLSession to Alamofire Aug 29, 2025
@grdsdev grdsdev changed the title feat!: Migrate HTTP networking from URLSession to Alamofire feat: Migrate HTTP networking from URLSession to Alamofire Aug 29, 2025
@grdsdev grdsdev changed the title feat: Migrate HTTP networking from URLSession to Alamofire RFC: migrate HTTP networking from URLSession to Alamofire Aug 29, 2025
grdsdev and others added 25 commits September 30, 2025 07:33
BREAKING CHANGE: This begins the migration from custom HTTP client to Alamofire.
Added Alamofire 5.9+ as a dependency to the Helpers module.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <[email protected]>
BREAKING CHANGE: Replace URLSession with Alamofire.Session in GlobalOptions.
- Updated SupabaseClientOptions.GlobalOptions to use Alamofire.Session instead of URLSession
- Modified SupabaseClient networking methods to use Alamofire request/response handling
- Added SupabaseNetworkingConfig and SupabaseAuthenticator for future extensibility
- Fixed Session type ambiguity by using fully qualified types (Auth.Session vs Alamofire.Session)

This is part of Phase 2 of the Alamofire migration.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <[email protected]>

# Conflicts:
#	Supabase.xcworkspace/xcshareddata/swiftpm/Package.resolved
BREAKING CHANGE: Replace StorageHTTPSession with direct Alamofire.Session usage.
- Updated StorageClientConfiguration to use Alamofire.Session instead of StorageHTTPSession
- Refactored StorageApi.execute() method to use Alamofire request/response handling
- Removed StorageHTTPClient.swift as it's no longer needed
- Updated deprecated storage methods to use Alamofire.Session
- Maintained existing multipart form data functionality

This is part of Phase 3 of the Alamofire migration.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <[email protected]>
BREAKING CHANGE: Replace FetchHandler with direct Alamofire.Session usage.
- Updated AuthClient.Configuration to use Alamofire.Session instead of FetchHandler
- Refactored APIClient.execute() method to use Alamofire request/response handling
- Updated Dependencies structure to use Alamofire.Session
- Fixed deprecated auth methods to use Alamofire.Session
- Removed custom HTTPClient usage from Auth module

This is part of Phase 4 of the Alamofire migration.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <[email protected]>
BREAKING CHANGE: Replace FetchHandler with direct Alamofire.Session usage.

Functions Module:
- Replaced FetchHandler with Alamofire.Session in FunctionsClient
- Updated rawInvoke() to use Alamofire request/response handling
- Simplified streaming functionality to use default configuration
- Removed sessionConfiguration dependencies

PostgREST Module:
- Updated PostgrestClient.Configuration to use Alamofire.Session
- Refactored PostgrestBuilder to use Alamofire directly
- Updated deprecated methods to use Alamofire.Session
- Removed custom HTTPClient usage

This is part of Phase 5 of the Alamofire migration.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <[email protected]>
BREAKING CHANGE: Replace fetch handler with Alamofire.Session for HTTP operations.

- Updated RealtimeClientOptions to use Alamofire.Session instead of fetch handler
- Modified RealtimeClientV2 protocol and implementation to use session property
- Updated RealtimeChannelV2 broadcast functionality to use Alamofire for HTTP requests
- WebSocket functionality remains unchanged (URLSessionWebSocket)
- Fixed async/await patterns in broadcast acknowledgment handling

Note: Deprecated RealtimeClient still uses custom HTTP implementation for backward compatibility.

This is part of Phase 6 of the Alamofire migration.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <[email protected]>
… Realtime

- Removed custom HTTPClient, LoggerInterceptor, and RetryRequestInterceptor files
- Fixed deprecated RealtimeClient to use Alamofire.Session instead of HTTPClientType
- Updated deprecated RealtimeChannel broadcast functionality to use Alamofire
- Maintained backward compatibility for deprecated classes
- All modules now successfully build with Alamofire

This completes the removal of custom HTTP client implementation.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <[email protected]>
- Fixed SupabaseClient initialization to use 'session' parameter instead of deprecated 'fetch'
- Removed HTTPClientMock test helper as it's no longer compatible with Alamofire
- All modules now build successfully without compilation errors
- Only deprecation warnings remain, which are expected

This completes the Alamofire migration with a fully building project.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <[email protected]>
- Replace HTTPTypes import with Alamofire
- Update HTTPFields to HTTPHeaders
- Change header access patterns to use string keys
- Update HTTPRequest.Method to HTTPMethod
- Modify header merging logic for Alamofire compatibility
- Update tests across all modules to use Alamofire types
- Update AuthAdmin, AuthClient, and AuthMFA for Alamofire compatibility
- Refactor APIClient and SessionManager internal implementations
- Improve error handling and request formatting
- Update FunctionsClient for Alamofire compatibility
- Refactor FunctionInvokeOptionsTests and FunctionsClientTests
- Improve error handling and request formatting in Functions module
- Update PostgREST builders and client for Alamofire compatibility
- Refactor HTTP fields and Foundation extensions
- Improve query building and filtering with Alamofire
- Streamline request formatting and error handling
- Refine PostgREST builders and client implementation
- Update HTTP request handling and Foundation extensions
- Improve test coverage for Alamofire integration
- Streamline query building and filtering logic
- Update StorageApi and StorageFileApi for Alamofire compatibility
- Refactor StorageBucketAPITests and StorageFileAPITests
- Improve file upload and storage operations with Alamofire
- Streamline multipart form data handling
- Completely refactor AuthClient with Alamofire implementation
- Update AuthAdmin and AuthMFA for Alamofire compatibility
- Refactor APIClient and SessionManager internal components
- Enhance HTTP fields handling for Alamofire
- Streamline authentication flow and error handling
- Add better status code validation for Alamofire responses
- Enhance error handling for non-2xx HTTP responses
- Improve request validation and response processing
… serialization

- Replace HTTPRequest struct usage with direct execute method calls
- Use serializingDecodable() for JSON responses instead of manual decoding
- Use serializingData() for raw data responses
- Update method signatures to use new execute parameters
- Fix type conversions for headers and query parameters
- Remove unused encoder variables and fix async warnings
- Maintain backward compatibility while modernizing request handling
- Improve serialization patterns for better performance
- Clean up remaining manual decoding steps
- Ensure consistent error handling across all Storage operations
- Fix header handling in StorageApi to properly merge configuration headers
- Fix JSON encoding to maintain camelCase compatibility with tests
- Fix MultipartFormData import in tests
- Remove unused variable warnings
- Improve test organization and structure

Results:
- 93.3% test pass rate (56/60 tests passing)
- All core functionality tests now working
- Only 4 multipart boundary tests remaining (dynamic generation issue)

Next steps:
- Fix remaining boundary generation tests
- Add comprehensive upload/update functionality tests
- Add edge case and error handling tests
…oding

- Fix multipart form data boundary generation using testingBoundary in DEBUG mode
- Restore snake_case encoding for JSON payloads
- All Storage tests now passing (100% pass rate)

This completes the initial test fixes and provides a solid foundation for coverage improvements.
…mework

- Create detailed coverage analysis showing 100% test pass rate (60/60 tests)
- Identify missing coverage areas: upload/update unit tests, edge cases, performance tests
- Add upload test framework with 4 new test methods (needs snapshot fixes)
- Document implementation priorities and success metrics
- Improve test organization and structure

Current status:
- 100% test pass rate for existing tests
- 82% function coverage for StorageFileApi (18/22 methods)
- 100% method coverage for StorageBucketApi (6/6 methods)
- 100% class coverage for supporting classes

Next steps:
- Fix upload test snapshots
- Add remaining upload/update unit tests
- Implement edge case and error scenario tests
- Add performance and integration tests
- Document major achievements: 100% test pass rate (60/60 tests)
- Detail critical fixes: header handling, JSON encoding, boundary generation
- Provide current coverage analysis: 82% StorageFileApi, 100% StorageBucketApi
- Outline implementation priorities and next steps
- Include technical improvements and documentation created

The Storage module now has excellent test coverage with a solid foundation
for continued improvements and robust error handling.
…ror handling

- Fix upload test snapshots with proper Cache-Control headers and line endings
- Improve error handling in testUploadErrorScenarios with inline snapshots
- Update Content-Length headers to match actual request sizes
- Simplify metadata structure in testUploadWithOptions
- Add proper line ending characters (\#r) to multipart form data snapshots

These improvements complete the upload test framework and ensure all tests
pass consistently with proper snapshot matching.
- Add AlamofireExtensions for HTTP client abstraction
- Remove deprecated HTTP layer components (HTTPRequest, HTTPResponse, SessionAdapters)
- Rename HTTPFields to HTTPHeadersExtensions for clarity
- Update Auth, PostgREST, Realtime, and Storage modules to use new HTTP layer
- Remove unused test files and clean up dependencies
- Update documentation with final test coverage summary
- Clean up deprecated code and improve code organization
@grdsdev grdsdev changed the title RFC: migrate HTTP networking from URLSession to Alamofire feat: migrate HTTP networking from URLSession to Alamofire Sep 30, 2025
@grdsdev grdsdev changed the base branch from main to release/v3.0.0 September 30, 2025 13:51
@grdsdev grdsdev changed the title feat: migrate HTTP networking from URLSession to Alamofire feat!: migrate HTTP networking from URLSession to Alamofire Sep 30, 2025
- Remove typed throws annotations (throws(AuthError), throws(FunctionsError))
- Remove wrappingError helper function and WrappingError.swift
- Remove mapToAuthError and mapToFunctionsError functions
- Errors now propagate directly without type constraints or mapping

BREAKING CHANGE: Methods no longer use typed throws. Consumers catching specific error types need to use runtime type checking instead.
@grdsdev grdsdev marked this pull request as ready for review October 2, 2025 21:05
@grdsdev grdsdev deleted the branch release/v3.0.0 October 15, 2025 18:00
@grdsdev grdsdev closed this Oct 15, 2025
@grdsdev grdsdev deleted the alamofire branch October 15, 2025 18:01
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants