'AccountSID','label'=>'Account SID','type'=>'text'), array('name'=>'AuthToken','label'=>'Auth Token','type'=>'text'), array('name'=>'From','label'=>'From','type'=>'text')); /** * Function to get provider name * @return provider name */ public function getName() { return 'Twilio'; } /** * Function to get required parameters other than (userName, password) * @return required parameters list */ public function getRequiredParams() { return self::$REQUIRED_PARAMETERS; } /** * Function to get service URL to use for a given type * @param $type like SEND, PING, QUERY */ public function getServiceURL($type = false) { $accountSID = $this->getParameter('AccountSID'); $this->SERVICE_URI = str_replace('{sid}', $accountSID, $this->SERVICE_URI); if($type) { switch(strtoupper($type)) { case self::SERVICE_AUTH: return $this->SERVICE_URI . '/http/auth'; case self::SERVICE_SEND: return $this->SERVICE_URI . '/http/sendmsg'; case self::SERVICE_QUERY: return $this->SERVICE_URI . '/http/querymsg'; } } return $this->SERVICE_URI; } /** * Function to set authentication parameters * @param $userName * @param $password */ public function setAuthParameters($userName, $password) { $this->userName = $userName; $this->password = $password; } /** * Function to set non-auth parameter. * @param $key * @param $value */ public function setParameter($key, $value) { $this->parameters[$key] = $value; } /** * Function to get parameter value * @param $key * @param $defaultValue * @return value/$default value */ public function getParameter($key, $defaultValue = false) { if(isset($this->parameters[$key])) { return $this->parameters[$key]; } return $defaultValue; } /** * Function to prepare parameters * @return parameters */ protected function prepareParameters() { foreach (self::$REQUIRED_PARAMETERS as $key=>$fieldInfo) { $params[$fieldInfo['name']] = $this->getParameter($fieldInfo['name']); } return $params; } /** * Function to handle SMS Send operation * @param $message * @param $toNumbers One or Array of numbers */ public function send($message, $toNumbers) { if(!is_array($toNumbers)) { $toNumbers = array($toNumbers); } $params = $this->prepareParameters(); $httpClient = new Vtiger_Net_Client($this->getServiceURL()); $httpClient->setHeaders(array('Authorization' => 'Basic '.base64_encode($params['AccountSID'].':'.$params['AuthToken']))); foreach($toNumbers as $toNumber) { $xmlResponse = $httpClient->doPost(array('From'=>$params['From'], 'To'=>$toNumber,'Body'=>$message)); $xmlObject = simplexml_load_string($xmlResponse); $result = array(); if($xmlObject->SMSMessage) { $result['id'] = (string)$xmlObject->SMSMessage->Sid; $status = (string)$xmlObject->SMSMessage->Status; $result['status'] = (string)$xmlObject->SMSMessage->Status; $result['to'] = (string)$xmlObject->SMSMessage->To; switch($status) { case 'queued' : case 'sending' : $status = self::MSG_STATUS_PROCESSING; break; case 'sent' : $status = self::MSG_STATUS_DISPATCHED; break; case 'delivered' : $status = self::MSG_STATUS_DELIVERED; break; case 'undelivered' : case 'failed' : $status = self::MSG_STATUS_FAILED; break; } $results[] = $result; } else { $result['error'] = true; $result['statusmessage'] = (string)$xmlObject->RestException->Message; $result['to'] = $toNumber; $results[] = $result; } } return $results; } /** * Function to get query for status using messgae id * @param $messageId */ public function query($messageId) { $params = $this->prepareParameters(); $params['Sid'] = $messageId; $params = $this->prepareParameters(); $httpClient = new Vtiger_Net_Client($this->getServiceURL().'/'.$messageId); $httpClient->setHeaders(array('Authorization' => 'Basic '.base64_encode($params['AccountSID'].':'.$params['AuthToken']))); $xmlResponse = $httpClient->doGet(array()); $xmlObject = simplexml_load_string($xmlResponse); $result = array(); $result['error'] = false; $status = (string)$xmlObject->Message->Status; switch($status) { case 'queued' : case 'sending' : $status = self::MSG_STATUS_PROCESSING; $result['needlookup'] = 1; break; case 'sent' : $status = self::MSG_STATUS_DISPATCHED; $result['needlookup'] = 1; break; case 'delivered' : $status = self::MSG_STATUS_DELIVERED; $result['needlookup'] = 0; break; case 'undelivered' : case 'failed' : default : $status = self::MSG_STATUS_FAILED; $result['needlookup'] = 1; break; } $result['status'] = $status; $result['statusmessage'] = $status; return $result; } function getProviderEditFieldTemplateName() { return 'Twilio.tpl'; } } ?>