mannu24/google-merchant-center
最新稳定版本:1.0.2
Composer 安装命令:
composer require mannu24/google-merchant-center
包简介
A comprehensive Laravel package for Google Merchant Center integration with product synchronization, batch processing, and automatic sync management.
关键字:
README 文档
README
A comprehensive Laravel package for seamless Google Merchant Center product synchronization with independent tables, batch processing, and automatic sync management.
Features
- 🚀 Product Synchronization - Sync products with Google Merchant Center
- 📦 Batch Processing - Handle large datasets efficiently
- 🔄 Automatic Sync - Set up automated synchronization workflows
- 🎯 Per-Product Control - Enable/disable sync for individual products
- 📊 Sync Logging - Comprehensive tracking and monitoring
- 🛡️ Error Handling - Robust retry logic and error management
- ⚡ Performance Optimized - Rate limiting and caching
- 🔧 Laravel Integration - Seamless Laravel ecosystem integration
Requirements
- PHP 8.0 or higher
- Laravel 8.x, 9.x, 10.x, 11.x, or 12.x
- Google Merchant Center account
- Google API credentials
Installation
composer require mannu24/google-merchant-center
Quick Setup
- Publish configuration:
php artisan vendor:publish --tag=gmc-config
- Publish migrations:
php artisan vendor:publish --tag=gmc-migrations
- Run migrations:
php artisan migrate
- Configure environment variables:
GMC_MERCHANT_ID=your_merchant_id GMC_SERVICE_ACCOUNT_JSON=/path/to/service-account.json GMC_AUTO_SYNC=true GMC_BATCH_SIZE=50 GMC_RETRY_ATTEMPTS=3
Basic Usage
1. Add Trait to Your Product Model
use Mannu24\GoogleMerchantCenter\Traits\SyncsWithGMC; class Product extends Model { use SyncsWithGMC; protected $fillable = [ 'title', 'description', 'price', 'quantity', 'image_url', 'brand', 'sku', 'status' ]; public function prepareGMCData(): array { return [ 'offerId' => $this->sku ?: (string) $this->id, 'title' => $this->title, 'description' => $this->description, 'link' => url("/products/{$this->id}"), 'imageLink' => $this->image_url, 'price' => ['value' => (string) $this->price, 'currency' => 'USD'], 'availability' => $this->quantity > 0 ? 'in stock' : 'out of stock', 'brand' => $this->brand, 'condition' => 'new' ]; } }
2. Sync Products
// Manual sync $product->syncToGMC(); // Force sync (ignores cache) $product->forceSyncToGMC(); // Check sync status if ($product->isSyncedWithGMC()) { echo "Product is synced!"; }
3. Bulk Operations
use Mannu24\GoogleMerchantCenter\Services\GMCService; $gmcService = app(GMCService::class); $result = $gmcService->syncMultipleProducts($products, 25);
4. Artisan Commands
# Sync all products php artisan gmc:sync-all # Sync with filters php artisan gmc:sync-all --filter="status=active" # Dry run (no actual sync) php artisan gmc:sync-all --dry-run # Force sync (ignore cache) php artisan gmc:sync-all --force
Database Structure
gmc_products Table
product_id- Reference to your productproduct_type- Model class namesync_enabled- Control sync per productgmc_product_id- GMC's product IDgmc_last_sync- Last sync timestampsync_status- Current sync statuslast_error- Last error message
gmc_sync_logs Table
- Tracks all sync attempts
- Stores request/response data
- Performance metrics
- Error details
Advanced Features
Batch Processing
$gmcService = app(GMCService::class); $gmcService->setBatchSize(25); $result = $gmcService->syncMultipleProducts($products);
Error Handling
try { $product->syncToGMC(); } catch (\Exception $e) { Log::error('GMC Sync failed: ' . $e->getMessage()); }
Sync History
use Mannu24\GoogleMerchantCenter\Models\GMCSyncLog; $logs = GMCSyncLog::with('gmcProduct')->latest()->get(); $failedLogs = GMCSyncLog::where('status', 'failed')->get();
Configuration
The package configuration file (config/gmc.php) includes:
- API credentials and endpoints
- Batch processing settings
- Retry and timeout configurations
- Logging preferences
- Cache settings
Testing
composer test
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
This package is open-sourced software licensed under the MIT license.
Support
统计信息
- 总下载量: 1
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-08-22