package Fey::Meta::HasOne::ViaSelect; use strict; use warnings; our $VERSION = '0.30'; use Moose; use MooseX::StrictConstructor; extends 'Fey::Meta::HasOne'; has 'select' => ( is => 'ro', does => 'Fey::Role::SQL::ReturnsData', required => 1, ); has 'bind_params' => ( is => 'ro', isa => 'CodeRef', ); # Since we don't know the content of the SQL, we just assume it can # undef sub _build_allows_undef { return 1; } sub _make_subref { my $self = shift; my $foreign_table = $self->foreign_table(); my $select = $self->select(); my $bind = $self->bind_params(); # XXX - this is really similar to # Fey::Object::Table->_get_column_values() and needs some serious # cleanup. return sub { my $self = shift; my $dbh = $self->_dbh($select); my $sth = $dbh->prepare( $select->sql($dbh) ); $sth->execute( $bind ? $self->$bind() : () ); my %col_values; $sth->bind_columns( \( @col_values{ @{ $sth->{NAME} } } ) ); my $fetched = $sth->fetch(); $sth->finish(); return unless $fetched; $self->meta()->ClassForTable($foreign_table)->new ( %col_values, _from_query => 1 ); }; } no Moose; __PACKAGE__->meta()->make_immutable(); 1; __END__ =head1 NAME Fey::Meta::HasOne::ViaSelect - A parent for has-one metaclasses based on a query object =head1 DESCRIPTION This class implements a has-one relationship for a class, based on a provided (or deduced) query object. =head1 CONSTRUCTOR OPTIONS This class accepts the following constructor options: =over 4 =item * select An object which does the L role. This query defines the relationship between the tables. =item * bind_params An optional subroutine reference which will be called when the SQL is executed. It is called as a method on the object of this object's associated class. =item * allows_undef This defaults to true. =back =head1 METHODS Besides the methods inherited from L, it also provides the following methods: =head2 $ho->select() Corresponds to the value passed to the constructor. =head2 $ho->bind_params() Corresponds to the value passed to the constructor. =head1 AUTHOR Dave Rolsky, =head1 BUGS See L for details. =head1 COPYRIGHT & LICENSE Copyright 2006-2009 Dave Rolsky, All Rights Reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. The full text of the license can be found in the LICENSE file included with this module. =cut