tapp / laravel-hubspot
This is my package laravel-hubspot
Fund package maintenance!
TappNetwork
Installs: 2 103
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 4
Forks: 0
Open Issues: 0
Requires
- php: ^8.2
- hubspot/api-client: ^13.0
- illuminate/contracts: ^10.0||^11.0||^12.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^3.6||^2.10
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^10.0||^9.0||^8.22.0
- pestphp/pest: ^3.0||^2.34
- pestphp/pest-plugin-arch: ^3.0||^2.7
- pestphp/pest-plugin-laravel: ^3.0||^2.3
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^2.0||^1.1
- phpstan/phpstan-phpunit: ^2.0||^1.3
- spatie/laravel-ray: ^1.35
- dev-main
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.15
- v1.0.14
- v1.0.13
- v1.0.12
- v1.0.11
- v1.0.10
- v1.0.9
- v1.0.8
- v1.0.7
- v1.0.6
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- dev-queue
- dev-queue-simple
- dev-dependabot/github_actions/actions/checkout-5
- dev-company-sync-updates
- dev-sync-updates
- dev-add-hubspot-id-to-config
- dev-hubspotUpdateMap
- dev-Update-Property-Sync
- dev-fix-naming
- dev-update-readme
- dev-log-exceptions
- dev-CU-868c4xdrv-500error
- dev-hubspot-company
- dev-HubspotCompany
- dev-dont-bind-if-disabled
This package is auto-updated.
Last update: 2025-08-26 17:07:07 UTC
README
A Laravel package for seamless integration with HubSpot CRM. Provides automatic synchronization of Laravel models with HubSpot contacts and companies, with support for queued operations.
Installation
composer require tapp/laravel-hubspot php artisan vendor:publish --tag="laravel-hubspot-config" php artisan vendor:publish --tag="hubspot-migrations" php artisan migrate
Configuration
Add your HubSpot API key to your .env
file:
HUBSPOT_ID=your_hubspot_id HUBSPOT_TOKEN=your_api_key HUBSPOT_DISABLED=false HUBSPOT_LOG_REQUESTS=false HUBSPOT_PROPERTY_GROUP=app_user_profile HUBSPOT_PROPERTY_GROUP_LABEL=App User Profile
Usage
User Model Setup
Add the trait to your User model and define the HubSpot property mapping:
use Tapp\LaravelHubspot\Models\HubspotContact; class User extends Authenticatable { use HubspotContact; public array $hubspotMap = [ 'email' => 'email', 'first_name' => 'first_name', 'last_name' => 'last_name', 'user_type' => 'type.name', // Supports dot notation for relations ]; }
Dynamic Properties
Override the hubspotProperties
method for computed values:
public function hubspotProperties(array $map): array { $properties = parent::hubspotProperties($map); // Add computed properties $properties['full_name'] = $this->first_name . ' ' . $this->last_name; return $properties; }
Observers (Recommended)
Register observers in your AppServiceProvider
for better separation of concerns:
use App\Models\User; use App\Models\Company; use Tapp\LaravelHubspot\Observers\HubspotContactObserver; use Tapp\LaravelHubspot\Observers\HubspotCompanyObserver; public function boot(): void { User::observe(HubspotContactObserver::class); Company::observe(HubspotCompanyObserver::class); }
Sync Properties
Create the property group and properties in HubSpot:
php artisan hubspot:sync-properties
Queuing
The package supports queued operations for better performance. Configure in your .env
:
HUBSPOT_QUEUE_ENABLED=true HUBSPOT_QUEUE_CONNECTION=default HUBSPOT_QUEUE_NAME=hubspot HUBSPOT_QUEUE_RETRY_ATTEMPTS=3 HUBSPOT_QUEUE_RETRY_DELAY=60
Run queue workers:
php artisan queue:work --queue=hubspot
Testing
Quick Start
# Run all tests composer test # Run only unit tests (fast, no API calls) composer test-unit # Run only integration tests (requires HubSpot API key) composer test-integration # Run with coverage report composer test-coverage
Setup Integration Tests
- Create
.env.testing
:
HUBSPOT_TEST_API_KEY=your_test_api_key_here HUBSPOT_DISABLED=false HUBSPOT_LOG_REQUESTS=true HUBSPOT_USE_REAL_API=false HUBSPOT_PROPERTY_GROUP=test_property_group HUBSPOT_QUEUE_ENABLED=false
-
Get HubSpot test API key with scopes:
crm.objects.contacts.read
crm.objects.contacts.write
crm.objects.companies.read
crm.objects.companies.write
-
Sync test properties:
export HUBSPOT_TEST_API_KEY=your_test_api_key_here
php artisan hubspot:sync-properties
Flexible Testing
Switch between mocked and real API calls:
# Run with mocks (fast, no API calls) HUBSPOT_USE_REAL_API=false composer test # Run with real API calls (requires API key) HUBSPOT_USE_REAL_API=true composer test
Testing in Consuming Projects
- Quick Start Guide - Fast testing checklist
- Comprehensive Testing Guide - Detailed testing strategy
Quick Testing Steps
- Clean test account:
php scripts/clean-hubspot-test-account.php
- Configure your app: Add traits to models and configure HubSpot settings
- Sync properties:
php artisan hubspot:sync-properties
- Test sync commands:
php artisan hubspot:sync-contacts App\Models\User
- Test user registration: Create users/companies and verify in HubSpot dashboard
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
- [TappNetwork](https://github.com/Scott Grayson)
- All Contributors
License
The MIT License (MIT). Please see License File for more information.