mannu24/gmc-integration 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

mannu24/gmc-integration

最新稳定版本:v1.1.1

Composer 安装命令:

composer require mannu24/gmc-integration

包简介

A comprehensive Laravel package for Google Merchant Center integration with product synchronization, batch processing, and automatic sync management.

README 文档

README

A Laravel package for seamless Google Merchant Center product synchronization with independent tables and optional per-product sync control.

Installation

composer require manu/gmc-integration

Setup

  1. Publish config:
php artisan vendor:publish --tag=gmc-config
  1. Publish migrations:
php artisan vendor:publish --tag=gmc-migrations
  1. Run migrations:
php artisan migrate
  1. Set environment variables:
GMC_MERCHANT_ID=your_merchant_id
GMC_SERVICE_ACCOUNT_JSON=/path/to/service-account.json
GMC_AUTO_SYNC=true
GMC_THROW_EXCEPTIONS=false
GMC_BATCH_SIZE=50
GMC_RETRY_ATTEMPTS=3
  1. Add trait to your product model:
use Manu\GMCIntegration\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'
        ];
    }
}

Database Structure

gmc_products Table

  • product_id - Reference to your product
  • product_type - Model class name
  • sync_enabled - Control sync per product
  • gmc_product_id - GMC's product ID
  • gmc_last_sync - Last sync timestamp
  • sync_status - Current sync status
  • last_error - Last error message

gmc_sync_logs Table

  • Tracks all sync attempts
  • Stores request/response data
  • Performance metrics
  • Error details

Features

  • Independent tables - No modifications to existing tables
  • Clean model - All GMC methods in trait
  • Optional per-product sync control
  • Manual and automatic syncing
  • Bulk operations with batch processing
  • Error handling with retry logic
  • Data validation before syncing
  • Rate limiting to avoid API limits
  • Cache protection against duplicate syncs
  • Async processing for better performance
  • Sync history tracking

Usage Examples

Manual Syncing

$product->syncwithgmc();
$product->syncToGMC();
$product->forceSyncToGMC();

Bulk Operations

$gmcService = app(GMCService::class);
$result = $gmcService->syncMultipleProducts($products, 25);

Sync Status

$status = $product->getGMCSyncStatus();
if ($product->isSyncedWithGMC()) {
    echo "Product is synced with GMC";
}

Artisan Commands

php artisan gmc:sync-all
php artisan gmc:sync-all --filter="status=active"
php artisan gmc:sync-all --dry-run
php artisan gmc:sync-all --force
php artisan gmc:sync-all --chunk=25

Configuration

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
GMC_RETRY_DELAY=1000
GMC_CACHE_DUPLICATE_SYNCS=true
GMC_CACHE_DURATION=300
GMC_LOG_SYNC_EVENTS=true
GMC_LOG_LEVEL=info

Advanced Features

Batch Processing

$gmcService = app(GMCService::class);
$gmcService->setBatchSize(25);
$result = $gmcService->syncMultipleProducts($products);

Error Handling

try {
    $product->syncwithgmc();
} catch (\Exception $e) {
    Log::error('GMC Sync failed: ' . $e->getMessage());
}

Sync History

use Manu\GMCIntegration\Models\GMCSyncLog;

$logs = GMCSyncLog::with('gmcProduct')->latest()->get();
$failedLogs = GMCSyncLog::where('status', 'failed')->get();
$avgResponseTime = GMCSyncLog::where('status', 'success')->avg('response_time_ms');

Performance Optimizations

  • Batch processing for large datasets
  • Rate limiting to avoid API throttling
  • Cache protection against duplicate syncs
  • Async processing for better response times
  • Retry logic for failed operations
  • Memory efficient chunking
  • Independent tables for better performance

统计信息

  • 总下载量: 9
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-07-19