upgrade-to-2.4.pl 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. #!/usr/bin/perl
  2. #
  3. # Copyright (C) Roman Dmitiriev, rnd@rajven.ru
  4. #
  5. use utf8;
  6. use FindBin '$Bin';
  7. use lib "$Bin/";
  8. use Data::Dumper;
  9. use Rstat::config;
  10. use Rstat::main;
  11. use Rstat::mysql;
  12. use Rstat::net_utils;
  13. use strict;
  14. use warnings;
  15. #$default_user_id; id=20
  16. my $default_user_id=get_option($dbh,20) || 1;
  17. my $hotspot_user_id=get_option($dbh,43) || 1;
  18. print "Stage 1: Migrate users\n";
  19. #find user with few ip
  20. my @user_list = get_records_sql($dbh,"SELECT L.id, COUNT(A.id) as a_count FROM User_list AS L, User_auth AS A WHERE L.id = A.user_id and A.deleted=0 GROUP BY A.user_id");
  21. #create user for
  22. foreach my $row (@user_list) {
  23. next if ($row->{a_count} <=1);
  24. my @auth_list = get_records_sql($dbh,"SELECT * FROM User_auth WHERE user_id=$row->{id} and deleted=0 GROUP BY mac");
  25. next if (scalar(@auth_list)<=1);
  26. for (my $i=1; $i < scalar(@auth_list); $i++) {
  27. my $new_user;
  28. $new_user->{ou_id}=$auth_list[$i]->{ou_id};
  29. if ($default_user_ou_id = $default_hotspot_ou_id) {
  30. if ($auth_list[$i]->{user_id} == $default_user_id or $auth_list[$i]->{user_id} == $hotspot_user_id) { $new_user->{ou_id}=$default_user_ou_id; }
  31. } else {
  32. if ($default_user_id == $hotspot_user_id) {
  33. if ($auth_list[$i]->{user_id} == $default_user_id) { $new_user->{ou_id}=$default_user_ou_id; }
  34. } else {
  35. if ($auth_list[$i]->{user_id} == $default_user_id) { $new_user->{ou_id}=$default_user_ou_id; }
  36. if ($auth_list[$i]->{user_id} == $hotspot_user_id) { $new_user->{ou_id}=$default_hotspot_ou_id; }
  37. }
  38. }
  39. $new_user->{login}=mac_splitted($auth_list[$i]->{mac});
  40. $new_user->{enabled}=$auth_list[$i]->{enabled};
  41. $new_user->{filter_group_id}=$auth_list[$i]->{filter_group_id};
  42. $new_user->{queue_id}=$auth_list[$i]->{queue_id};
  43. $new_user->{day_quota}=$auth_list[$i]->{day_quota};
  44. $new_user->{month_quota}=$auth_list[$i]->{month_quota};
  45. if (!$auth_list[$i]->{comments}) {
  46. $auth_list[$i]->{comments}=$auth_list[$i]->{ip};
  47. my $user_info = get_record_sql($dbh,"SELECT * FROM User_list WHERE id=".$auth_list[$i]->{user_id});
  48. if ($user_info and $user_info->{fio}) { $auth_list[$i]->{comments} = $user_info->{fio}; }
  49. }
  50. if (!$auth_list[$i]->{dns_name}) { $auth_list[$i]->{dns_name}=''; } else {
  51. my $name_count = get_count_records($dbh,'User_list',"login='".$auth_list[$i]->{dns_name}."'");
  52. if ($name_count>0) { $name_count++; $auth_list[$i]->{dns_name}.="-".$name_count; }
  53. $new_user->{login}=$auth_list[$i]->{dns_name};
  54. }
  55. $new_user->{fio}=$auth_list[$i]->{dns_name}." ".$auth_list[$i]->{comments};
  56. my $new_id = insert_record($dbh,"User_list",$new_user);
  57. if ($new_id) {
  58. do_sql($dbh,"UPDATE User_auth SET user_id=$new_id WHERE mac='".$auth_list[$i]->{mac}."' and deleted=0");
  59. print "Created user for mac $auth_list[$i]->{mac} : $new_user->{login} and move all auth records for this mac to new user id: $new_id\n";
  60. } else {
  61. print "Error create user for ".Dumper($auth_list[$i])."\n";
  62. }
  63. }
  64. }
  65. print "Done!\n";
  66. print "Stage 2: Migrate devices\n";
  67. my @auth_devices = get_records_sql($dbh,"SELECT * FROM User_auth WHERE device_model_id>0 and deleted=0");
  68. foreach my $row (@auth_devices) {
  69. my $device = get_record_sql($dbh,"SELECT * FROM devices WHERE user_id=".$row->{user_id});
  70. next if ($device);
  71. my $device_model = get_record_sql($dbh,"SELECT * FROM device_models WHERE id=".$row->{device_model_id});
  72. next if ($device_model->{vendor_id} == 1);
  73. my $user_info = get_record_sql($dbh,"SELECT * FROM User_list WHERE id=".$row->{user_id});
  74. next if (!$user_info);
  75. my $new_dev;
  76. $new_dev->{device_name} = $user_info->{login};
  77. $new_dev->{device_type} = 5;
  78. $new_dev->{user_id} = $row->{user_id};
  79. $new_dev->{ip} = $row->{ip};
  80. $new_dev->{device_model_id} = $row->{device_model_id};
  81. $new_dev->{vendor_id}=$device_model->{vendor_id};
  82. if ($row->{comments}) { $new_dev->{comment} = $row->{comments}; }
  83. my $new_dev_id = insert_record($dbh,"devices",$new_dev);
  84. if ($new_dev_id) {
  85. print "Create device: $new_dev->{device_name} $new_dev->{ip} id: $new_dev_id\n";
  86. } else {
  87. print "Error create device: $new_dev->{device_name} $new_dev->{ip}!!!\n";
  88. }
  89. }
  90. do_sql($dbh,"UPDATE User_list SET ou_id=".$default_user_ou_id." WHERE id=".$default_user_id);
  91. do_sql($dbh,"UPDATE User_auth SET ou_id=".$default_user_ou_id." WHERE user_id=".$default_user_id);
  92. if ($default_user_id != $hotspot_user_id) {
  93. do_sql($dbh,"UPDATE User_list SET ou_id=".$default_hotspot_ou_id." WHERE id=".$hotspot_user_id);
  94. do_sql($dbh,"UPDATE User_auth SET ou_id=".$default_hotspot_ou_id." WHERE user_id=".$hotspot_user_id);
  95. }
  96. do_sql($dbh,"DELETE FROM `config_options` WHERE `config_options`.`id` = 20");
  97. do_sql($dbh,"DELETE FROM `config_options` WHERE `config_options`.`id` = 43");
  98. do_sql($dbh,"DELETE FROM `config` WHERE `config`.`option_id` = 20");
  99. do_sql($dbh,"DELETE FROM `config` WHERE `config`.`option_id` = 43");
  100. do_sql($dbh,"DELETE FROM devices WHERE deleted=1");
  101. print "Done!\n";
  102. exit;