NAME
    DateTime::Format::PDF - PDF DateTime Parser and Formatter.

SYNOPSIS
     use DateTime::Format::PDF;

     my $obj = DateTime::Format::PDF->new;
     my $dt = $obj->parse_datetime($pdf_date);
     my $pdf_date = $obj->format_datetime($dt);

DESCRIPTION
    This module understands the formats used by PDF file. It can be used to
    parse these formats in order to create DateTime objects, and it can take
    a DateTime object and produce a string representing it in a format
    accepted by PDF.

METHODS
  "new"
     my $obj = DateTime::Format::PDF->new(%params);

    Constructor.

    Returns instance of object.

  "parse_datetime"
     my $dt = $obj->parse_datetime($pdf_date);

    Parse PDF datetime string.

    Possible valid strings:

    "D:YYYY"
    "D:YYYYMM"
    "D:YYYYMMDD"
    "D:YYYYMMDDHH"
    "D:YYYYMMDDHHmm"
    "D:YYYYMMDDHHmmSS"
    "D:YYYYMMDDHHmmSSZ"
    "D:YYYYMMDDHHmmSSOHHmm"
    "D:YYYYMMDDHHmmSSOHH'mm"
    "D:YYYYMMDDHHmmSSOHH'mm'"
    "D:YYYYMMDDHHmmSSOHHmm'"

    Returns DateTime object.

  "format_datetime"
     my $pdf_date = $obj->format_datetime($dt);

    Format DateTime object to PDF datetime string. Output value is
    "D:YYYYMMDDHHmmSSOHHmm".

    Returns string.

ERRORS
     format_datetime():
             Bad DateTime object.
                     Value: %s

     parse_datetime():
             Invalid date format: %s

EXAMPLE1
     use strict;
     use warnings;

     use DateTime::Format::PDF;

     # Object.
     my $obj = DateTime::Format::PDF->new;

     # Parse date.
     my $dt = $obj->parse_datetime("D:20240401084337-01'30");

     # Print out.
     print $dt->strftime("%a, %d %b %Y %H:%M:%S %z")."\n";

     # Output like:
     # Mon, 01 Apr 2024 08:43:37 -0130

EXAMPLE2
     use strict;
     use warnings;

     use DateTime;
     use DateTime::Format::PDF;

     # Object.
     my $obj = DateTime::Format::PDF->new;

     # Example date.
     my $dt = DateTime->now;

     # Format.
     my $pdf_date = $obj->format_datetime($dt);

     # Print out.
     print "PDF date: $pdf_date\n";

     # Output like:
     # PDF date: D:20240401084337+0000

EXAMPLE3
     use strict;
     use warnings;

     use DateTime::Format::PDF;
     use PDF::Builder;

     if (@ARGV < 1) {
             print STDERR "Usage: $0 pdf_file\n";
             exit 1;
     }
     my $pdf_file = $ARGV[0];

     # Open file.
     my $pdf = PDF::Builder->open($pdf_file);

     # Parser.
     my $pdf_date_parser = DateTime::Format::PDF->new;

     my ($dt_created, $dt_modified);
     my $print_format = "%a, %d %b %Y %H:%M:%S %z";
     if (defined $pdf->created) {
             $dt_created = $pdf_date_parser->parse_datetime($pdf->created);
             print "Created: ".$dt_created->strftime($print_format)."\n";
     }
     if (defined $pdf->modified) {
             $dt_modified = $pdf_date_parser->parse_datetime($pdf->modified);
             print "Modified: ".$dt_modified->strftime($print_format)."\n";
     }

     # Output:
     # Created: Fri, 15 May 2009 08:40:48 +0200
     # Modified: Fri, 15 May 2009 08:44:00 +0200

EXAMPLE4
     use strict;
     use warnings;

     use DateTime::Format::PDF;
     use PDF::API2;

     if (@ARGV < 1) {
             print STDERR "Usage: $0 pdf_file\n";
             exit 1;
     }
     my $pdf_file = $ARGV[0];

     # Open file.
     my $pdf = PDF::API2->open($pdf_file);

     # Get meta info.
     my %meta = $pdf->info;

     # Parser.
     my $pdf_date_parser = DateTime::Format::PDF->new;

     my ($dt_created, $dt_modified);
     my $print_format = "%a, %d %b %Y %H:%M:%S %z";
     if (exists $meta{'CreationDate'}) {
             $dt_created = $pdf_date_parser->parse_datetime($meta{'CreationDate'});
             print "Created: ".$dt_created->strftime($print_format)."\n";
     }
     if (exists $meta{'ModDate'}) {
             $dt_modified = $pdf_date_parser->parse_datetime($meta{'ModDate'});
             print "Modified: ".$dt_modified->strftime($print_format)."\n";
     }

     # Output:
     # Created: Fri, 15 May 2009 08:40:48 +0200
     # Modified: Fri, 15 May 2009 08:44:00 +0200

DEPENDENCIES
    DateTime::Format::Builder, Error::Pure, Scalar::Util.

REPOSITORY
    <https://github.com/michal-josef-spacek/DateTime-Format-PDF>

AUTHOR
    Michal Josef Špaček <mailto:skim@cpan.org>

    <http://skim.cz>

LICENSE AND COPYRIGHT
    © 2024 Michal Josef Špaček

    BSD 2-Clause License

VERSION
    0.02