Latest Updates

Documenting code, one commit at a time.

Laravel PHP OAuth

Limiting OAuth Providers in Laravel

Working on the devlog-ist/landing project, we're refining the authentication flow. The goal is to streamline user registration and login, particularly for non-developers who might be contributing recommendations. We've adjusted the available OAuth providers to match user roles.

Previously, both GitHub and LinkedIn were presented as default options on the login and registration pages.

Read more
PHP Laravel OAuth

Enhancing User Security in Laravel OAuth Implementations

OAuth provides a streamlined approach to user authentication, but it's crucial to implement security measures that protect user data and prevent unauthorized access. A common scenario involves social login, where users authenticate via third-party providers like GitHub or LinkedIn.

The Problem: Unregistered Users and Automatic Registration

A potential vulnerability arises when users not yet

Read more

Enhancing GitHub OAuth Flow: Preserving User Permissions

Introduction

This article discusses a common issue in applications using GitHub OAuth for authentication: inadvertently overwriting a user's existing token with one that has fewer permissions. We'll explore how to ensure the application preserves the user's original, broader-scoped token when requesting narrower scopes during subsequent logins.

The Problem

Many applications use GitHub

Read more

Improving AI Usage Tracking with Refactored Queries

Optimizing AI Token Usage Queries

We've recently refactored and optimized our AI token usage tracking to improve performance and maintainability. This involved extracting duplicated queries and enhancing user filtering.

The Changes

The primary focus was on improving the efficiency of retrieving daily and monthly tenant AI usage data. This was achieved through two key changes:

Read more

Optimizing Application Performance Through Targeted Database and Code Improvements

Introduction

Application performance is often a critical factor in user experience and overall system efficiency. This post delves into several strategies for enhancing performance, focusing on database query optimization, efficient data handling, and code-level improvements.

Database Query Optimization

Inefficient database queries can be a major bottleneck. One common issue is the N+1

Read more

Optimizing Premium Access Checks in Background Jobs

Introduction

We recently optimized a background job responsible for post-generation in our application, specifically focusing on how it handles premium access checks. Initially, the job was configured to check user-level premium access, which led to inefficiencies. This post outlines the problem, the solution, and the benefits we observed.

The Problem: Redundant User-Level Checks

Read more

The Pitfalls of Premature Optimization

Developers often strive for efficiency, but sometimes, optimizing too early can lead to more problems than solutions.

The Danger of Early Optimization

Optimizing code before understanding its performance bottlenecks can waste time and introduce unnecessary complexity. It's tempting to micro-optimize, but it's crucial to identify the actual performance-critical sections first.

Read more

Optimizing Product Ranking and Data Aggregation in SQL

Introduction

This post delves into optimizing SQL queries for product ranking and data aggregation, focusing on common pitfalls and effective strategies to enhance performance and accuracy. We'll explore techniques to address memory errors, improve query speed, and ensure data integrity when dealing with complex relationships and large datasets.

Addressing Memory Errors in Ranking

Read more