Server IP : 103.119.228.120 / Your IP : 18.225.56.79 Web Server : Apache System : Linux v8.techscape8.com 3.10.0-1160.119.1.el7.tuxcare.els2.x86_64 #1 SMP Mon Jul 15 12:09:18 UTC 2024 x86_64 User : nobody ( 99) PHP Version : 5.6.40 Disable Function : shell_exec,symlink,system,exec,proc_get_status,proc_nice,proc_terminate,define_syslog_variables,syslog,openlog,closelog,escapeshellcmd,passthru,ocinum cols,ini_alter,leak,listen,chgrp,apache_note,apache_setenv,debugger_on,debugger_off,ftp_exec,dl,dll,myshellexec,proc_open,socket_bind,proc_close,escapeshellarg,parse_ini_filepopen,fpassthru,exec,passthru,escapeshellarg,escapeshellcmd,proc_close,proc_open,ini_alter,popen,show_source,proc_nice,proc_terminate,proc_get_status,proc_close,pfsockopen,leak,apache_child_terminate,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,dl,symlink,shell_exec,system,dl,passthru,escapeshellarg,escapeshellcmd,myshellexec,c99_buff_prepare,c99_sess_put,fpassthru,getdisfunc,fx29exec,fx29exec2,is_windows,disp_freespace,fx29sh_getupdate,fx29_buff_prepare,fx29_sess_put,fx29shexit,fx29fsearch,fx29ftpbrutecheck,fx29sh_tools,fx29sh_about,milw0rm,imagez,sh_name,myshellexec,checkproxyhost,dosyayicek,c99_buff_prepare,c99_sess_put,c99getsource,c99sh_getupdate,c99fsearch,c99shexit,view_perms,posix_getpwuid,posix_getgrgid,posix_kill,parse_perms,parsesort,view_perms_color,set_encoder_input,ls_setcheckboxall,ls_reverse_all,rsg_read,rsg_glob,selfURL,dispsecinfo,unix2DosTime,addFile,system,get_users,view_size,DirFiles,DirFilesWide,DirPrintHTMLHeaders,GetFilesTotal,GetTitles,GetTimeTotal,GetMatchesCount,GetFileMatchesCount,GetResultFiles,fs_copy_dir,fs_copy_obj,fs_move_dir,fs_move_obj,fs_rmdir,SearchText,getmicrotime MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /usr/local/ssl/local/ssl/local/ssl/local/ssl/local/ssl/local/share/perl5/Email/Date/ |
Upload File : |
use 5.006; use strict; use warnings; package Email::Date::Format; # ABSTRACT: produce RFC 2822 date strings $Email::Date::Format::VERSION = '1.005'; our @EXPORT_OK = qw[email_date email_gmdate]; use Exporter 5.57 'import'; use Time::Local (); #pod =head1 SYNOPSIS #pod #pod use Email::Date::Format qw(email_date); #pod #pod my $header = email_date($date->epoch); #pod #pod Email::Simple->create( #pod header => [ #pod Date => $header, #pod ], #pod body => '...', #pod ); #pod #pod =head1 DESCRIPTION #pod #pod This module provides a simple means for generating an RFC 2822 compliant #pod datetime string. (In case you care, they're not RFC 822 dates, because they #pod use a four digit year, which is not allowed in RFC 822.) #pod #pod =func email_date #pod #pod my $date = email_date; # now #pod my $date = email_date( time - 60*60 ); # one hour ago #pod #pod C<email_date> accepts an epoch value, such as the one returned by C<time>. #pod It returns a string representing the date and time of the input, as #pod specified in RFC 2822. If no input value is provided, the current value #pod of C<time> is used. #pod #pod C<email_date> is exported only if requested. #pod #pod =func email_gmdate #pod #pod my $date = email_gmdate; #pod #pod C<email_gmdate> is identical to C<email_date>, but it will return a string #pod indicating the time in Greenwich Mean Time, rather than local time. #pod #pod C<email_gmdate> is exported only if requested. #pod #pod =cut sub _tz_diff { my ($time) = @_; my $diff = Time::Local::timegm(localtime $time) - Time::Local::timegm(gmtime $time); my $direc = $diff < 0 ? '-' : '+'; $diff = abs $diff; my $tz_hr = int( $diff / 3600 ); my $tz_mi = int( $diff / 60 - $tz_hr * 60 ); return ($direc, $tz_hr, $tz_mi); } sub _format_date { my ($local) = @_; sub { my ($time) = @_; $time = time unless defined $time; my ($sec, $min, $hour, $mday, $mon, $year, $wday) = $local ? (localtime $time) : (gmtime $time); my $day = (qw[Sun Mon Tue Wed Thu Fri Sat])[$wday]; my $month = (qw[Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec])[$mon]; $year += 1900; my ($direc, $tz_hr, $tz_mi) = $local ? _tz_diff($time) : ('+', 0, 0); sprintf "%s, %d %s %d %02d:%02d:%02d %s%02d%02d", $day, $mday, $month, $year, $hour, $min, $sec, $direc, $tz_hr, $tz_mi; } } BEGIN { *email_date = _format_date(1); *email_gmdate = _format_date(0); }; 1; __END__ =pod =encoding UTF-8 =head1 NAME Email::Date::Format - produce RFC 2822 date strings =head1 VERSION version 1.005 =head1 SYNOPSIS use Email::Date::Format qw(email_date); my $header = email_date($date->epoch); Email::Simple->create( header => [ Date => $header, ], body => '...', ); =head1 DESCRIPTION This module provides a simple means for generating an RFC 2822 compliant datetime string. (In case you care, they're not RFC 822 dates, because they use a four digit year, which is not allowed in RFC 822.) =head1 FUNCTIONS =head2 email_date my $date = email_date; # now my $date = email_date( time - 60*60 ); # one hour ago C<email_date> accepts an epoch value, such as the one returned by C<time>. It returns a string representing the date and time of the input, as specified in RFC 2822. If no input value is provided, the current value of C<time> is used. C<email_date> is exported only if requested. =head2 email_gmdate my $date = email_gmdate; C<email_gmdate> is identical to C<email_date>, but it will return a string indicating the time in Greenwich Mean Time, rather than local time. C<email_gmdate> is exported only if requested. =head1 AUTHORS =over 4 =item * Casey West =item * Ricardo SIGNES <rjbs@cpan.org> =back =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2004 by Casey West. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. =cut