$msg = $_REQUEST['message']; # # # # # # # # # LOG TO FILE # # # # # # # # # $stamp = date("Y-m-d H:i:s"); $fp = fopen("sms.log", "a+"); foreach ($_REQUEST as $k => $v) { fputs($fp, "[" . $stamp . "]" . $k . " => " . $v . "\n"); } fclose($fp); echo "received"; # # # # # # # # # END LOG TO FILE # # # # # # # # # # # # # # # # # # LOG TO DB # # # # # # # # # global $current_user; $current_user->retrieve(1); require_once "custom/sms/sms.php"; $sms = new sms(); $sms->retrieve_settings(); require_once "modules/sugartalk_SMS/sugartalk_SMS.php"; $sugartalk_SMS = new sugartalk_SMS(); require_once "modules/Administration/sugartalk_smsPhone/sms_enzyme.php"; $e = new sms_enzyme(); $result = $e->parse_sms_macro($msg); if ($result['code'] != '') { # recreate $e and retrieve the module's id $e = new sms_enzyme($result['module']); include_once $e->mod_bean_files; $object = new $e->module_sing(); $where_array = array($result['field'] => $result['code']); $object->retrieve_by_string_fields($where_array); $parent_id = $object->id; $parent_type = $result['module']; $assigned_user_id = $object->assigned_user_id;
function sendSMS($save_emails = 1, $testmode = false) { require_once 'custom/sms/sms.php'; require_once 'modules/Administration/sugartalk_smsPhone/sms_enzyme.php'; $sms = new sms(); $sms->retrieve_settings(); global $beanList, $beanFiles, $sugar_config; global $mod_strings; $mod_strings = return_module_language($sugar_config['default_language'], 'EmailMan'); if (!isset($beanList[$this->related_type])) { return false; } $class = $beanList[$this->related_type]; if (!class_exists($class)) { require_once $beanFiles[$class]; } if (!class_exists('SMS')) { } $module = new $class(); // tracy: the module $module->retrieve($this->related_id); // tracy: person's id $mod = array_search($class, $beanList); # tracy: use the selected phone field else use the default phone_mobile (esp for Users) $phone_number = ""; if ($mod == "Users") { $phone_number = $module->phone_mobile; } elseif (!empty($mod)) { $e = new sms_enzyme($mod); $phone_field = $e->get_custom_phone_field(); if (!empty($phone_field)) { $phone_number = $module->{$phone_field}; } } $phone_number = preg_replace('/[^0-9]/', '', $phone_number); $this->test = $testmode; # tracy: invalid if there's no number if (empty($phone_number) or $phone_number == '') { $this->set_as_sent($phone_number, true, null, 'SMS', 'invalid email'); $GLOBALS['log']->debug('Phone number was empty. Emailman id = ' . $this->id); } # tracy: check if phone number is in the suppression list if (isset($this->restricted_phone_numbers) && isset($this->restricted_phone_numbers[$phone_number])) { if ($this->restricted_phone_numbers[$phone_number] == 1) { $this->set_as_sent($phone_number, true, null, 'SMS', 'blocked'); $GLOBALS['log']->debug('Phone number is in the suppression list by phone number. Emailman id = ' . $this->id); return true; } } //fetch email marketing. if (empty($this->current_emailmarketing) or !isset($this->current_emailmarketing)) { if (!class_exists('EmailMarketing')) { } $this->current_emailmarketing = new EmailMarketing(); } if (empty($this->current_emailmarketing->id) or $this->current_emailmarketing->id !== $this->marketing_id) { $this->current_emailmarketing->retrieve($this->marketing_id); $this->newmessage = true; } //fetch email template associated with the marketing message. if (empty($this->current_emailtemplate) or $this->current_emailtemplate->id != $this->current_emailmarketing->template_id) { if (!class_exists('EmailTemplate')) { } $this->current_emailtemplate = new EmailTemplate(); $this->current_emailtemplate->retrieve($this->current_emailmarketing->template_id); } $sms_message = isset($this->current_emailtemplate->body) ? $this->current_emailtemplate->body : ''; //parse and replace bean variables in sms_message $template_data = $this->current_emailtemplate->parse_email_template(array('body' => $sms_message), 'Contacts', $module, $macro_nv); // what if user chose other accounts or user? hmm //replace sms_message with clean message $sms_message = $template_data['body']; # tracy: do not send sms if msg is empty if ($sms_message == '') { $this->set_as_sent($phone_number, true, null, 'SMS', 'send error'); $GLOBALS['log']->debug('Message was empty. Emailman id = ' . $this->id); return false; } // fetch campaign details.. if (empty($this->current_campaign)) { if (!class_exists('Campaign')) { } $this->current_campaign = new Campaign(); } //refetch strings in case they have been changed by creation of email templates or other beans. $mod_strings = return_module_language($sugar_config['default_language'], 'EmailMan'); # get the parent info $sms->parent_type = $module->object_name == 'Case' ? 'Cases' : array_search($module->object_name, $beanList); $sms->parent_id = $module->id; if (isset($sms->params) && !empty($sms->params)) { $sms->pname = $module->name; $res = $sms->send_message($phone_number, $sms_message); # tracy: this handles the error response from the api if ($sms->response_text == "SENT" || $res == "SENT") { $this->set_as_sent($phone_number, true, null, 'SMS', 'targeted'); $GLOBALS['log']->debug('Message sent to {$phone_number}. Emailman id = ' . $this->id); return true; } else { $this->set_as_sent($phone_number, true, null, 'SMS', 'send error'); $GLOBALS['log']->fatal('API Error: {$sms->response_text}. Emailman id = ' . $this->id); return false; } } else { $this->set_as_sent($phone_number, true, null, 'SMS', 'send error'); $GLOBALS['log']->fatal('SMS Config Error: There was no provider configured for this service. Emailman id = ' . $this->id); return false; } }