Skip to content

Conversation

@roncodes
Copy link
Member

No description provided.

roncodes and others added 11 commits January 9, 2026 02:13
- Add required validation for name, email, and phone fields
- Add validation for drivers_license_number and internal_id
- Add validation for photo_uuid and avatar_uuid
- Add validation for location fields (latitude, longitude)
- Add custom error messages for better UX
- Add custom attribute names for clearer validation errors
- Ensure email and phone uniqueness checks
- Add password minimum length validation (8 characters)

This fixes the issue where drivers could be created without
required fields through the internal API, and improves the
validation error messages shown to users.

Resolves issue where onboarding driver creation was failing
silently due to incomplete validation rules.
- Check if user exists before calling methods on it
- Create new user if user_uuid is provided but user doesn't exist
- Prevents 'Call to a member function companies() on null' error
- Fixes driver creation failure when invalid user_uuid is provided

This resolves the error:
Error: Call to a member function companies() on null
in DriverController.php on line 172
- Changed closure from function($input) to function()
- Use $this->input() to access request data instead
- Fixes ArgumentCountError when Rule::requiredIf evaluates closure
Issue: Users created via driver API were not being tracked in billing system
Root cause: company_uuid was set AFTER user creation via assignCompany()
Solution: Set company_uuid in userDetails BEFORE User::create()

This ensures ResourceCreatedListener can properly track the resource creation
since it requires company_uuid to log usage to billing_resource_usage table.

Without company_uuid at creation time, the listener logs a warning and exits:
'Could not determine company UUID for resource'

Now the flow is:
1. Set company_uuid in userDetails
2. User::create() fires eloquent.created event
3. ResourceCreatedListener receives event with company_uuid
4. Resource usage tracked successfully
…+ fill + save

Issue: Vehicles created via API were not being tracked in billing system
Root cause: Using new Vehicle() + fill() + save() doesn't fire 'created' event
Solution: Replace with Vehicle::create() which properly fires the event

The problem:
- new Vehicle() creates instance
- fill() populates attributes
- save() fires 'updated' event, NOT 'created' event
- ResourceCreatedListener only listens for 'created' event

The fix:
- Vehicle::create($input) fires 'created' event properly
- ResourceCreatedListener receives event with company_uuid
- Resource usage tracked successfully

This is cleaner and more idiomatic Laravel code, and ensures
billing resource tracking works correctly.
Fix: Add complete validation rules for internal driver creation
@roncodes roncodes merged commit 3743542 into main Jan 16, 2026
4 checks passed
@roncodes roncodes deleted the dev-v0.6.33 branch January 16, 2026 07:39
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