The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#!/usr/bin/perl;

use strict;
use warnings;

use lib '../../lib';

use OpenID::Lite::RelyingParty::Discover::Service;
use OpenID::Lite::RelyingParty::Discover;
use OpenID::Lite::Identifier;
use OpenID::Lite::RelyingParty::Associator;
use OpenID::Lite::Constants::AssocType qw(:all);
use OpenID::Lite::Constants::SessionType qw(:all);
use OpenID::Lite::RelyingParty::CheckIDRequest;

use Data::Dump qw(dump);
use Perl6::Say;
use MIME::Base64;
use LWP::UserAgent;

my $service = OpenID::Lite::RelyingParty::Discover::Service->new(
    claimed_identifier => "=!9978.5647.C6FA.BD12",
    types              => [
        "http://openid.net/extensions/sreg/1.1",
        "http://openid.net/signon/1.0",
    ],
    uris => ["https://linksafe.ezibroker.net/server/"],
);

my $assoc = OpenID::Lite::RelyingParty::Associator->new(
    assoc_type   => HMAC_SHA1,
    session_type => NO_ENCRYPTION,
    agent => LWP::UserAgent->new,
    #    session_type => DH_SHA1,
);
my $association = $assoc->associate($service)
    or die $assoc->errstr;
say sprintf q{ASSOC_TYPE:   %s}, $association->type;
say sprintf q{ASSOC_HANDLE: %s}, $association->handle;
say sprintf q{EXPIRATION:   %s}, $association->expires_at;
say sprintf q{SECRET:       %s},
    MIME::Base64::encode_base64( $association->secret );

my $req = OpenID::Lite::RelyingParty::CheckIDRequest->new(
    service     => $service,
    association => $association,
);

my $url = $req->redirect_url(
    realm     => q{http://example.com},
    return_to => q{http://example.com/return_to},
);
say $url;