get_request_phone_number(); $password = @$PASSWORDS[$phone_number]; if (!isset($password) || !$kalsms->is_validated_request($password)) { header("HTTP/1.1 403 Forbidden"); error_log("Invalid request signature"); echo "Invalid request signature"; return; } $action = $kalsms->get_request_action(); switch ($action->type) { case KalSMS::ACTION_INCOMING: error_log("Received SMS from {$action->from}"); $reply = new KalSMS_OutgoingMessage(); $reply->message = "You said: {$action->message}"; error_log("Sending reply: {$reply->message}"); header("Content-Type: text/xml"); echo $action->get_response_xml(array($reply)); return; case KalSMS::ACTION_OUTGOING: $messages = array(); $dir = opendir($OUTGOING_DIR_NAME); while ($file = readdir($dir)) { if (preg_match('#\.json$#', $file)) { $data = json_decode(file_get_contents("$OUTGOING_DIR_NAME/$file"), true); if ($data && @$data['from'] == $phone_number) { $sms = new KalSMS_OutgoingMessage(); $sms->id = $data['id']; $sms->to = $data['to']; $sms->from = $data['from']; $sms->message = $data['message']; $messages[] = $sms; } } } closedir($dir); header("Content-Type: text/xml"); echo $action->get_response_xml($messages); return; case KalSMS::ACTION_SEND_STATUS: $id = $action->id; // delete file with matching id if (preg_match('#^\w+$#', $id) && unlink("$OUTGOING_DIR_NAME/$id.json")) { echo "OK"; } else { header("HTTP/1.1 404 Not Found"); echo "invalid id"; } return; case KalSMS::ACTION_TEST: echo "OK"; return; default: header("HTTP/1.1 404 Not Found"); echo "Invalid action"; return; }