2017-01-30 21:36:44 +01:00
< ? php
/* μlogger
*
* Copyright ( C ) 2017 Bartek Fabiszewski ( www . fabiszewski . net )
*
* This is free software ; you can redistribute it and / or modify it under
2017-04-07 00:05:28 +02:00
* the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 3 of the License , or
2017-01-30 21:36:44 +01:00
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful , but
* WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* General Public License for more details .
*
2017-04-07 00:05:28 +02:00
* You should have received a copy of the GNU General Public License
* along with this program ; if not , see < http :// www . gnu . org / licenses />.
2017-01-30 21:36:44 +01:00
*/
/* This script imports data from old phpTrackme database scheme .
*
2017-04-16 21:25:18 +02:00
* However , as μlogger uses more secure password storage methods ,
2017-01-30 21:36:44 +01:00
* it is impossible to convert old password hashes to the new format .
2017-04-09 23:35:55 +02:00
* Administrator will have to fill in user passwords manually .
* Alternatively authentication code could be modify in order to
* temporarily accept old hashes and convert it as users log in .
* It should be pretty simple , but this is not a top priority
2017-01-30 21:36:44 +01:00
* for this small project .
*/
// this script is disabled by default. Change below to true before running.
$enabled = false ;
// path to root folder of phpTrackme
$phpTrackmePath = " ../../phpTrackme " ;
// path to root folder of μlogger
$uloggerPath = " .. " ;
/* -------------------------------------------- */
/* no user modifications should be needed below */
if ( $enabled == false ) {
echo " Script is disabled \n " ;
exit ( 1 );
}
$path = realpath ( dirname ( __FILE__ ));
if ( ! empty ( $phpTrackmePath ) && $phpTrackmePath [ 0 ] == " . " ) {
$phpTrackmePath = $path . " / " . $phpTrackmePath ;
}
$phpTrackmeConfig = $phpTrackmePath . " /config.php " ;
if ( ! is_readable ( $phpTrackmeConfig )) {
echo " Can't find phpTrackme config file: $phpTrackmeConfig\n " ;
exit ( 1 );
}
include ( $phpTrackmeConfig );
$pt_dbhost = $dbhost ;
$pt_dbuser = $dbuser ;
$pt_dbpass = $dbpass ;
$pt_dbname = $dbname ;
$pt_mysqli = new mysqli ( $pt_dbhost , $pt_dbuser , $pt_dbpass , $pt_dbname );
$pt_mysqli -> set_charset ( " utf8 " );
if ( $pt_mysqli -> connect_errno ) {
echo " Can't connect to $pt_dbname database: ( " . $pt_mysqli -> errno . " ) " . $pt_mysqli -> error . " \n " ;
exit ( 1 );
}
if ( ! empty ( $uloggerPath ) && $uloggerPath [ 0 ] == " . " ) {
$uloggerPath = $path . " / " . $uloggerPath ;
}
$uloggerConfig = $uloggerPath . " /config.php " ;
if ( ! is_readable ( $uloggerConfig )) {
echo " Can't find μlogger config fiel: $uloggerConfige\n " ;
exit ( 1 );
}
include ( $uloggerConfig );
$mysqli = new mysqli ( $dbhost , $dbuser , $dbpass , $dbname );
$mysqli -> set_charset ( " utf8 " );
if ( $mysqli -> connect_errno ) {
echo " Can't connect to $dbname database : ( " . $mysqli -> errno . " ) " . $mysqli -> error . " \n " ;
exit ( 1 );
}
2017-04-17 22:04:33 +02:00
$prefix = preg_replace ( '/[^a-z0-9_]/i' , '' , $dbprefix );
$tPositions = $prefix . " positions " ;
$tTracks = $prefix . " tracks " ;
$tUsers = $prefix . " users " ;
2017-01-30 21:36:44 +01:00
// import data
if ( ! $users_result = $pt_mysqli -> query ( " SELECT * FROM users ORDER BY ID " )) {
echo " Query failed \n " ;
exit ( 1 );
}
2017-04-17 22:04:33 +02:00
if ( ! ( $user_insert = $mysqli -> prepare ( " INSERT INTO ` $tUsers ` (login, password) VALUES (?, ?) " ))) {
2017-01-30 21:36:44 +01:00
echo " Prepare failed: ( " . $mysqli -> errno . " ) " . $mysqli -> error . " \n " ;
exit ( 1 );
}
$pt_user = null ;
$pt_pass = null ;
if ( ! $user_insert -> bind_param ( " ss " , $pt_user , $pt_pass )) {
echo " Binding parameters failed: ( " . $user_insert -> errno . " ) " . $user_insert -> error . " \n " ;
exit ( 1 );
}
while ( $user = $users_result -> fetch_assoc ()) {
$pt_user = $user [ 'username' ];
$pt_pass = $user [ 'password' ];
$pt_id = $user [ 'ID' ];
if ( ! $user_insert -> execute ()) {
echo " Execute failed: ( " . $user_insert -> errno . " ) " . $user_insert -> error . " \n " ;
exit ( 1 );
}
$user_id = $user_insert -> insert_id ;
process_user_tracks ( $user_id );
}
2017-01-30 23:45:51 +01:00
$users_result -> close ();
$user_insert -> close ();
2017-01-30 21:36:44 +01:00
2017-01-30 23:45:51 +01:00
$mysqli -> close ();
$pt_mysqli -> close ();
echo " Import finished successfully \n " ;
exit ( 0 );
/* Helper functions */
/** Import tracks metadata for given user
* @ param $user_id User id
*/
2017-01-30 21:36:44 +01:00
function process_user_tracks ( $user_id ) {
global $pt_mysqli , $mysqli ;
2017-03-16 16:39:40 +01:00
$sql = " SELECT ID, Name, Comments FROM trips WHERE FK_Users_ID = ? ORDER BY ID " ;
2017-01-30 21:36:44 +01:00
if ( ! ( $tracks_select = $pt_mysqli -> prepare ( $sql ))) {
echo " Prepare failed: ( " . $pt_mysqli -> errno . " ) " . $pt_mysqli -> error . " \n " ;
exit ( 1 );
}
if ( ! $tracks_select -> bind_param ( 'i' , $user_id )) {
echo " Binding parameters failed: ( " . $tracks_select -> errno . " ) " . $tracks_select -> error . " \n " ;
exit ( 1 );
}
2017-03-16 16:39:40 +01:00
if ( ! $tracks_select -> bind_result ( $pt_id , $pt_name , $pt_comment )) {
echo " Binding parameters failed: ( " . $tracks_select -> errno . " ) " . $tracks_select -> error . " \n " ;
exit ( 1 );
}
2017-01-30 21:36:44 +01:00
if ( ! $tracks_select -> execute ()) {
echo " Execute failed: ( " . $tracks_select -> errno . " ) " . $tracks_select -> error . " \n " ;
exit ( 1 );
}
2017-03-16 16:39:40 +01:00
$tracks_select -> store_result ();
2017-04-17 22:04:33 +02:00
if ( ! ( $track_insert = $mysqli -> prepare ( " INSERT INTO ` $tTracks ` (user_id, name, comment) VALUES (?, ?, ?) " ))) {
2017-01-30 21:36:44 +01:00
echo " Prepare failed: ( " . $mysqli -> errno . " ) " . $mysqli -> error . " \n " ;
exit ( 1 );
}
$pt_name = null ;
$pt_comment = null ;
if ( ! $track_insert -> bind_param ( " iss " , $user_id , $pt_name , $pt_comment )) {
echo " Binding parameters failed: ( " . $track_insert -> errno . " ) " . $track_insert -> error . " \n " ;
exit ( 1 );
}
2017-03-16 16:39:40 +01:00
while ( $tracks_select -> fetch ()) {
2017-01-30 21:36:44 +01:00
if ( ! $track_insert -> execute ()) {
echo " Execute failed: ( " . $track_insert -> errno . " ) " . $track_insert -> error . " \n " ;
exit ( 1 );
}
$track_id = $track_insert -> insert_id ;
2017-01-30 23:45:51 +01:00
process_track ( $user_id , $pt_id , $track_id );
2017-01-30 21:36:44 +01:00
}
2017-03-16 16:39:40 +01:00
$tracks_select -> free_result ();
2017-01-30 23:45:51 +01:00
$tracks_select -> close ();
$track_insert -> close ();
2017-01-30 21:36:44 +01:00
}
2017-01-30 23:45:51 +01:00
/** Import positions for given track
* @ param $user_id User id
* @ param $old_id Old database track id
* @ param $new_id New database track id
*/
function process_track ( $user_id , $old_id , $new_id ) {
2017-01-30 21:36:44 +01:00
global $pt_mysqli , $mysqli ;
2017-03-16 16:39:40 +01:00
$sql = " SELECT Latitude, Longitude, Altitude, Speed, Angle, DateOccurred, Comments FROM pt_positions WHERE FK_Users_ID = ? AND FK_Trips_ID = ? ORDER BY DateOccurred " ;
2017-01-30 21:36:44 +01:00
if ( ! ( $pos_select = $pt_mysqli -> prepare ( $sql ))) {
echo " Prepare failed: ( " . $pt_mysqli -> errno . " ) " . $pt_mysqli -> error . " \n " ;
exit ( 1 );
}
2017-01-30 23:45:51 +01:00
if ( ! $pos_select -> bind_param ( 'ii' , $user_id , $old_id )) {
2017-01-30 21:36:44 +01:00
echo " Binding parameters failed: ( " . $pos_select -> errno . " ) " . $pos_select -> error . " \n " ;
exit ( 1 );
}
2017-03-16 16:39:40 +01:00
if ( ! $pos_select -> bind_result ( $lat , $lon , $altitude , $speed , $bearing , $time , $comment )) {
echo " Binding parameters failed: ( " . $pos_select -> errno . " ) " . $pos_select -> error . " \n " ;
exit ( 1 );
}
2017-01-30 21:36:44 +01:00
if ( ! $pos_select -> execute ()) {
echo " Execute failed: ( " . $pos_select -> errno . " ) " . $pos_select -> error . " \n " ;
exit ( 1 );
}
2017-03-16 16:39:40 +01:00
$pos_select -> store_result ();
2017-04-17 22:04:33 +02:00
if ( ! ( $pos_insert = $mysqli -> prepare ( " INSERT INTO ` $tPositions ` (time, user_id, track_id, latitude, longitude, altitude, speed, bearing, accuracy, provider, comment, image_id)
2017-01-30 21:36:44 +01:00
VALUES ( ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? ) " ))) {
echo " Prepare failed: ( " . $mysqli -> errno . " ) " . $mysqli -> error . " \n " ;
exit ( 1 );
}
$provider = $comment = $time = $imageid = null ;
$lat = $lon = 0 ;
$altitude = $speed = $bearing = $accuracy = null ;
if ( ! $pos_insert -> bind_param ( 'siiddddddssi' ,
2017-01-30 23:45:51 +01:00
$time , $user_id , $new_id , $lat , $lon , $altitude , $speed , $bearing , $accuracy , $provider , $comment , $imageid )) {
2017-01-30 21:36:44 +01:00
echo " Binding parameters failed: ( " . $pos_insert -> errno . " ) " . $pos_insert -> error . " \n " ;
exit ( 1 );
}
2017-03-16 16:39:40 +01:00
while ( $pos_select -> fetch ()) {
2017-01-30 21:36:44 +01:00
$provider = null ;
if ( ! $pos_insert -> execute ()) {
echo " Execute failed: ( " . $pos_insert -> errno . " ) " . $pos_insert -> error . " \n " ;
exit ( 1 );
}
}
2017-01-30 23:45:51 +01:00
$pos_insert -> close ();
2017-03-16 16:39:40 +01:00
$pos_select -> free_result ();
2017-01-30 23:45:51 +01:00
$pos_select -> close ();
2017-01-30 21:36:44 +01:00
}
?>