Skip to content

Laravel package for efficient synchronization between your models and Google Sheets with advanced state tracking and error handling.

Notifications You must be signed in to change notification settings

ultra-bugs/syncro-sheet

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

10 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

WIP

This package is not avail on packagist yet. If you interesting, take a local clone or zip download then try it out.

SyncroSheet

Laravel package for efficient synchronization between your models and Google Sheets with advanced state tracking and error handling.

Features

  • πŸ”„ Sync from Laravel models to Google Sheets. Bidirectional sync is planned to implement
  • πŸ“¦ Batch processing with memory efficiency
  • 🎯 Support for both full and partial syncs
  • πŸ’Ύ Sophisticated state tracking and resume capability
  • πŸ” Automatic retry mechanism with exponential backoff
  • πŸ“Š Detailed sync history and progress tracking
  • 🚨 Comprehensive notification system
  • πŸ”‘ Smart token management for Google API

Requirements

  • PHP >= 8.1
  • Laravel >= 10
  • Google API accessible

Installation

composer require zuko/syncro-sheet

Publish the configuration and migrations:

php artisan vendor:publish --provider="Zuko\SyncroSheet\LaravelSyncroSheetProvider"
php artisan migrate

Configuration

Google Sheets Setup

  1. Create a Google Cloud Project
  2. Enable Google Sheets API
  3. Create credentials (OAuth 2.0 or Service Account)
  4. Set up your .env file:
GOOGLE_SHEETS_CLIENT_ID=your-client-id
GOOGLE_SHEETS_CLIENT_SECRET=your-client-secret
GOOGLE_SHEETS_REDIRECT_URI=your-redirect-uri

Or using service account:

GOOGLE_DEVELOPER_KEY=your-service-account-key
GOOGLE_SERVICE_ENABLED=true

As a wrapped around revolution/laravel-google-sheets. these env vars is taken from config/google.php

If you already set these authorization values. You can leave env untouched.

Package Configuration

// config/syncro-sheet.php

return [
    'defaults' => [
        'batch_size' => 1000,
        'timeout' => 600,
        'retries' => 3
    ],
    // ... other configurations
];

Basic Usage

1. Make Your Model Sync-able

use Zuko\SyncroSheet\Contracts\SheetSyncable;

class Product extends Model implements SheetSyncable
{
    public function getSheetIdentifier(): string
    {
        return '1234567890-your-google-sheet-id';
    }

    public function getSheetName(): string
    {
        return 'Products';
    }

    public function toSheetRow(): array
    {
        return [
            $this->id,
            $this->name,
            $this->price,
            $this->stock,
            $this->updated_at->format('Y-m-d H:i:s')
        ];
    }

    public function getBatchSize(): ?int
    {
        return 500; // Optional, defaults to config value
    }
}

2. Run Sync Operations

use Zuko\SyncroSheet\Services\SyncManager;

// Full sync
$syncManager = app(SyncManager::class);
$syncState = $syncManager->fullSync(Product::class);

// Partial sync
$syncState = $syncManager->partialSync(Product::class, [1, 2, 3]);

Or using facade static call

use SyncroSheet;
// or
use Zuko\SyncroSheet\Facades\SyncroSheet;

// Full sync
$syncState = SyncroSheet::fullSync(Product::class);

// Partial sync
$syncState = SyncroSheet::partialSync(Product::class, [1, 2, 3]);

// Get last sync state
$lastSync = SyncroSheet::getLastSync(Product::class);

3. Artisan Commands

# Full sync
php artisan sheet:sync Product

# Partial sync
php artisan sheet:sync Product --ids=1,2,3

Advanced Usage

1. Custom Data Transformation

use Zuko\SyncroSheet\Services\DataTransformer;

class ProductTransformer extends DataTransformer
{
    protected function transformRecord(SheetSyncable $record): array
    {
        return [
            'ID' => $record->id,
            'Product Name' => $record->name,
            'Price' => number_format($record->price, 2),
            'In Stock' => $record->stock > 0 ? 'Yes' : 'No',
            'Last Updated' => $record->updated_at->format('Y-m-d H:i:s')
        ];
    }
}

2. Event Listeners

use Zuko\SyncroSheet\Events\SyncEvent;

Event::listen(SyncEvent::SYNC_STARTED, function ($syncState) {
    Log::info("Sync started for {$syncState->model_class}");
});

Event::listen(SyncEvent::SYNC_COMPLETED, function ($syncState) {
    Log::info("Sync completed: {$syncState->total_processed} records");
});

3. Custom Notifications

use Zuko\SyncroSheet\Notifications\BaseNotification;

class CustomSyncNotification extends BaseNotification
{
    protected function getMailMessage(): MailMessage
    {
        return (new MailMessage)
            ->subject('Custom Sync Notification')
            ->line('Your custom notification logic here');
    }

    protected function getSlackMessage(): SlackMessage
    {
        return (new SlackMessage)
            ->content('Custom Slack notification');
    }
}

4. State Management

use Zuko\SyncroSheet\Services\StateManager;

$stateManager = app(StateManager::class);

// Get last successful sync
$lastSync = $stateManager->getLastSuccessfulSync(Product::class);

// Get sync history
$syncHistory = \Zuko\SyncroSheet\Models\SyncState::where('model_class', Product::class)
    ->with('entries')
    ->latest()
    ->get();

5. Error Handling

use Zuko\SyncroSheet\Services\ErrorHandler;

try {
    $syncManager->fullSync(Product::class);
} catch (GoogleSheetsException $e) {
    // Handle Google Sheets specific errors
} catch (SyncException $e) {
    // Handle general sync errors
}

Best Practices

  1. Batch Size: Adjust based on your model's complexity and memory constraints
public function getBatchSize(): int
{
    return $this->hasMedia() ? 100 : 1000;
}
  1. Rate Limiting: Configure based on your Google Sheets API quotas
// config/syncro-sheet.php
'sheets' => [
    'rate_limit' => [
        'max_requests' => 100,
        'per_seconds' => 60
    ]
]
  1. Error Handling: Implement custom notification channels
use Zuko\SyncroSheet\Notifications\SyncFailedNotification;

class SlackSyncNotifier extends Notification
{
    public function toSlack($notifiable)
    {
        // Custom Slack notification logic
    }
}

Contributing

Please see CONTRIBUTING.md for details.

License

The MIT License (MIT). Please see License File for more information.

About

Laravel package for efficient synchronization between your models and Google Sheets with advanced state tracking and error handling.

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages