Blob Blame History Raw
package Lufi::Command::sqliteToOtherDB;
use Mojo::Base 'Mojolicious::Command';
use Lufi::DB::BreakingChange;
use Lufi::DB::File;
use Lufi::DB::Slice;
use Lufi::DB::Invitation;
use Mojo::SQLite;
use FindBin qw($Bin);
use Term::ProgressBar;
use Lufi::DefaultConfig qw($default_config);

has description => 'Migrate the records from a SQLite db to the currently configured database';
has usage       => sub { shift->extract_usage };

sub run {
    my $c = shift;

    my $cfile = Mojo::File->new($Bin, '..' , 'lufi.conf');
    if (defined $ENV{MOJO_CONFIG}) {
        $cfile = Mojo::File->new($ENV{MOJO_CONFIG});
        unless (-e $cfile->to_abs) {
            $cfile = Mojo::File->new($Bin, '..', $ENV{MOJO_CONFIG});
        }
    }
    my $config = $c->app->plugin('Config', {
        file    => $cfile,
        default => $default_config
    });

    if ($config->{dbtype} eq 'sqlite') {
        say 'Please configure `dbtype` to something else than `sqlite` to use this command.';
        print $c->usage;
        exit 1;
    }

    my $sqlite      = Mojo::SQLite->new('sqlite:'.$config->{db_path});
    my $files       = $sqlite->db->select('files', undef)->hashes;
    my $slices      = $sqlite->db->select('slices', undef)->hashes;
    my $invitations = $sqlite->db->select('invitations', undef)->hashes;
    my $changes     = $sqlite->db->select('breakingchanges', undef)->hashes;

    my $progress = Term::ProgressBar->new({count => $files->size + $slices->size + $invitations->size + $changes->size});

    $files->each(sub {
        my ($file, $num) = @_;

        $progress->update();

        Lufi::DB::File->new(app => $c->app)
                      ->short($file->{short})
                      ->deleted($file->{deleted})
                      ->mediatype($file->{mediatype})
                      ->filename($file->{filename})
                      ->filesize($file->{filesize})
                      ->counter($file->{counter})
                      ->delete_at_first_view($file->{delete_at_first_view})
                      ->delete_at_day($file->{delete_at_day})
                      ->created_at($file->{created_at})
                      ->created_by($file->{created_by})
                      ->last_access_at($file->{last_access_at})
                      ->mod_token($file->{mod_token})
                      ->nbslices($file->{nbslices})
                      ->complete($file->{complete})
                      ->passwd($file->{passwd})
                      ->abuse($file->{abuse})
                      ->write();
    });
    $slices->each(sub {
        my ($slice, $num) = @_;

        Lufi::DB::Slice->new(app => $c->app)
                      ->short($slice->{short})
                      ->j($slice->{j})
                      ->write();

        $progress->update();
    });
    $invitations->each(sub {
        my ($invitation, $num) = @_;

        Lufi::DB::Invitation->new(app => $c->app)
                            ->token($invitation->{token})
                            ->ldap_user($invitation->{ldap_user})
                            ->ldap_user_mail($invitation->{ldap_user_mail})
                            ->guest_mail($invitation->{guest_mail})
                            ->created_at($invitation->{created_at})
                            ->expire_at($invitation->{expire_at})
                            ->files_sent_at($invitation->{files_sent_at})
                            ->expend_expire_at($invitation->{expend_expire_at})
                            ->files($invitation->{files})
                            ->show_in_list($invitation->{show_in_list})
                            ->deleted($invitation->{deleted})
                            ->write();
        $progress->update();
    });
    $changes->each(sub {
        my ($change, $num) = @_;

        Lufi::DB::BreakingChange->new(app => $c->app)
                                ->change($change->{change})
                                ->ack($change->{ack})
                                ->write();
        $progress->update();
    });
}

=encoding utf8

=head1 NAME

Lufi::Command::sqliteToOtherDB Migrate the records from a SQLite db to the currently configured database

=head1 SYNOPSIS

  Usage: script/lufi sqliteToOtherDB

  This command needs you to:
    - set `db_path` in your config file (otherwise, it will use the default path, `lufi.db` to migrate data from)
    - set `dbtype` to an other database type in your config file
    - configure the other database access in your config file

=cut

1;