NAME
    Regexp::Pattern::YouTube - Regexp patterns related to YouTube

VERSION
    This document describes version 0.005 of Regexp::Pattern::YouTube (from
    Perl distribution Regexp-Pattern-YouTube), released on 2020-08-21.

SYNOPSIS
     use Regexp::Pattern; # exports re()
     my $re = re("YouTube::channel_id");

DESCRIPTION
    Regexp::Pattern is a convention for organizing reusable regex patterns.

PATTERNS
    *   channel_id

        YouTube channel ID.

        YouTube channel ID is an encoding of 128-bit number using a custom
        base-64 character set. It's 24 characters long.

        Caveats:

        *   Like with video ID format, there's no official guarantee that
            the channel ID will always be 24 characters, or that the allowed
            character set will stay the same.

        *   This regex does not check whether a channel exists. To do that,
            you'll need to use the YouTube API.

        Examples:

        Example #1.

         "UCq-Fj5jknLsUf-MWSy4_brA" =~ re("YouTube::channel_id", {-anchor=>1});  # matches

        Incorrect length.

         "UCq-Fj5jknLsUf-MWSy4_brAx" =~ re("YouTube::channel_id", {-anchor=>1});  # DOESN'T MATCH

        Contains invalid character.

         "UCq-Fj5jknLsUf+MWSy4_brA" =~ re("YouTube::channel_id", {-anchor=>1});  # DOESN'T MATCH

    *   playlist_id

        YouTube playlist ID.

        YouTube playlist ID is an encoding of 192-bit number using a custom
        base-64 character set. It's 34 characters long.

        Caveats:

        *   Like with video and channel ID formats, there's no official
            guarantee that the playlist ID will always be 34 characters, or
            that the allowed character set will stay the same.

        *   This regex does not check whether a playlist exists. To do that,
            you'll need to use the YouTube API.

        Examples:

        Example #1.

         "PL9bw4S5ePsEHQKZ4uTtbNXNQGjjOB8bRk" =~ re("YouTube::playlist_id", {-anchor=>1});  # matches

        Incorrect length.

         "PL9bw4S5ePsEHQKZ4uTtbNXNQGjjOB8bRk-" =~ re("YouTube::playlist_id", {-anchor=>1});  # DOESN'T MATCH

        Contains invalid character.

         "PL9bw4S5ePsEHQKZ4u+tbNXNQGjjOB8bRk" =~ re("YouTube::playlist_id", {-anchor=>1});  # DOESN'T MATCH

    *   video_id

        YouTube video ID.

        YouTube video ID is an encoding of 64-bit number in a custom base-64
        character set. It's 11 characters long.

        Caveats:

        *   There's no official guarantee that the video ID will always be
            11 characters, or that the allowed character set will stay the
            same. From
            L<https://groups.google.com/d/msg/youtube-api-gdata/maM-h-zKPZc/
            PJDlDWv77TEJ>:

            "We don't make any public guarantees about the format for video
            ids. While they're currently 11 character strings that contain
            letters, numbers and some punctuation, I wouldn't recommend
            hardcoding that into your application (unless you have an easy
            way of changing it in the future)."

        *   This regex does not check whether a video exists. To do that,
            you'll need to use the YouTube API.

        Examples:

        Example #1.

         "aNAtbYSxzuA" =~ re("YouTube::video_id", {-anchor=>1});  # matches

        Incorrect length.

         "aNAtbYSxzuA-" =~ re("YouTube::video_id", {-anchor=>1});  # DOESN'T MATCH

        Contains invalid character.

         "aNAtb+SxzuA" =~ re("YouTube::video_id", {-anchor=>1});  # DOESN'T MATCH

HOMEPAGE
    Please visit the project's homepage at
    <https://metacpan.org/release/Regexp-Pattern-YouTube>.

SOURCE
    Source repository is at
    <https://github.com/perlancar/perl-Regexp-Pattern-YouTube>.

BUGS
    Please report any bugs or feature requests on the bugtracker website
    <https://rt.cpan.org/Public/Dist/Display.html?Name=Regexp-Pattern-YouTub
    e>

    When submitting a bug or request, please include a test-file or a patch
    to an existing test-file that illustrates the bug or desired feature.

SEE ALSO
    Regexp::Pattern

    Some utilities related to Regexp::Pattern: App::RegexpPatternUtils,
    rpgrep from App::rpgrep.

AUTHOR
    perlancar <perlancar@cpan.org>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2020, 2018, 2016 by perlancar@cpan.org.

    This is free software; you can redistribute it and/or modify it under
    the same terms as the Perl 5 programming language system itself.