| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- #!/usr/bin/perl
- #
- # Copyright (C) Roman Dmitiriev, rnd@rajven.ru
- #
- #Обновляем БД устрйств
- use FindBin '$Bin';
- use lib "$Bin/";
- use Data::Dumper;
- use Rstat::config;
- use Rstat::main;
- use Rstat::mysql;
- use Rstat::net_utils;
- use strict;
- use warnings;
- print "Stage 0: Read system devices\n";
- my @user_devices=();
- if (-e "system-devs.csv") {
- my @nSQL=read_file("system-devs.csv");
- foreach my $row (@nSQL) {
- my ($dev_id,$dev_model,$dev_vendor) = split(/;/,$row);
- my $device;
- $device->{id}=$dev_id;
- $device->{model_name}=$dev_model;
- $device->{vendor_id}=$dev_vendor;
- push(@user_devices,$device);
- }
- }
- print "Stage 1: Read system vendors\n";
- my @user_vendors=();
- if (-e "system-vendors.csv") {
- my @nSQL=read_file("system-vendors.csv");
- foreach my $row (@nSQL) {
- my ($vendor_id,$vendor_name) = split(/;/,$row);
- my $vendor;
- $vendor->{id}=$vendor_id;
- $vendor->{name}=$vendor_name;
- push(@user_vendors,$vendor);
- }
- }
- print "Done!\n";
- my %vendor_migration;
- print "Import Vendors\n";
- foreach $vendor (@user_vendors) {
- #seach exists vendor
- my $vendor_exist = get_record_sql($dbh,"SELECT * FROM vendors WHERE LOWER(name)='".lc(trim($vendor->{name}))."'");
- if ($vendor_exist) {
- next if ($vendor_exist->{id} = $vendor->{id});
- do_sql($dbh,"UPDATE vendors SET id=".$vendor->{id}." WHERE id=".$vendor_exist->{id});
- do_sql($dbh,"UPDATE device_models SET vendor_id=".$vendor->{id}." WHERE vendor_id=".$vendor_exist->{id});
- do_sql($dbh,"UPDATE devices SET vendor_id=".$vendor->{id}." WHERE vendor_id=".$vendor_exist->{id});
- next;
- }
- print "id: $vendor->{name} Migrated.\n";
- insert_record($dbh,"vendors",$vendor);
- }
- print "Done!\n";
- print "Import devices\n";
- foreach $device (@user_devices) {
- #seach exists device
- my $device_exist = get_record_sql($dbh,"SELECT * FROM device_models WHERE vendor_id=".$device->{vendor_id}." AND LOWER(model_name)='".lc(trim($device->{model_name}))."'");
- if ($device_exist) {
- next if ($device_exist->{id} = $device->{id});
- do_sql($dbh,"UPDATE device_models SET id=".$device->{id}." WHERE id=".$device_exist->{id});
- do_sql($dbh,"UPDATE devices SET device_model_id=".$device->{id}." WHERE device_model_id=".$device_exist->{id});
- next;
- }
- print "id: $device->{model_name} Migrated.\n";
- insert_record($dbh,"device_models",$device);
- }
- print "Done!\n";
- exit;
|