NAME
Myco::Entity::Meta::Attribute
SYNOPSIS
# Note this class is normally used only via
# Myco::Entity::Meta
## Within an entity class definition - add attribute to class
# ::Attribute's constructor should only be used via
# ::Meta's add_attribute() as shown:
my $md = Myco::Entity::Meta( name => __PACKAGE__ );
$md->add_attribute(
name => 'doneness',
type => 'int',
readonly => 0, # default is read/write
access_list => { rw => ['admin'],
ro => [qw(average_joes junior_admins)] },
tangram_options => { required => 1},
synopsis => "How you'd like your meat cooked",
syntax_msg => "correct format, please!",
values => [qw(0 1 2 3 4 5)],
value_labels => {0 => 'rare',
1 => 'medium-rare',
2 => 'medium',
3 => 'medium-well',
4 => 'well',
5 => 'charred'},
ui => { widget => [ 'popup_menu' ],
label => 'Cook until...',
},
);
## Typical post-setup usage
# ...given a Myco::Entity::Meta enabled entity object $obj
my $metadata = $obj->introspect;
# Get reference to array of ::Meta::Attribute objects for $obj's class
my $attributes = $metadata->get_attributes;
# Look up attribute's type
my $type = $attributes->{doneness}->get_type;
# Use of stored accessor coderef - set doneness = 3
$attributes->{doneness}->setval($obj, 3);
DESCRIPTION
Container for meta data describing an attribute of a Myco Entity class
COMMON ENTITY INTERFACE
Constructor, accessors, and other methods -- as inherited from Myco::Entity
ATTRIBUTES
Attributes may be initially set during object construction (with new()
) but otherwise are accessed solely through accessor methods. Typical usage:
Set attribute value
$obj->set_attributeName($value);
Check functions (see Class::Tangram) perform data validation. If there is any concern that the set method might be called with invalid data then the call should be wrapped in an
eval
block to catch exceptions that would result.Get attribute value
$value = $obj->get_attributeName;
A listing of available attributes follows:
access_list
type: hash ref
Hash containing either or both of these keys: rw, ro (for read-write, read-only, respectively). Each key corresponds to a anonymous array of names of user roles authorized for the given type of access.
getter
type: code ref
Reference to getter method of entity attribute.
name
type: string required: not empty
Name of entity attribute.
readonly
type: int (boolean)
If set to true calls to entity attribute setter will result in throwing of exception type Myco::Exception::MNI.
setter
type: code ref
Reference to setter method of entity attribute.
synopsis
type: string
Short (a few words) description of entity attribute.
tangram_options
type: hash ref
Hash of Class::Tangram entity attribute options.
template
type: int (boolean)
If set to true entity attribute is marked as a "template", meaning the following:
the entity class does not have use of this entity attribute (although its metadata definition is available)
a sub-class of this entity class will have this entity attribute added to its schema; it is added directly to the sub-class, not inherited.
type
type: string
Data type of entity attribute; must be a valid Class::Tangram data type. [required: not undef]
type_options
type: hash ref
Additional detail regarding the entity attribute data type. Valid option(s):
string_length: int
Maximum character length of string type entity attributes. During schema generation this results in the automatic addition of
sql => 'VARCHAR(#)'
to the 'tangram_options' parameter, unless that parameter already has the 'sql' option set. Also, if this entity attribute employs a textfield or password_field as a user interface (either specified via the 'ui' metadata attribute or as the default [for scalars]) then the closure generated will include
-maxlength => #
in the CGI.pm method parameter list (see below: attribute 'ui').
syntax_msg
type: string
Short (under one line) description of valid entity attribute value syntax.
values
type: array ref
Array of all valid values for this entity attribute. Use only when appropriate. By default, setting this metadata parameter results in a "popup_menu" being used as the user interface widget type, with values displayed in the order given.
Special Array Values
The special string values below may be included as members of the array to customize this entity attribute's user interface behavior. These values do NOT get stored in the entity object attribute.
__select__
Including in the array the string "__select__" will make "<Select>" appear as a popup menu choice.
__other__
If the array contains the string "__other__" then during widget generation the popup menu will include the choice "<Other>", and a text box will appear below labeled "Other:" that allows entry of an alternate value which will be used as the input value for this entity attribute if '<Other>' is selected.
__blank__
If the array contains the string "__blank__" then the popup menu will contain a blank selection at the given position.
value_labels
type: hash ref
Hash mapping entity attribute values (which should be the same as those specified with the "values" parameter) to a user visible label; for use when generating value selection user interface widget for this entity attribute.
ui
type: hash ref
{
label => 'Sprocket',
widget => ['popup_menu', -rows => 2, -columns => 2],
# etc.
}
A data structure containing instructions for generating a user interface element for this entity attribute. This data structure used in the creation of a Myco::Entity::Meta::Attribute::UI object which becomes part of the attribute metadata. Run-time access to this metadata should only occur via accessor methods.
The following hash keys (corresponding to ::Meta::Attribute::UI object attributes) are allowed:
closure
type: code ref
A reference to an anonymous subroutine capable of generating a user interface element for this entity object attribute. The subroutine is a closure and can be thought of as the compiled representation of all other user interface related metadata (values, value_labels, ui->widget, ui->label) for this entity attribute.
See documentation of method
create_closure()
from class Myco::Entity::Meta::Attribute::UI.This attribute is set automatically by a call to
set_widget()
.label
type: string
Label text to appear in user iterface on or near this entity attribute's inteface widget.
options
type: hash ref { hidden => 1 }
Options that affect the user interface behavior of this entity attribute. Available options:
hidden
type: boolean
If set to true indicates that a widget for this attribute should not by default be visable. However, when generating an HTML-based form for the pupose of creating/updating entity objects that contain this attribute, the attribute should be included as a hidden form field.
value_default
type: string
If the attribute metadata contains the
values
parameter then during widget generation the value supplied with this option is selected by default.value_select
type: boolean
This option is automatically set to true if the attribute metadata contains the
values
parameter and the list of values includes the string '__select__'.
suffix
type: string
Additional HTML that will be appended to the generated widget HTML.
widget
type: array ref ['popup_menu', -rows => 2, -columns => 2]
The first array element is the name of the CGI.pm form element method to be used to generate the widget. Named parameters for this CGI.pm method may optionally follow. Named parameters -name, -values, and -value_labels should _not_ be specified here (these will automatically be set as appropriate, from, for example, other metadata attributes).
Setting this attribute will trigger the automatic setting of the 'closure' attribute.
Default UI Widget
If this piece of metadata is not supplied in class definition then during metadata initialization for this entity asttribute, an appropriate user interface widget may be automatically chosen, depending on the type of the entity attribute (as indicated in the 'type' metadata attribute). The default UI elements (CGI.pm form element method names) are listed below by major entity type categories:
scalars: textfield
(string, int, real, rawdate, etc.) If, however, the 'values' metadata attribute is set then 'popup_menu' will be used instead.
flat_array: none
other: none
(ref, (i)array, (i)set, hash, dmdatetime, perl_dump)
ADDED CLASS / INSTANCE METHODS
get_type_defaults
Returns a reference to a hash (key == attribute type) of default meta data info which is used during attribute object initialization.
getval
# Given $attrmeta, an ::Attribute metadata object for some class,
# and $entity, an instance of same class
$attrval = $attrmeta->getval($entity);
# Complete, but unrealistic example of use
$attrval = $entity->introspect->get_attributes->{attr1}
->getval($entity);
Get the value of an attribute of $entity, utilizing the getter code reference retrieved via get_getter
.
setval
# Given $attrmeta, an ::Attribute metadata object for some class,
# and $entity, an instance of same class
$attrval = $attrmeta->setval($entity, $value);
# Complete, but unrealistic example of use
$attrval = $entity->introspect->get_attributes->{attr1}
->setval($entity, $value);
Set value of an attribute of $entity, utilizing the setter code reference retrieved via get_setter
.
LICENSE AND COPYRIGHT
Copyright (c) 2006 the myco project. All rights reserved. This software is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
SEE ALSO
Myco::Entity::Meta, Myco::Entity, CGI, Myco::Entity::Meta::Attribute::Test, Myco, Tangram, Class::Tangram, myco-mkentity