+ function pproxy_realip(&$header, $ip_str)
+ {
+ return ($this->provider_proxy->realip($header, $ip_str));
+ }
+
+ function reload($is_first, $prov_proxy)
+ {
+ fprintf(STDERR, "SAP RELOAD STUFF (%d)\n", count($prov_proxy));
+
+ $this->provider_proxy->update($prov_proxy);
+ }
+
+ function direct_command($cmdstr)
+ {
+ GLOBAL $G_alarm_passwd;
+
+ $cmd = cmd_deserialize($cmdstr);
+
+ if (!isset($cmd['cmd'])) {
+ return cmd_return(500, 'no cmd found');
+ }
+ // "cmd" => "userauth", "sess" => 'xxxxxxxxxxx', 'private' => 'it_must_be_correct',
+ // 'the_end' => 'true' );
+ // cmd=userauth&sess=52d796ac08c47&private=yourpasswd192.168.122.152d796ac08c47&the_end=true
+ if ($cmd['cmd'] == 'userauth') {
+ if (!isset($cmd['sess']) || !isset($cmd['private'])) {
+ return cmd_return(401, 'malformed cmd');
+ }
+ $idx = -1;
+ if (($user = $this->app->get_user($cmd['sess'], $idx)) == FALSE)
+ return cmd_return(402, 'user not found');
+
+ if (($user->flags & USER_FLAG_TY_ADMIN) == 0x00)
+ return cmd_return(403, 'permission denied');
+
+ if (md5($G_alarm_passwd.$user->ip.$user->sess) != $cmd['private'])
+ return cmd_return(404, 'authentication failed ['.$cmd['private'].']['.$G_alarm_passwd.$user->ip.$user->sess.']');
+
+ return cmd_return(200, 'success');
+ }
+
+ return cmd_return(501, 'no cmd found');
+ }
+
+ function direct_mgmt($socket)
+ {
+ printf("DIRECT: begin\n");
+ $st = DIRECT_ST_READ;
+ $cmd_all = "";
+ $endtime = $this->curtime + 3;
+
+ while(time() <= $endtime) {
+ printf("DIRECT: init loop %d\n", $st);
+ if ($st == DIRECT_ST_READ) {
+ $buf = fread($socket, 4096);
+ if ($buf == FALSE && feof($socket)) {
+ break;
+ }
+ else if ($buf != FALSE && strlen($buf) > 0) {
+ $cmd_all .= $buf;
+
+ if (substr(trim($cmd_all), -13) == "&the_end=true") {
+ $output_arr = $this->direct_command($cmd_all);
+ $output = cmd_serialize($output_arr);
+ $output_cur = 0;
+ $output_len = mb_strlen($output, "ASCII");
+ $st = DIRECT_ST_WRITE;
+ continue;
+ }
+ }
+ }
+ else if ($st == DIRECT_ST_WRITE) {
+ $ret = fwrite($socket, $output, $output_len);
+ if ($ret === FALSE) {
+ if (feof($socket)) {
+ break;
+ }
+ }
+ else if ($ret > 0 && $ret < $output_len) {
+ $output = substr($output, -($output_len - $ret));
+ $output_len -= $ret;
+ continue;
+ }
+ else if ($ret == $output_len) {
+ fclose($socket);
+ return TRUE;
+ }
+ }
+ // probably not needed
+ // usleep(10000);
+ }
+
+ fclose($socket);
+ return FALSE;
+ }
+} // class Sac_a_push