Adding initial ads support.
This commit is contained in:
parent
529f5a1e43
commit
c2e1b80e1a
4
Build.PL
4
Build.PL
@ -21,6 +21,10 @@ my $build = Module::Build->new(
|
|||||||
'XML::Twig' => 0,
|
'XML::Twig' => 0,
|
||||||
'JSON' => 0,
|
'JSON' => 0,
|
||||||
'IP::Geolocation::MMDB' => 0,
|
'IP::Geolocation::MMDB' => 0,
|
||||||
|
'Moo' => 0,
|
||||||
|
'Moo::Role' => 0,
|
||||||
|
'Module::Pluggable' => 0,
|
||||||
|
'List::AllUtils' => 0,
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
$build->create_build_script;
|
$build->create_build_script;
|
||||||
|
21
lib/BurguillosInfo/Ad.pm
Normal file
21
lib/BurguillosInfo/Ad.pm
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
package BurguillosInfo::Ad;
|
||||||
|
|
||||||
|
use v5.36.0;
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use feature 'signatures';
|
||||||
|
|
||||||
|
use Moo::Role;
|
||||||
|
|
||||||
|
sub order {
|
||||||
|
return 999;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub seconds {
|
||||||
|
return 15;
|
||||||
|
}
|
||||||
|
|
||||||
|
requires 'id is_active img text';
|
||||||
|
1;
|
88
lib/BurguillosInfo/Ads.pm
Normal file
88
lib/BurguillosInfo/Ads.pm
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
package BurguillosInfo::Ads;
|
||||||
|
|
||||||
|
use v5.36.0;
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use feature 'signatures';
|
||||||
|
|
||||||
|
use List::AllUtils qw/none/;
|
||||||
|
|
||||||
|
use Moo;
|
||||||
|
use Module::Pluggable
|
||||||
|
search_path => ['BurguillosInfo::Ads'],
|
||||||
|
instantiate => 'instance',
|
||||||
|
on_require_error => sub ( $plugin, $error ) {
|
||||||
|
die $error;
|
||||||
|
};
|
||||||
|
|
||||||
|
{
|
||||||
|
my @array_ads;
|
||||||
|
|
||||||
|
sub _array ($self) {
|
||||||
|
if ( !scalar @array_ads ) {
|
||||||
|
$self->_populate_array;
|
||||||
|
}
|
||||||
|
return [@array_ads];
|
||||||
|
}
|
||||||
|
|
||||||
|
sub _populate_array ($self) {
|
||||||
|
@array_ads = $self->plugins();
|
||||||
|
for my $ad (@array_ads) {
|
||||||
|
$self->_check_ad_valid($ad);
|
||||||
|
}
|
||||||
|
@array_ads = sort { $self->_order_two_ads( $a, $b ); } @array_ads;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sub _order_two_ads ( $self, $a, $b ) {
|
||||||
|
my $by_order = $a->order <=> $b->order;
|
||||||
|
if ($by_order) {
|
||||||
|
return $by_order;
|
||||||
|
}
|
||||||
|
my $by_alpha = $a->id cmp $b->id;
|
||||||
|
return $by_alpha;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub get_next ( $self, $current_ad_number = undef ) {
|
||||||
|
my $array = $self->_array;
|
||||||
|
if ( !scalar @$array
|
||||||
|
|| none { $_->is_active } @$array )
|
||||||
|
{
|
||||||
|
return { continue => 0, current_ad_number => undef };
|
||||||
|
}
|
||||||
|
if ( !defined $current_ad_number ) {
|
||||||
|
$current_ad_number = 0;
|
||||||
|
}
|
||||||
|
my $ad = $array->[$current_ad_number];
|
||||||
|
if ( !$ad->is_active ) {
|
||||||
|
return $self->get_next( $self->_get_next_number($current_ad_number) );
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
ad => $ad,
|
||||||
|
continue => 1,
|
||||||
|
current_ad_number => $self->_get_next_number($current_ad_number),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
sub _get_next_number ( $self, $current_ad_number = undef ) {
|
||||||
|
my $array = $self->_array;
|
||||||
|
if ( !scalar @$array ) {
|
||||||
|
return undef;
|
||||||
|
}
|
||||||
|
if ( !defined $current_ad_number ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if ( ++$current_ad_number > ( scalar @$array ) - 1 ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return $current_ad_number;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub _check_ad_valid ( $self, $ad ) {
|
||||||
|
if ( !$ad->does('BurguillosInfo::Ad') ) {
|
||||||
|
die "$ad does not implement BurguillosInfo::Ad.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
1;
|
Loading…
Reference in New Issue
Block a user