App-Office-CMS
view release on metacpan or search on metacpan
lib/App/Office/CMS/Database/Asset.pm view on Meta::CPAN
{
my($self, $id) = @_;
$self -> log(debug => "get_asset_type_by_id($id)");
return $self -> db -> simple -> query('select * from asset_types where id = ?', $id) -> hash;
} # End of get_asset_type_by_id.
# --------------------------------------------------
sub get_asset_types
{
my($self) = @_;
$self -> log(debug => 'get_asset_types');
return [$self -> db -> simple -> query('select * from asset_types') -> hashes];
} # End of get_asset_types.
# --------------------------------------------------
sub save_asset_record
{
my($self, $context, $asset) = @_;
$self -> log(debug => "save_asset_record($context, -)");
my($table_name) = 'assets';
my(@time) = localtime;
my($time) = strftime('%Y-%m-%d %X', @time);
my(@field) = (qw/
asset_type_id
design_id
page_id
site_id
/);
my($data) = {};
for (@field)
{
$$data{$_} = $$asset{$_};
}
if ($context eq 'add')
{
$$asset{id} = $self -> db -> insert_hash_get_id($table_name, $data);
}
else
{
$self -> db -> simple -> update($table_name, $data, {id => $$asset{id} });
}
$self -> log(debug => "Saved ($context) asset with id $$asset{id}");
} # End of save_asset_record.
# --------------------------------------------------
sub update
{
my($self, $page, $asset) = @_;
$self -> log(debug => 'update()');
$self -> log(debug => '-' x 50);
$self -> log(debug => "Asset: $_ => $$asset{$_}") for sort keys %$asset;
$self -> log(debug => '-' x 50);
my($action) = $$page{exact_match} ? 'update' : 'add';
$self -> save_asset_record($action, $asset);
return ucfirst "$action asset";
} # End of update.
# --------------------------------------------------
1;
( run in 0.470 second using v1.01-cache-2.11-cpan-0bb4e1dffa6 )