Latest Updates

Documenting code, one commit at a time.

Implementing Payment Provider Abstraction with Feature Flags

When integrating multiple payment providers into an application, managing the transition and allowing for flexibility becomes crucial. This post explores how to introduce an abstraction layer combined with feature flags to handle different payment providers, such as Stripe and Paddle.

The Challenge

Directly integrating a payment gateway like Stripe can tightly couple the payment logic within

Read more

Enhancing Subscription Recognition in Billing Systems

Introduction

This post addresses an issue where a billing system, specifically when using a service like Cashier, fails to correctly identify active subscriptions beyond the default type. We'll explore the problem and provide a solution to ensure all subscription types are properly recognized.

The Problem: Default Subscription Type Bias

In many billing systems, especially those utilizing

Read more

Enhancing the Quoting Module with New Features

Overview

Recent development efforts have focused on enriching the quoting module within our application. These enhancements streamline the user experience and improve overall functionality by introducing autocomplete capabilities, refined matching algorithms, and integrated conversation features.

Key Enhancements

Autocomplete Functionality

The addition of autocomplete significantly

Read more
PHP Laravel MySQL

Fixing Type Errors in Subscription Models

When working with custom models that extend core framework functionalities, it's crucial to maintain type compatibility. A recent fix in our application addressed a TypeError that arose from an incorrect extension of the Subscription model.

The Problem: Type Hint Mismatch

The custom Subscription model was initially set up to extend Eloquent's Model directly.

Read more

Improving Data Accuracy with Enhanced API Integration

Introduction

This post details an enhancement to our application's data aggregation process. We addressed an issue where total counts were inaccurate by switching from a local database to an external API for data retrieval, ensuring more reliable results.

The Problem: Data Discrepancies

Previously, our application relied on a local database table, populated with data from an events API,

Read more

Improving Database Transaction Handling in Tests

Introduction

During recent testing of the social login functionality in our application, we encountered intermittent failures. These "flaky" tests were traced back to how database transactions were being handled, particularly in PostgreSQL.

The Challenge

The core issue was that within a test, a failed database query (e.g., due to a validation error during profile synchronization) would

Read more