Viewing File: /usr/local/cpanel/3rdparty/perl/536/cpanel-lib/Crypt/Perl/X509/Extension/subjectAltName.pm

package Crypt::Perl::X509::Extension::subjectAltName;

use strict;
use warnings;

=encoding utf-8

=head1 NAME

Crypt::Perl::X509::Extension::subjectAltName - X.509 subjectAltName extension

=head1 SYNOPSIS

    my $san = Crypt::Perl::X509::Extension::subjectAltName->new(
        [ dNSName => 'foo.com' ],
        [ dNSName => 'bar.com' ],
        [ rfc822Name => 'haha@tld.com' ],
    );

=head1 DESCRIPTION

Instances of this class represent a C<subjectAltName> extension
of an X.509 (SSL) certificate.

You probably don’t need to
instantiate this class directly; instead, you can instantiate it
implicitly by listing out arguments to
L<Crypt::Perl::PKCS10>’s constructor. See that module’s
L<SYNOPSIS|Crypt::Perl::PKCS10/SYNOPSIS> for an example.

You can also use instances of this class as arguments to
L<Crypt::Perl::PKCS10::Attribute::extensionRequest>’s constructor
to include a request for a C<subjectAltName> extension in a PKCS #10
Certificate Signing Request.

=head1 SEE ALSO

L<https://tools.ietf.org/html/rfc5280#section-4.2.1.6>

=cut

use parent qw(
    Crypt::Perl::X509::Extension
    Crypt::Perl::X509::GeneralNames
);

use Crypt::Perl::X509::GeneralNames ();

use constant OID => '2.5.29.17';

use constant ASN1 => Crypt::Perl::X509::GeneralNames::ASN1() . <<END;
    subjectAltName ::= GeneralNames
END

1;
Back to Directory File Manager