snappmarket / smnotif-php-bridge
A client package to use snappmarket notifier service.
Installs: 1 537
Dependents: 0
Suggesters: 0
Security: 0
Stars: 9
Watchers: 3
Forks: 5
Open Issues: 2
Requires
- php: ^7.2|^8.0
- ext-json: *
- guzzlehttp/guzzle: ^7.0.1
- dev-master
- 3.1.2
- 3.1.1
- 3.1.0
- 3.0.2
- 3.0.1
- 3.0.0
- 2.x-dev
- 2.0.7
- 2.0.6
- 2.0.5
- 2.0.4
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- 0.1.1
- 0.1.0
- dev-dependabot/composer/guzzlehttp/psr7-2.5.0
- dev-symfony
- dev-dependabot/composer/guzzlehttp/guzzle-7.4.5
- dev-feature/upgrading-guzzle
- dev-feature/php8-support
This package is auto-updated.
Last update: 2024-12-17 15:34:31 UTC
README
SnappMarket Notification Service PHP Bridge
This package developed to use SnappMarket Notification Service.
To see full documentation check:
- TEST : TEST Documentations
- STAGING : STAGING Documentations
- PRODUCTION : PRODUCTION Documentations
(note : Don't forget to set Swagger-Token as request header. Value of Swagger-Token is the api key you can get it from Snappmarket Notifier Service)
Requirements
PHP >= 7.2.0
JSON PHP Extension
installation
require package inside your composer.json
file.
$ composer require snappmarket/smnotif-php-bridge
Basic Usage To Send SMS Notification
You can use it inside a raw php file or project or a php framework like Laravel or Symfony.
The NotifierApi
class takes four parameters.
$api_key
: The Api Key that your get from Notifier Service.$api_version
: The api version that you are using ex:1$is_secure
: if true call service with 'https' else calls with 'http'.$app_env
: The application environment that you are using (includingNotifierApi::PRODUCTION
,NotifierApi::STAGE
,NotifierApi::TEST
)
1- raw php file
<?php require __DIR__ . '/vendor/autoload.php'; try { $api_token = "Your API Token"; $api_version = 1; $is_secure = true; $app_env = \Notifier\NotifierApi::PRODUCTION; $notifier = new \Notifier\NotifierApi($api_token,$api_version,$is_secure,$app_env); $sms_notifier = $notifier->setType(\Notifier\NotifierApi::SMS); $response = $sms_notifier->setBypassLimitControl(1) // to bypass time limit control (like activation codes) ->setExpireTime('1h 15m') // expires in 1 hour and 15 minutes ->setMode(\Notifier\NotifierApi::ASYNC_MODE) // send notification async or sync ->setPriority(\Notifier\NotifierApi::BLOCKER_PRIORITY) // priority : blocker, high, medium, low ->setProviderCode('10002') // get sms provider codes from notification service ->setSmsBodyStructure(\Notifier\NotifierApi::DYNAMIC_STRUCTURE) // static or dynamic? ->setSmsBody('Hello {{name}}. Your discount is {{discount}}!!') // sms body (you can also use sms templates) ->setReceivers([ [ 'number' => "0939*******", 'sms_template_data' => [ 'name' => 'Alireza Jangi', 'discount' => 45 ] ], [ 'number' => "0937*******", 'sms_template_data' => [ 'name' => 'Another Name', 'discount' => 77 ] ] ]) ->send(); } catch (Exception $e) { throw $e; } ?>
2- inside php class
use Notifier\NotifierApi; try { $api_token = "Your API Token"; $api_version = 1; $is_secure = true; $app_env = NotifierApi::PRODUCTION; $notifier = new NotifierApi($api_token,$api_version,$is_secure,$app_env); $sms_notifier = $notifier->setType(\Notifier\NotifierApi::SMS); $response = $sms_notifier->setBypassLimitControl(1) // to bypass time limit control (like activation codes) ->setExpireTime('1h 15m') // expires in 1 hour and 15 minutes ->setMode(NotifierApi::ASYNC_MODE) // send notification async or sync ->setPriority(NotifierApi::BLOCKER_PRIORITY) // priority : blocker, high, medium, low ->setProviderCode('10002') // get sms provider codes from notification service ->setSmsBodyStructure(NotifierApi::DYNAMIC_STRUCTURE) // static or dynamic? ->setSmsBody('Hello {{name}}. Your discount is {{discount}}!!') // sms body (you can also use sms templates) ->setReceivers([ [ 'number' => "0939*******", 'sms_template_data' => [ 'name' => 'Alireza Jangi', 'discount' => 45 ] ], [ 'number' => "0937*******", 'sms_template_data' => [ 'name' => 'Another Name', 'discount' => 77 ] ] ]) ->send(); } catch (Exception $e) { throw $e; }
Basic Usage To Send PUSH Notification
You can use it inside a raw php file or project or a php framework like Laravel or Symfony.
The NotifierApi
class takes four parameters.
$api_key
: The Api Key that your get from Notifier Service.$api_version
: The api version that you are using ex:1$is_secure
: if true call service with 'https' else calls with 'http'.$app_env
: The application environment that you are using (includingNotifierApi::PRODUCTION
,NotifierApi::STAGE
,NotifierApi::TEST
)
// Static Push Notification try { $api_token = "5df0d20cd6b9c5df0d20cd6ba3"; $api_version = 1; $is_secure = true; $app_env = NotifierApi::TEST; $notifier = new NotifierApi($api_token,$api_version,$is_secure,$app_env); $push_notifier = $notifier->setType(\Notifier\NotifierApi::PUSH); $response = $push_notifier->setBypassLimitControl(1) // to bypass time limit control (like activation codes) ->setExpireTime('10m') // expires in 10 minutes ->setMode(NotifierApi::ASYNC_MODE) // send notification async or sync ->setReceivers(["3502960","4727193"]) // Receivers for static push notification are user IDs ->setPriority(NotifierApi::BLOCKER_PRIORITY) // priority : blocker, high, medium, low ->setProviderCode('20001') // get push provider codes from notification service ->setBodyStructure(NotifierApi::STATIC_STRUCTURE) // you set it to static in this type ->setTitle('This is a test ') // push title ->setBody('This is a test message without any variables!!') // push body ->setMessagePageTitle("") // This is the message title you want to save in user phone ->setMessagePageBody("") // This is the message body you want to save in user phone ->setImage("https://m.snapp.market/logo.png") // set push notification image ->setBanner("https://m.snapp.market/logo.png") // set push notification banner ->setSound("default") // set push notification sound ->setModalText("Some text for modal") // if you set it a modal will be open in application ->setDeepLink("") // set Deep Link ->setWebView("") // set Web View ->setWebLink("") // set Web Link ->send(); die($response); } catch (Exception $e) { throw $e; } // Dynamic Push Notification try { $api_token = "5df0d20cd6b9c5df0d20cd6ba3"; $api_version = 1; $is_secure = true; $app_env = NotifierApi::TEST; $notifier = new NotifierApi($api_token,$api_version,$is_secure,$app_env); $push_notifier = $notifier->setType(\Notifier\NotifierApi::PUSH); $response = $push_notifier->setBypassLimitControl(1) // to bypass time limit control (like activation codes) ->setExpireTime('10m') // expires in 10 minutes ->setMode(NotifierApi::ASYNC_MODE) // send notification async or sync ->setReceivers([ [ 'user_id' => "********", 'push_template_data' => [ 'first_name' => 'Alireza', 'last_name' => "jangi", 'code' => "3434" ] ], [ 'number' => "*******", 'push_template_data' => [ 'first_name' => 'Another Name', 'last_name' => 'Another Name', 'code' => '9833' ] ] ]) // Receivers for static push notification are user IDs ->setPriority(NotifierApi::BLOCKER_PRIORITY) // priority : blocker, high, medium, low ->setProviderCode('20001') // get push provider codes from notification service ->setBodyStructure(NotifierApi::DYNAMIC_STRUCTURE) // you set it to static in this type ->setTitle('Hello {{first_name}} {{last_name}}') // push title ->setBody('Welcome! This is your code : {{code}} ') // push body ->setMessagePageTitle("") // This is the message title you want to save in user phone ->setMessagePageBody("") // This is the message body you want to save in user phone ->setImage("https://m.snapp.market/logo.png") // set push notification image ->setBanner("https://m.snapp.market/logo.png") // set push notification banner ->setSound("default") // set push notification sound ->setModalText("Some text for modal") // if you set it a modal will be open in application ->setDeepLink("") // set Deep Link ->setWebView("") // set Web View ->setWebLink("") // set Web Link ->send(); die($response); } catch (Exception $e) { throw $e; }
Examples
- To register a new sms template check Sms Template Examples
- More examples to send sms notifications Send Sms Notifications Examples