Product Updates
Type-Safe PHP Generation
Ian Bentley
December 5, 2024
PHP is so back
Off the back of Laravel’s $57 million Series A (opens in a new tab), we won’t be the first to observe that PHP is so back. Which makes it the perfect time to announce the beta release of our new PHP SDK Generator! We’re bringing modern type safety and a streamlined developer experience to the PHP SDKs generated on our platform.
Headline features
Our PHP SDK Generator balances a simple developer experience with feature depth.
Simple developer experience:
- Robust type safety with carefully typed properties for all models
- Readability for easy debugging with a streamlined, object-oriented approach
- Minimal external dependencies for a lightweight footprint
Depth:
- Union type support, embracing PHP 8’s modern type system
- Laravel service provider for seamless integration
- SDK hooks for customizing request workflows
- Pagination support for handling large datasets efficiently
- Retry logic for handling transient errors
Type safety in PHP
Humble beginnings
Born as a loosely typed language, PHP spent years as the wild child of web development, allowing developers to play fast and loose with their data types. But as applications have grown more complex, the need for stricter type checking has become apparent.
Enter PHP 7, which introduced scalar type declarations and return type declarations, marking the beginning of PHP’s type matruity. Next, PHP 8 landed, bringing union types, null-safe operators, and other type-related improvements that firmly put PHP on the path to true type-safety.
Building type safety into our SDK generation
Our PHP SDK Generator takes fullest advantage of PHP’s nascent type system. We’ve implemented a robust type-hinting system that leverages the latest PHP features to provide a truly type-safe developer experience. Here’s how we’ve done it:
- Native Types: Wherever possible, we use PHP’s native types like
enum
,string
,int
,float
, andbool
. - Class-Based Objects: We generate standard PHP classes with public properties, using attributes and reflection to guide serialization.
- DateTime Handling: We use the native
\DateTime
class for timestamp handling, ensuring consistent date and time operations. - Custom Types: For special cases like
Date
, we leverage theBrick\DateTime\LocalDate
class from our minimal set of dependencies.
Let’s take a look at how this translates into real code:
class Drink{public string $name;public float $price;public ?DrinkType $type;public ?int $stock;public ?string $productCode;public function __construct(string $name, float $price, ?DrinkType $type, ?int $stock, ?string $productCode){// Constructor implementation}}
This approach ensures that your IDE can provide accurate auto-complete suggestions, that type-related errors are caught early in the development process and that developers cannot accidentally build objects with incomplete data.
Unions: Embracing PHP 8’s Type System
One of the most exciting features of PHP 8 was the introduction of union types, and our SDK Generator leverages this to provide even more precise type definitions. Union types allow properties or parameters to accept multiple types, providing flexibility while maintaining type safety.
Here’s how we’ve implemented union types in our generated SDKs:
class BeverageContainer{/**** @var Shared\Mocktail|Shared\Cocktail $beverage*/public Shared\Mocktail|Shared\Cocktail $beverage;public function __construct(Shared\Mocktail|Shared\Cocktail $beverage){$this->beverage = $beverage;}}
A Lightweight Footprint
We understand the importance of keeping your project’s dependency tree manageable. That’s why our PHP SDK generator has been designed to rely on as few external libraries as possible. We’ve carefully selected a minimal set of dependencies:
guzzlehttp/guzzle
: For a robust HTTP clientjms/serializer
: To handle data serialization and deserializationBrick\DateTime
: For comprehensive date and time support
This lean approach ensures that integrating our generated SDK into your project won’t bloat your composer.json or introduce potential conflicts with your existing dependencies.
Laravel-compatible packages for every API
PHP generation comes with optional Laravel integration support that can be enabled in the SDK’s gen.yaml
configuration. This will generate a Laravel Service Provider (opens in a new tab). The following snippet demonstrates an example of how to use
the Laravel DI container with Dub’s PHP SDK (opens in a new tab).
use Dub\Dub;use Illuminate\Contracts\View\View;use Illuminate\Http\Request;final readonly class LinksController{public function __construct(private Dub $dub,) {}public function index(Request $request): View{return view('links.index', ['links' => $this->dub->links->list(),]);}}
Inject custom logic with hooks
One of our most powerful new features is SDK hooks, which allow you to intercept and modify requests at various stages in their lifecycle. This gives you precise control over how your users’ SDK interacts with your APIs, enabling customizations like:
- Adding custom headers or query parameters
- Modifying request bodies
- Implementing complex authentication flows
- Adding custom logging or monitoring
Here’s an example of how you might use hooks to make sure all requests are sent over HTTPS
:
namespace Some\SDK\Hooks;use GuzzleHttp\ClientInterface;class HttpsCheckHook implements SDKInitHook{public function sdkInit(string $baseUrl, ClientInterface $client): SDKRequestContext{$parts = parse_url($baseUrl)if (array_key_exists('scheme', $parts) && $parts['scheme'] !== 'https') {$parts['scheme'] = 'https';}$baseUrl = http_build_url($parts);return new SDKRequestContext($baseUrl, $client);}}
Enhanced Developer Experience
We’ve gone the extra mile to ensure that working with our generated PHP SDKs is a joy for developers:
- Improved Import Patterns: Say goodbye to namespace conflicts and hello to predictable behavior in your IDE’s type hinting.
- Intuitive Factory Pattern: Our convenient factory pattern manages the SDK configuration, making it a breeze to get started and customize as needed.
- Comprehensive Documentation: Each generated SDK comes with detailed markdown documentation, ensuring you have all the information you need at your fingertips.
Looking Forward
As we enter this beta phase, we’re excited to see how the PHP community puts our SDK Generator to work. We’re committed to refining and improving the generator based on your feedback, so don’t be shy – put it through its paces and let us know what you think!