msg); } //On chargera nous même les messages si on en a besoin public function need_global_messages() { return false; } public function process($source_id, $pmb_user_id) { global $uid, $token; $userinfos = []; $msg = ''; header('Content-Type: application/json'); if(!isset($uid) || !is_numeric($uid) || !$uid) { $msg = encoding_normalize::utf8_normalize($this->msg['divercities_no_uid']); echo encoding_normalize::json_encode(array('state'=>'KO', 'msg'=>$msg, 'userinfos'=>$userinfos)); return; } if(!isset($token) || !is_string($token) || !$token) { $msg = encoding_normalize::utf8_normalize($this->msg['divercities_no_token']); echo encoding_normalize::json_encode(array('state'=>'KO', 'msg'=>$msg, 'userinfos'=>$userinfos)); return; } $q = "select empr_nom, empr_prenom,empr_mail from empr where id_empr={$uid} and empr_date_expiration > date(now())"; $r = pmb_mysql_query($q); $n = pmb_mysql_num_rows($r); if(!$n) { $msg = encoding_normalize::utf8_normalize($this->msg['divercities_invalid_uid']); echo encoding_normalize::json_encode(array('state'=>'KO', 'msg'=>$msg, 'userinfos'=>$userinfos)); return; } $source = $this->instantiate_source_class($source_id); $param = $source->config; $verified_token = md5($uid.$param['shared_key'].$param['station_id']); if($token != $verified_token) { $msg = encoding_normalize::utf8_normalize($this->msg['divercities_invalid_token']); echo encoding_normalize::json_encode(array('state'=>'KO', 'msg'=>$msg, 'userinfos'=>$userinfos)); return; } $res = pmb_mysql_fetch_assoc($r); $userinfos['lastname'] = $res['empr_nom']; $userinfos['firstname'] = $res['empr_prenom']; $userinfos['mail'] = $res['empr_mail']; echo encoding_normalize::json_encode(array('state'=>'OK', 'msg'=>$msg, 'userinfos'=>$userinfos)); } } class divercities_source extends connecteur_out_source { public function get_config_form() { global $charset; $result = parent::get_config_form(); //init parametres a la creation if(!$this->id) { $this->config['station_id'] = ''; $this->config['shared_key'] = bin2hex(openssl_random_pseudo_bytes(32)); } //Adresse du Web service $result .= '