Difference between revisions of "Perl 101 for EPrints"
|  (→Retrieving data from a config file) |  (→Retrieving data from a config file) | ||
| Line 8: | Line 8: | ||
| 	{ tagname => 'etd_ms:title', eprint_fieldname => 'title', type => 'simple_text', include_null_value => 1 }, | 	{ tagname => 'etd_ms:title', eprint_fieldname => 'title', type => 'simple_text', include_null_value => 1 }, | ||
| 	{ tagname => 'etd_ms:creator', eprint_fieldname => 'creators_name', type => 'name', multiple => 1}, | 	{ tagname => 'etd_ms:creator', eprint_fieldname => 'creators_name', type => 'name', multiple => 1}, | ||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| 	{ tagname => 'etd_ms:degree', type => 'compound', parts => [ | 	{ tagname => 'etd_ms:degree', type => 'compound', parts => [ | ||
| 		{ tagname => 'etd_ms:name', type => 'simple_text', eprint_fieldname => 'thesis_degree_name' }, | 		{ tagname => 'etd_ms:name', type => 'simple_text', eprint_fieldname => 'thesis_degree_name' }, | ||
Revision as of 07:22, 12 June 2015
Retrieving data from a config file
Example of a data config file under /cfg/cfg.d/example.pl
$c->{etd_ms}->{fields} = [
	{ tagname => 'etd_ms:title', eprint_fieldname => 'title', type => 'simple_text', include_null_value => 1 },
	{ tagname => 'etd_ms:creator', eprint_fieldname => 'creators_name', type => 'name', multiple => 1},
	{ tagname => 'etd_ms:degree', type => 'compound', parts => [
		{ tagname => 'etd_ms:name', type => 'simple_text', eprint_fieldname => 'thesis_degree_name' },
		{ tagname => 'etd_ms:level', type => 'simple_text', eprint_fieldname => 'thesis_type' },
		{ tagname => 'etd_ms:discipline', type => 'simple_text', eprint_fieldname => 'department' },
		{ tagname => 'etd_ms:grantor', type => 'simple_text', eprint_fieldname => 'institution' },
	] },
];
Retrieving values from this config file in an export plugin under /plugins/EPrints/Plugin/Export/example.pm
               my $fields = $session->get_conf('etd_ms','fields');					
               foreach my $field_conf (@{$fields})
		{
		   my $tags = $plugin->generate_tag($eprint, $field_conf);			
		   foreach my $tag (@{$tags})
		   {
					push @dcdata, ($tag) if $tag; 
		   }
		}
Supporting function that returns an arrayref
sub generate_tag {
	my ($plugin, $eprint, $field_conf) = @_;
	#Constant value
	if ($field_conf->{type} eq 'constant')
	{
		return $plugin->generate_constant_tag($eprint, $field_conf);
	}
}
Supporting function that generates a tag
sub generate_constant_tag
{
	my ($plugin, $eprint, $field_conf) = @_;
	my $tag = $plugin->_simple_tag($field_conf, $field_conf->{value});
	return [ $tag ];
}
