mirror of
https://github.com/Yubico/yubikey-val.git
synced 2024-11-29 09:24:12 +01:00
61 lines
1.6 KiB
PHP
61 lines
1.6 KiB
PHP
|
#!/usr/bin/php
|
||
|
<?php
|
||
|
|
||
|
set_include_path(get_include_path() . PATH_SEPARATOR . "/usr/share/ykval:/etc/ykval");
|
||
|
|
||
|
require_once 'ykval-config.php';
|
||
|
require_once 'ykval-db.php';
|
||
|
|
||
|
|
||
|
$logname="ykval-import";
|
||
|
$myLog = new Log($logname);
|
||
|
|
||
|
$db=new Db($baseParams['__YKVAL_DB_DSN__'],
|
||
|
$baseParams['__YKVAL_DB_USER__'],
|
||
|
$baseParams['__YKVAL_DB_PW__'],
|
||
|
$baseParams['__YKVAL_DB_OPTIONS__'],
|
||
|
$logname . ':db');
|
||
|
|
||
|
if (!$db->connect()) {
|
||
|
$myLog->log(LOG_WARNING, "Could not connect to database");
|
||
|
error_log("Could not connect to database");
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
|
||
|
while ($res=fgetcsv(STDIN, 0, "\t")) {
|
||
|
$params=array("id"=>$res[0],
|
||
|
"active"=>$res[1],
|
||
|
"created"=>$res[2],
|
||
|
"secret"=>$res[3],
|
||
|
"email"=>$res[4],
|
||
|
"notes"=>$res[5],
|
||
|
"otp"=>$res[6]);
|
||
|
|
||
|
|
||
|
$query="SELECT * FROM clients WHERE id='" . $params['id'] . "'";
|
||
|
$result=$db->customQuery($query);
|
||
|
if(!$result->fetch(PDO::FETCH_ASSOC)) {
|
||
|
// We didn't have the id in database so we need to do insert instead
|
||
|
$query="INSERT INTO clients " .
|
||
|
"(id,active,created,secret,email,notes,otp) VALUES " .
|
||
|
"('" . $params["id"] . "', " .
|
||
|
"'" . $params["active"] . "', " .
|
||
|
"'" . $params['created'] . "'," .
|
||
|
"'" . $params['secret'] . "'," .
|
||
|
"'" . $params['email'] . "'," .
|
||
|
"'" . $params['notes'] . "'," .
|
||
|
"'" . $params['otp'] . "')";
|
||
|
|
||
|
if(!$db->customQuery($query)){
|
||
|
$myLog->log(LOG_ERR, "Failed to insert new client with query " . $query);
|
||
|
error_log("Failed to insert new client with query " . $query);
|
||
|
exit(1);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
$myLog->log(LOG_NOTICE, "Successfully imported clients to database");
|
||
|
echo "Successfully imported clients to database\n";
|