Skip to content

Commit

Permalink
RedmoSmsIT integrated
Browse files Browse the repository at this point in the history
  • Loading branch information
Ariful Islam committed Nov 29, 2022
1 parent fb12533 commit a517329
Show file tree
Hide file tree
Showing 3 changed files with 88 additions and 0 deletions.
1 change: 1 addition & 0 deletions readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,7 @@ $status = $sender->send();
| Mobireach | Username,Password, From | Done | - | - |
| NovocomBD | ApiKey , ClientId , SenderId | Done | - | - |
| OnnoRokomSMS | userName, userPassword, type, maskName, campaignName | Done | not tested yet in live | - |
| RedmoITSms | api_token, sender_id | Done | not tested yet in live | - |
| SmartLabSMS | user, password, sender | Done | - | - |
| SMSNet24 | user_id, user_password, route_id(optional), sms_type_id(optional) | Done | - | admin2@digitallabbd.com, +880 1705 691269, +880 1733393 712 |
| Sslsms | api_token, sid, csms_id | Done | - | - |
Expand Down
6 changes: 6 additions & 0 deletions src/Config/sms.php
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
use Xenon\LaravelBDSms\Provider\Mobishasra;
use Xenon\LaravelBDSms\Provider\NovocomBd;
use Xenon\LaravelBDSms\Provider\Onnorokom;
use Xenon\LaravelBDSms\Provider\RedmoItSms;
use Xenon\LaravelBDSms\Provider\SmartLabSms;
use Xenon\LaravelBDSms\Provider\Sms4BD;
use Xenon\LaravelBDSms\Provider\SmsNet24;
Expand Down Expand Up @@ -161,6 +162,11 @@
'maskName' => env('SMS_ONNOROKOM_MASK', ''),
'campaignName' => env('SMS_ONNOROKOM_CAMPAIGN_NAME', ''),
],
RedmoItSms::class => [
'sender_id' => env('SMS_REDMOIT_SENDER_ID', ''),
'api_token' => env('SMS_REDMOIT_API_TOKEN', ''),
'type' => env('SMS_REDMOIT_TYPE', 'string'),
],
SmartLabSms::class => [
'user' => env('SMS_SMARTLAB_USER', ''),
'password' => env('SMS_SMARTLAB_PASSWORD', ''),
Expand Down
81 changes: 81 additions & 0 deletions src/Provider/RedmoItSms.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
<?php
/*
* Last Modified: 6/29/21, 12:06 AM
* Copyright (c) 2021
* -created by Ariful Islam
* -All Rights Preserved By
* -If you have any query then knock me at
* arif98741@gmail.com
* See my profile @ https://github.com/arif98741
*/

namespace Xenon\LaravelBDSms\Provider;

use Xenon\LaravelBDSms\Handler\ParameterException;
use Xenon\LaravelBDSms\Handler\RenderException;
use Xenon\LaravelBDSms\Request;
use Xenon\LaravelBDSms\Sender;

class RedmoItSms extends AbstractProvider
{
/**
* DianaHost constructor.
* @param Sender $sender
*/
public function __construct(Sender $sender)
{
$this->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();

$query = [
'sender_id' => $config['sender_id'],
'recipient' => $number,
'message' => $text,
];

$headers = [
'Authorization' => 'Bearer ' . $config['api_token'],
'Content-Type' => 'application/json'
];

$requestObject = new Request('https://sms.redmoit.com/api/v3/sms/send', $query, $queue);
$requestObject->setHeaders($headers)->setContentTypeJson(true);
$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('api_token', $this->senderObject->getConfig())) {
throw new ParameterException('api_token is absent in configuration');
}

if (!array_key_exists('sender_id', $this->senderObject->getConfig())) {
throw new ParameterException('sender_id key is absent in configuration');
}
}

}

0 comments on commit a517329

Please sign in to comment.