diff --git a/readme.md b/readme.md index e9952ce..9c52b0c 100644 --- a/readme.md +++ b/readme.md @@ -210,7 +210,7 @@ echo $status = $sender->send(); | OnnoRokomSMS | userName, userPassword, type, maskName, campaignName | - | Done | not tested yet in live | - | | QuickSms | api_key, senderid, type,scheduledDateTime | - | Done | not tested yet in live | - | | RedmoITSms | api_token, sender_id | - | Support closed | - | -| RedmoITSms | api_token, sender_id | - | Support closed | - | +| SendMySms | user, closed | - | Done | tested in live | | SmartLabSMS | user, password, sender | - | Done | - | - | | Sms4BD | publickey, privatekey, type,sender, delay | - | Done | - | - | | SmsBangladesh | user, password, from | - | Done | - | - | diff --git a/src/Config/sms.php b/src/Config/sms.php index 41d87e8..84848bf 100644 --- a/src/Config/sms.php +++ b/src/Config/sms.php @@ -44,6 +44,7 @@ use Xenon\LaravelBDSms\Provider\Onnorokom; use Xenon\LaravelBDSms\Provider\QuickSms; use Xenon\LaravelBDSms\Provider\RedmoItSms; +use Xenon\LaravelBDSms\Provider\SendMySms; use Xenon\LaravelBDSms\Provider\SmartLabSms; use Xenon\LaravelBDSms\Provider\Sms4BD; use Xenon\LaravelBDSms\Provider\SmsBangladesh; @@ -236,6 +237,10 @@ 'api_token' => env('SMS_REDMOIT_API_TOKEN', ''), 'type' => env('SMS_REDMOIT_TYPE', 'string'), ], + SendMySms::class => [ + 'user' => env('SMS_SENDMYSMS_USER', ''), + 'key' => env('SMS_SENDMYSMS_PASSWORD', ''), + ], SmartLabSms::class => [ 'user' => env('SMS_SMARTLAB_USER', ''), 'password' => env('SMS_SMARTLAB_PASSWORD', ''), diff --git a/src/Provider/SendMySms.php b/src/Provider/SendMySms.php new file mode 100644 index 0000000..daf1419 --- /dev/null +++ b/src/Provider/SendMySms.php @@ -0,0 +1,84 @@ +senderObject = $sender; + } + + /** + * Send Request To Api and Send Message + * @throws RenderException + */ + public function sendRequest() + { + $number = $this->senderObject->getMobile(); + $text = $this->senderObject->getMessage(); + $config = $this->senderObject->getConfig(); + $queue = $this->senderObject->getQueue(); + $queueName = $this->senderObject->getQueueName(); + $tries = $this->senderObject->getTries(); + $backoff = $this->senderObject->getBackoff(); + + $query = [ + 'user' => $config['user'], + 'key' => $config['key'], + 'to' => $number, + 'msg' => $text, + ]; + + $requestObject = new Request($this->apiEndpoint, $query, $queue, [], $queueName, $tries, $backoff); + $requestObject->setFormParams($query); + $response = $requestObject->post(); + if ($queue) { + return true; + } + + $body = $response->getBody(); + $smsResult = $body->getContents(); + + $data['number'] = $number; + $data['message'] = $text; + return $this->generateReport($smsResult, $data)->getContent(); + } + + /** + * @throws ParameterException + */ + public function errorException() + { + if (!array_key_exists('user', $this->senderObject->getConfig())) { + throw new ParameterException('user key is absent in configuration'); + } + if (!array_key_exists('key', $this->senderObject->getConfig())) { + throw new ParameterException('key is absent in configuration'); + } + + } +}