package Metabase::User::Profile; use 5.006; use strict; use warnings; our $VERSION = '0.001'; $VERSION = eval $VERSION; ## no critic use Carp; use JSON; use Data::GUID guid_string => { -as => '_guid' }; use base 'Metabase::Report'; __PACKAGE__->load_fact_classes; #--------------------------------------------------------------------------# # public API #--------------------------------------------------------------------------# sub create { my ($class, @args) = @_; my $args = $class->__validate_args( \@args, { full_name => 1, email_address => 1, secret => 1, } ); my $profile = $class->open( # placeholder guid in resource resource => "metabase:user:00000000-0000-0000-0000-000000000000", ); # fix-up our resource string to refer to our assigned guid $profile->{metadata}{core}{resource} = [ '//str' => "metabase:user:" . $profile->guid ]; # add facts $profile->add( 'Metabase::User::FullName' => $args->{full_name} ); $profile->add( 'Metabase::User::EmailAddress' => $args->{email_address} ); $profile->add( 'Metabase::User::Secret' => $args->{secret} ); $profile->close; return $profile; } sub save { my ($self, $filename ) = @_; open my $fh, ">", $filename or Carp::confess "Error saving profile: $!"; print {$fh} JSON->new->encode( $self->as_struct ); close $fh; return 1; } sub load { my ($class, $filename) = @_; open my $fh, "<", $filename or Carp::confess "Error loading profile: $!"; my $string = do { local $/; <$fh> }; close $fh; return $class->from_struct( JSON->new->decode( $string ) ); } #--------------------------------------------------------------------------# # internals #--------------------------------------------------------------------------# # XXX: Maybe we also want validate_other crap or just validate. # -- rjbs, 2009-03-30 sub validate_content { my ($self) = @_; my ($guid) = $self->resource =~ m{^metabase:user:(.+)$}; Carp::confess "resource guid differs from fact guid" if $guid ne $self->guid; $self->SUPER::validate_content; } sub report_spec { return { 'Metabase::User::EmailAddress' => '1+', 'Metabase::User::FullName' => '1', 'Metabase::User::Secret' => '1', } } 1; __END__ =head1 NAME Metabase::User::Profile - Metabase report class for user-related facts =head1 SYNOPSIS use Metabase::User::Profile; my $profile = Metabase::User::Profile->create( full_name => 'John Doe', email_address => 'jdoe@example.com', secret => 'aixuZuo8', ); =head1 DESCRIPTION Metabase report class encapsulating Facts about a metabase user =head1 USAGE =head2 The short way my $profile = Metabase::User::Profile->create( full_name => 'John Doe', email_address => 'jdoe@example.com', secret => 'aixuZuo8', ); =head2 The long way my $profile = Metabase::User::Profile->open( resource => 'metabase:user:B66C7662-1D34-11DE-A668-0DF08D1878C0' ); $profile->add( 'Metabase::User::EmailAddress' => 'jdoe@example.com' ); $profile->add( 'Metabase::User::FullName' => 'John Doe' ); $profile->add( 'Metabase::User::Secret' => 'aixuZuo8' ); $profile->close; =head1 METHODS =head2 create my $new_profile = Metabase::User::Profile->create(%arg); This method creates a new user profile object from the given parameters. Valid parameters include: full_name - the user's full name email_address - the user's email address secret - the shared secret to use for authentication =head2 load my $profile = Metabase::User::Profile->load($filename); This method loads a profile from disk and returns it. =head2 save $profile->save($filename); This method writes out the profile to a file. If the file cannot be written, an exception is raised. If the save is successful, a true value is returned. =head1 BUGS Please report any bugs or feature using the CPAN Request Tracker. Bugs can be submitted through the web interface at L 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. =head1 AUTHOR =over =item * David A. Golden (DAGOLDEN) =back =head1 COPYRIGHT AND LICENSE Copyright (c) 2009 by David A. Golden Licensed under the same terms as Perl itself (the "License"). You may not use this file except in compliance with the License. A copy of the License was distributed with this file or you may obtain a copy of the License from http://dev.perl.org/licenses/ Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. =cut