129 lines
3.1 KiB
PHP
Executable File
129 lines
3.1 KiB
PHP
Executable File
<?php define('__ROOT__', dirname(__FILE__) );
|
|
require_once __ROOT__.'/manager/autoloader.php';
|
|
|
|
use \manager\ModuleRequest;
|
|
use \manager\ResourceDispatcher;
|
|
use \manager\ManagerError;
|
|
use \manager\Repo;
|
|
|
|
debug();
|
|
|
|
|
|
|
|
|
|
|
|
/* PARSAGE DE JOURNAUX D'APPEL
|
|
*
|
|
*
|
|
*/
|
|
function parseCallLog(){
|
|
|
|
/* [1] On recupere le journal d'appel
|
|
=========================================================*/
|
|
$filename = 'calllog.xml';
|
|
$file = simplexml_load_file( $filename );
|
|
|
|
/* [2] On parcours chaque ligne
|
|
=========================================================*/
|
|
$names = array(); // Contiendra les correspondances num/names
|
|
$msms = array(); // Contiendra les personnes utilisant SMS/MMS
|
|
$call = array(); // Contiendra les personnes utilisant CALL
|
|
|
|
|
|
|
|
/* [3] On parcours chaque ligne
|
|
=========================================================*/
|
|
foreach($file->Item as $log){
|
|
// On recupere le numero en string
|
|
$num = (string) $log['Number'];
|
|
|
|
// On formatte le numero
|
|
if( preg_match("/^(?:\+33|33|0)(.+)/", $num, $m) )
|
|
$num = '0'.$m[1];
|
|
// Si pas un numero, on sort de la boucle
|
|
else
|
|
continue;
|
|
|
|
|
|
/* (1) Si le type est MMS ou SMS */
|
|
if( $log['Type'] == 'SMS' || $log['Type'] == 'MMS' ){
|
|
|
|
// Si la personne n'est pas referencee, on l'ajoute
|
|
// Sinon on incremente son nombre d'apparition
|
|
if( isset($msms[$num]) )
|
|
$msms[$num]+= 1;
|
|
else
|
|
$msms[$num] = 1;
|
|
|
|
// On enregistre le nom si c'est pas fait
|
|
if( !isset($names[$num]) ) $names[$num] = $log['Name'];
|
|
|
|
|
|
/* (2) Si le type est PHONE */
|
|
}else if( $log['Type'] == 'PHONE' ){
|
|
|
|
// Si la personne n'est pas referencee, on l'ajoute
|
|
// Sinon on incremente son nombre d'apparition
|
|
if( isset($call[$num]) )
|
|
$call[$num]+= 1;
|
|
else
|
|
$call[$num] = 1;
|
|
|
|
// On enregistre le nom si c'est pas fait
|
|
if( !isset($names[$num]) ) $names[$num] = $log['Name'];
|
|
|
|
}
|
|
|
|
// var_dump( $log );
|
|
}
|
|
|
|
|
|
/* [4] On trie par nombre de contacts
|
|
=========================================================*/
|
|
$tmp = $msms;
|
|
/* (2) Tri des appels */
|
|
$maxMSMS = array();
|
|
for( $i = 0 ; $i < 10 ; $i++ ){
|
|
$maxval = max($tmp);
|
|
$maxkey = array_search($maxval, $tmp);
|
|
array_push( $maxMSMS, array($maxkey, $maxval) );
|
|
unset($tmp[$maxkey]);
|
|
}
|
|
|
|
|
|
$tmp = $call;
|
|
/* (2) Tri des appels */
|
|
$maxCalls = array();
|
|
for( $i = 0 ; $i < 10 ; $i++ ){
|
|
$maxval = max($tmp);
|
|
$maxkey = array_search($maxval, $tmp);
|
|
array_push( $maxCalls, array($maxkey, $maxval) );
|
|
unset($tmp[$maxkey]);
|
|
}
|
|
|
|
/* [5] On debug les donnees recues
|
|
=========================================================*/
|
|
echo "Il y a ".count($names)." personnes :<br>";
|
|
echo "- ".count($msms)." par SMS/MMS<br>";
|
|
echo "- ".count($call)." par telephone<br><br>";
|
|
|
|
echo "TOP 10 DES APPELS<br>";
|
|
echo "=================<br>";
|
|
foreach($maxCalls as $v)
|
|
var_dump( $v[0] ." (".$names[$v[0]].") \t\t\t". $v[1] ." appels");
|
|
|
|
echo "TOP 10 DES MMS/SMS<br>";
|
|
echo "==================<br>";
|
|
foreach($maxMSMS as $v)
|
|
var_dump( $v[0] ." (".$names[$v[0]].") \t\t\t". $v[1] ." appels");
|
|
|
|
// var_dump( $call );
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
|
|
parseCallLog();
|
|
|
|
?>
|