laraditz / shopee
A simple laravel package for Shopee
Requires
- php: ^8.1
- illuminate/database: ^10.0|^11.0|^12.0
- illuminate/support: ^10.0|^11.0|^12.0
Requires (Dev)
- orchestra/testbench: ^8.0|^9.0|^10.0
- phpunit/phpunit: ^10.0|^11.0
This package is auto-updated.
Last update: 2025-09-11 09:16:37 UTC
README
A comprehensive Laravel package for seamlessly integrating with the Shopee Open Platform API. This package provides an elegant, fluent interface for managing shops, products, orders, and payments on Shopee's marketplace.
Installation
You can install the package via composer:
composer require laraditz/shopee
Before Starting
Configure your Shopee API credentials in your .env
file (recommended) or publish and modify the config file.
SHOPEE_SANDBOX_MODE=true # Set to false for production SHOPEE_PARTNER_ID=<your_shopee_partner_id> SHOPEE_PARTNER_KEY=<your_shopee_partner_key> SHOPEE_SHOP_ID=<your_shopee_shop_id>
(Optional) You can publish the config file via this command:
php artisan vendor:publish --provider="Laraditz\Shopee\ShopeeServiceProvider" --tag="config"
Run the migration command to create the necessary database tables for storing shop data, access tokens, and API request logs.
php artisan migrate
Available Services & Methods
Below is a list of all available methods in this SDK. For detailed usage, please refer to the Developerโs Guide and the API Reference. This package organizes Shopee API endpoints into logical services. Each method name corresponds to its respective API endpoint (converted from snake_case
โ camelCase
), and all parameters follow the exact definitions provided in the API reference.
Note: All method parameters must be passed as named arguments, not positional arguments.
๐ Authorization and Authentication Service auth()
Handles OAuth 2.0 authentication flow and token management.
Method | Description | Parameters |
---|---|---|
accessToken() |
Generate access token from authorization code | entity_id , EntityType entity_type |
refreshToken() |
Refresh access token before expiration (4 hours) | ShopeeAccessToken shopeeAccessToken |
๐ช Shop Service shop()
Manages shop information and authorization processes.
Method | Description |
---|---|
generateAuthorizationURL() |
Generate authorization URL for shop authorization |
getShopInfo() |
Retrieve comprehensive shop information and status |
๐ฆ Product Service product()
Comprehensive product and inventory management capabilities.
Method | Description | Parameters |
---|---|---|
getItemList() |
Retrieve paginated list of shop items with filters | offset , page_size , item_status , update_time_from , update_time_to |
getItemBaseInfo() |
Get basic product information including pricing and status | item_id_list , need_tax_info , need_complaint_policy |
getItemExtraInfo() |
Get extended product details like dimensions and attributes | item_id_list |
getModelList() |
Retrieve all variants/models for a specific product | item_id |
searchItem() |
Search products by name, SKU, or status with pagination | item_name , item_sku , item_status , offset , page_size and more |
updateStock() |
Update inventory levels for product variants in bulk | item_id , stock_list |
๐ Order Service order()
Handles order management and retrieval with detailed tracking information.
Method | Description | Parameters |
---|---|---|
getOrderList() |
Retrieve paginated orders within specified date range | time_range_field , time_from , time_to , page_size , cursor and more |
getOrderDetail() |
Get comprehensive order details by order serial number | order_sn_list , request_order_status_pending , response_optional_fields |
๐ฐ Payment Service payment()
Manages payment and financial transaction details.
Method | Description | Parameters |
---|---|---|
getEscrowDetail() |
Retrieve detailed escrow and payment information for orders | order_sn |
Usage Examples
The package provides a fluent, chainable API interface. Access services by chaining the service name before calling the method.
Basic Usage
use Laraditz\Shopee\Facades\Shopee; // Get order details $orderDetails = Shopee::order()->getOrderDetail( order_sn_list: '211020BNFYMXXX,211020BNFYXXX2' ); // Get shop information $shopInfo = Shopee::shop()->getShopInfo(); // Search products $products = Shopee::product()->searchItem( item_name: 'smartphone', page_size: 20, offset: 0 ); // Alternative: using service container $orders = app('shopee')->order()->getOrderList( time_range_field: 'create_time', time_from: strtotime('-30 days'), time_to: time(), page_size: 50 );
Multi-Shop Support
By default, the package uses SHOPEE_SHOP_ID
from your .env
file. For multi-shop applications, specify the shop ID per request:
use Laraditz\Shopee\Facades\Shopee; // Method 1: Using make() with shop_id $products = Shopee::make(shop_id: '2257XXXXX') ->product() ->getItemList( offset: 0, page_size: 10, item_status: 'NORMAL' ); // Method 2: Using shopId() method $orders = Shopee::shopId('2257XXXXX') ->order() ->getOrderList( time_range_field: 'create_time', time_from: strtotime('-7 days'), time_to: time() );
Error Handling
use Laraditz\Shopee\Facades\Shopee; use Illuminate\Http\Client\RequestException; try { $result = Shopee::product()->updateStock( item_id: 123456789, stock_list: [ [ 'model_id' => 123123123, 'seller_stock' => [ [ 'location_id' => 'MYZ', 'stock' => 100, ] ], ] ] ); } catch (RequestException $e) { // Handle HTTP/network errors logger()->error('Request failed: ' . $e->getMessage()); }
Webhook Integration
This package provides comprehensive webhook support for real-time notifications from Shopee. Refer to Push Mecahnism documentation for more details.
Event Handling
Create listeners for webhook events to automatically process updates from Shopee:
Event | Description |
---|---|
Laraditz\Shopee\Events\WebhookReceived |
Triggered when receiving push notifications from Shopee |
Setting Up Webhooks
Configure Webhook URL: In your Shopee Open Platform dashboard, set the webhook URL to:
https://your-app-url/shopee/webhooks
Create Event Listeners to Handle Webhook Data: Create a listener to process incoming data:
<?php namespace App\Listeners; use Laraditz\Shopee\Events\WebhookReceived; class YourWebhookListener { public function handle(WebhookReceived $event) { $webhookData = $event->data; // Process order updates, product changes, etc. if ($webhookData['event'] === 'order_status_update') { // Handle order status changes } } }
Register Event Listeners: Register listeners in your EventServiceProvider
(Laravel 10 and below):
use Laraditz\Shopee\Events\WebhookReceived; protected $listen = [ WebhookReceived::class => [ YourWebhookListener::class, ], ];
Artisan Commands
The package provides convenient Artisan commands for token management:
# Remove expired access tokens from database php artisan shopee:flush-expired-token # Refresh existing access tokens before expiration php artisan shopee:refresh-token
Automated Token Refresh
Since Shopee access tokens expire every 4 hours, it's recommended to schedule the refresh command to run automatically. Add this to your app/Console/Kernel.php
:
protected function schedule(Schedule $schedule) { // Refresh tokens every 3 hours to prevent expiration $schedule->command('shopee:refresh-token') ->everyThreeHours() ->withoutOverlapping(); // Clean up expired tokens daily $schedule->command('shopee:flush-expired-token') ->daily(); }
Important: Without automatic refresh, expired tokens will require shop reauthorization and manual token generation.
Changelog
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email raditzfarhan@gmail.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.