Daje-Generate/lib/Daje/Generate/Sql/Table.pm
use v5.40;
use feature 'class';
no warnings 'experimental::class';
use Daje::Generate::Sql::Table::Fields;
use Daje::Generate::Sql::Table::Index;
use Daje::Generate::Sql::Table::ForeignKey;
use Daje::Generate::Sql::Table::Sql;
class Daje::Generate::Sql::Table :isa(Daje::Generate::Sql::Base::Common) {
method generate_table() {
my $sql = "";
my $sections = "";
my $json_arr = $self->json;
my $length = scalar @{$json_arr};
for (my $i = 0; $i < $length; $i++) {
my $json = @{$json_arr}[$i];
if (exists($json->{version})) {
if(exists($json->{version}->{tables})) {
my $tables = $json->{version}->{tables};
my $len = scalar @{$tables};
for(my $j = 0; $j < $len; $j++){
my $table = $self->shift_section($tables);
$sql .= $self->create_table_sql($table);
}
}
$sections .= $self->create_section($sql, $json->{version}->{number});
}
}
$self->set_sql($self->create_file($sections));
return ;
}
method create_file($sections) {
my $file = $self->template->get_data_section('file');
my $date = localtime();
$file =~ s/<<date>>/$date/ig;
$file =~ s/<<sections>>/$sections/ig;
return $file;
}
method create_section($sql, $number) {
my $section = $self->template->get_data_section('section');
$section =~ s/<<version>>/$number/ig;
$section =~ s/<<table>>/$sql/ig;
return $section;
}
method create_table_sql($table) {
my $result = "";
my $fields = '';
my $indexes = '';
my $foreignkeys = "";
my $sql = "";
my $name = $table->{table}->{name};
if (exists($table->{table}->{fields})) {
$fields = $self->create_fields($table->{table});
$foreignkeys = $self->create_fkeys($table->{table}, $name);
}
my $test = $table->{table}->{index};
if (exists($table->{table}->{index})) {
$indexes = $self->create_index($table->{table})
}
if (exists($table->{table}->{sql})) {
$sql = $self->create_sql($table->{table}, $name)
}
my $template = $self->fill_template($name, $fields, $foreignkeys, $indexes);
return $template;
}
method create_sql($json, $tablename) {
my $sql_stmt = Generate::Sql::Table::Sql->new(
json => $json,
template => $self->template,
tablename => $tablename,
);
my $result = $sql_stmt->create_sql();
return $result;
}
method fill_template($name, $fields, $foreignkeys, $indexes) {
my $template = $self->template->get_data_section('table');
$template =~ s/<<fields>>/$fields/ig;
$template =~ s/<<tablename>>/$name/ig;
if(exists($foreignkeys->{template_fkey})) {
$template =~ s/<<foregin_keys>>/$foreignkeys->{template_fkey}/ig;
} else {
$template =~ s/<<foregin_keys>>//ig;
}
if(exists($foreignkeys->{template_ind})) {
$indexes .= '\n' . $foreignkeys->{template_ind};
}
$template =~ s/<<tablename>>/$indexes/ig;
return $template;
}
method create_fields($json) {
my $fields = Generate::Sql::Table::Fields->new(
json => $json,
template => $self->template,
);
$fields->create_fields();
my $sql = $fields->sql;
return $sql;
}
method create_index($json) {
my $test = 1;
my $index = Generate::Sql::Table::Index->new(
json => $json,
template => $self->template,
tablename => 'users',
);
$index->create_index();
my $sql = $index->sql;
return $sql;
}
method create_fkeys($json, $table_name) {
my $foreignkeys = {};
my $foreign_key = Generate::Sql::Table::ForeignKey->new(
json => $json,
template => $self->template,
tablename => $table_name,
);
$foreign_key->create_foreign_keys();
if ($foreign_key->created() == 1) {
$foreignkeys = $foreign_key->templates();
}
return $foreignkeys;
}
}
1;
#################### pod generated by Pod::Autopod - keep this line to make pod updates possible ####################
=head1 NAME
lib::Daje::Generate::Sql::Table - lib::Daje::Generate::Sql::Table
=head1 DESCRIPTION
pod generated by Pod::Autopod - keep this line to make pod updates possible ####################
=head1 REQUIRES
L<Daje::Generate::Sql::Table::Sql>
L<Daje::Generate::Sql::Table::ForeignKey>
L<Daje::Generate::Sql::Table::Index>
L<Daje::Generate::Sql::Table::Fields>
L<feature>
L<v5.40>
=head1 METHODS
=cut