Uname: Linux web3.us.cloudlogin.co 5.10.226-xeon-hst #2 SMP Fri Sep 13 12:28:44 UTC 2024 x86_64
Software: Apache
PHP version: 8.1.31 [ PHP INFO ] PHP os: Linux
Server Ip: 162.210.96.117
Your Ip: 3.144.163.15
User: edustar (269686) | Group: tty (888)
Safe Mode: OFF
Disable Function:
NONE

name : Vendor.pm
package Net::Amazon::S3::Vendor;
$Net::Amazon::S3::Vendor::VERSION = '0.991';
use Moose 0.85;

# ABSTRACT: Base class for vendor specific behaviour

has host                    => (
	is          => 'ro',
	isa         => 'Str',
	required    => 1,
);

has authorization_method    => (
	is          => 'ro',
	isa         => 'Str',
	lazy        => 1,
	default     => sub {
		require Net::Amazon::S3::Signature::V2;
		'Net::Amazon::S3::Signature::V2',
	},
);

has use_https               => (
	is          => 'ro',
	isa         => 'Bool',
	lazy        => 1,
	default     => sub { 1 },
);

has use_virtual_host        => (
	is          => 'ro',
	isa         => 'Bool',
	lazy        => 1,
	default     => sub { $_[0]->authorization_method->enforce_use_virtual_host },
);

has default_region          => (
	is          => 'ro',
	required    => 0,
	default     => sub { 'us-east-1' },
);

has enforce_empty_content_length => (
	is          => 'ro',
	default     => sub { 1 },
);

sub guess_bucket_region {
	my ($self, $bucket) = @_;

	return $self->default_region;
}

1;

__END__

=pod

=encoding UTF-8

=head1 NAME

Net::Amazon::S3::Vendor - Base class for vendor specific behaviour

=head1 VERSION

version 0.991

=head1 SYNOPSIS

	# use it with Amazon AWS
	my $s3 = Net::Amazon::S3->new (
		vendor => Net::Amazon::S3::Vendor::Amazon->new,
		...,
	);

	# or build your own vendor description
	my $vendor = Net::Amazon::S3::Vendor::Generic->new (
		host                 => 'my.s3.service',
		use_https            => 1,
		use_virtual_host     => 1,
		authorization_method => 'Net::Amazon::S3::Signature::V2',
	);

	# or
	my $vendor = Net::Amazon::S3::Vendor::Generic->new (
		host                 => 'my.s3.service',
		use_https            => 1,
		use_virtual_host     => 1,
		authorization_method => 'Net::Amazon::S3::Signature::V4',
		default_region       => '...',
	);

	# and construct your s3 connection
	my $s3 = Net::Amazon::S3->new (
		vendor => $vendor,
		...
	);

=head1 DESCRIPTION

S3 protocol is used not only by Amazon AWS but by many other object-storage services.
They provide same API, but it's just there's a little difference.

Examples?

Allright, you can upload file but other provider does not support multipart uploads.

Or although some providers support Signature V4 they may not support HEAD bucket request
to fetch it automatically.

=head2 Properties

=head3 host

Required, where service is located.

Available here so one can move its parameters into its own vendor class.

=head3 authorization_method

Default: L<< Net::Amazon::S3::Signature::V2 >>

Signature class used to authorize requests.

=head3 use_https

Default: true.

Whether to use HTTPS or not.

=head3 use_virtual_host

Default: whatever C<authorization_method> enforces

Whether to use path or virtual host access style.
Path style uses single host with bucket contained in uri path whereas virtual host style
use bucket specific virtual hosts.

=head3 default_region

Default: undef

Value that C<guess_bucket_region> will return.

Use when your provider doesn't support HEAD region request but uses Signature V4 authorization
method.

=head2 Methods

=head3 guess_bucket_region ($bucket)

Returns bucket's region

=head1 AUTHOR

Branislav ZahradnĂ­k <barney@cpan.org>

=head1 COPYRIGHT AND LICENSE

This software is copyright (c) 2022 by Amazon Digital Services, Leon Brocard, Brad Fitzpatrick, Pedro Figueiredo, Rusty Conover, Branislav ZahradnĂ­k.

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
© 2025 GrazzMean