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.
You can install the package via composer:
composer require laraditz/shopeeConfigure 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>
SHOPEE_REDIRECT_URL=<your_redirect_url> # Optional β see Authorization Flow(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 migrateTo authorize a Shopee shop with your app:
- Visit Shopee Open Platform Console.
- On your App List, click
Authorizelink next to theTest/Live Partner_id. Alternatively, you can generate the authorization URL using thegenerateAuthorizationURL()method. - Make sure the domain for authorized redirect URL already been whitelisted beforehand.
- Enter
https://your-app-url/shopee/shops/authorizedas the Redirect URL and click Next. - Proceed to login using the seller account that you want to authorized to be use for the app.
- Shopee redirects back to
https://your-app-url/shopee/shops/authorized. - Package automatically handles the authorization code exchange and token storage.
- Shop is now ready for API calls.
By default, the package renders a built-in success page after authorization. To redirect to your own URL instead, set SHOPEE_REDIRECT_URL in your .env:
SHOPEE_REDIRECT_URL=https://your-app-url/shopee/callbackOn success, the package redirects to your URL with the following query parameters:
| Parameter | Description |
|---|---|
shop_id |
Shopee shop ID |
shop_name |
Shop display name |
region |
Shop region (e.g. MY, SG) |
access_token |
OAuth access token |
refresh_token |
OAuth refresh token |
expires_at |
Token expiry (ISO 8601) |
On failure (e.g. token exchange error), the redirect includes:
| Parameter | Value |
|---|---|
error |
token_failed |
shop_id |
Shopee shop ID |
Security:
SHOPEE_REDIRECT_URLmust be an exact absolute URL without query strings. Only requests carrying this exact value are honoured β any other value is silently discarded, preventing open redirect attacks. Use HTTPS in production as tokens are passed in the URL.
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.
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 |
Manages shop information and authorization processes.
| Method | Description |
|---|---|
generateAuthorizationURL() |
Generate authorization URL for shop authorization |
getShopInfo() |
Retrieve comprehensive shop information and status |
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 |
addItem() |
Create a new product listing on Shopee | Refer to Shopee API Reference |
updateItem() |
Update an existing product listing | item_id and any fields to update - refer to Shopee API Reference |
deleteItem() |
Delete a product listing | item_id |
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 |
Manages payment and financial transaction details.
| Method | Description | Parameters |
|---|---|---|
getEscrowDetail() |
Retrieve detailed escrow and payment information for orders | order_sn |
The package provides a fluent, chainable API interface. Access services by chaining the service name before calling the method.
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
);
// Add a new product
$newProduct = Shopee::product()->addItem(
item_name: 'My Product',
description: 'Product description',
original_price: 29.90,
normal_stock: 100,
weight: 0.5,
item_sku: 'SKU-001',
category_id: 100001,
// ... refer to Shopee API Reference for full parameter list
);
// Update an existing product
Shopee::product()->updateItem(
item_id: 123456789,
item_name: 'Updated Product Name',
original_price: 24.90,
);
// Delete a product
Shopee::product()->deleteItem(item_id: 123456789);
// 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
);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()
);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());
}This package provides comprehensive webhook support for real-time notifications from Shopee. Refer to Push Mecahnism documentation for more details.
Create listeners for webhook events to automatically process updates from Shopee:
| Event | Description |
|---|---|
Laraditz\Shopee\Events\WebhookReceived |
Triggered when receiving push notifications from Shopee |
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,
],
];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-tokenSince 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.
Please see CHANGELOG for more information what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email raditzfarhan@gmail.com instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.
