5ef760db5f58989d502f151a5e940fc8f3b722b9
[freeside.git] / FS / FS / Misc / DateTime.pm
1 package FS::Misc::DateTime;
2
3 use base qw( Exporter );
4 use vars qw( @EXPORT_OK );
5 use POSIX;
6 use Carp;
7 use Date::Parse;
8 use DateTime::Format::Natural;
9 use FS::Conf;
10
11 @EXPORT_OK = qw( parse_datetime day_end );
12
13 =head1 NAME
14
15 FS::Misc::DateTime - Date and time subroutines
16
17 =head1 SYNOPSIS
18
19 use FS::Misc::DateTime qw( parse_datetime );
20
21 =head1 SUBROUTINES
22
23 =over 4
24
25 =item parse_datetime STRING
26
27 Parses a date (and possibly time) from the supplied string and returns
28 the date as an integer UNIX timestamp.
29
30 =cut
31
32 sub parse_datetime {
33   my $string = shift;
34   return '' unless $string =~ /\S/;
35
36   my $conf = new FS::Conf;
37   my $format = $conf->config('date_format') || '%m/%d/%Y';
38
39   if ( $format eq '%d/%m/%Y' ) { #  =~ /\%d.*\%m/ ) {
40     #$format =~ s/\%//g;
41     my $parser = DateTime::Format::Natural->new( 'time_zone' => 'local',
42                                                  #'format'=>'d/m/y',#lc($format)
43                                                );
44     $dt = $parser->parse_datetime($string);
45     if ( $parser->success ) {
46       return $dt->epoch;
47     } else {
48       #carp "WARNING: can't parse date: ". $parser->error;
49       #return '';
50       #huh, very common, we still need the "partially" (fully enough for our purposes) parsed date.
51       $dt->epoch;
52     }
53   } else {
54     return str2time($string);
55   }
56   
57 }
58
59 =item day_end TIME
60
61 Parses TIME as an integer UNIX timestamp and returns a new timestamp with the
62 same date but 23:59:59 for the time.
63
64 =cut
65
66 sub day_end {
67     my $time = shift;
68
69     my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =
70         localtime($time);
71     mktime(59,59,23,$mday,$mon,$year,$wday,$yday,$isdst);
72 }
73
74 =back
75
76 =head1 BUGS
77
78 =cut
79
80 1;