galaxy.tools.parameters package
Classes encapsulating Galaxy tool parameters.
- class galaxy.tools.parameters.DataCollectionToolParameter(tool, input_source, trans=None)[source]
Bases:
BaseDataToolParameter
- property collection_types
- from_json(value, trans, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- to_text(value)[source]
Convert a value to a text representation suitable for displaying to the user >>> p = ToolParameter(None, XML(‘<param name=”_name” />’)) >>> print(p.to_text(None)) Not available. >>> print(p.to_text(‘’)) Empty. >>> print(p.to_text(‘text’)) text >>> print(p.to_text(True)) True >>> print(p.to_text(False)) False >>> print(p.to_text(0)) 0
- class galaxy.tools.parameters.DataToolParameter(tool, input_source, trans=None)[source]
Bases:
BaseDataToolParameter
Parameter that takes on one (or many) or a specific set of values.
- TODO: There should be an alternate display that allows single selects to be
displayed as radio buttons and multiple selects as a set of checkboxes
TODO: The following must be fixed to test correctly for the new security_check tag in the DataToolParameter (the last test below is broken) Nate’s next pass at the dataset security stuff will dramatically alter this anyway.
- from_json(value, trans, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- to_param_dict_string(value, other_values=None)[source]
Called via __str__ when used in the Cheetah template
- to_text(value)[source]
Convert a value to a text representation suitable for displaying to the user >>> p = ToolParameter(None, XML(‘<param name=”_name” />’)) >>> print(p.to_text(None)) Not available. >>> print(p.to_text(‘’)) Empty. >>> print(p.to_text(‘text’)) text >>> print(p.to_text(True)) True >>> print(p.to_text(False)) False >>> print(p.to_text(0)) 0
- class galaxy.tools.parameters.SelectToolParameter(tool, input_source, context=None)[source]
Bases:
ToolParameter
Parameter that takes on one (or many) or a specific set of values.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch(), workflow_building_mode=False) >>> p = SelectToolParameter(None, XML( ... ''' ... <param name="_name" type="select"> ... <option value="x">x_label</option> ... <option value="y" selected="true">y_label</option> ... <option value="z">z_label</option> ... </param> ... ''')) >>> print(p.name) _name >>> sorted(p.to_dict(trans).items()) [('argument', None), ('display', None), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'SelectToolParameter'), ('multiple', False), ('name', '_name'), ('optional', False), ('options', [('x_label', 'x', False), ('y_label', 'y', True), ('z_label', 'z', False)]), ('refresh_on_change', False), ('textable', False), ('type', 'select'), ('value', 'y')] >>> p = SelectToolParameter(None, XML( ... ''' ... <param name="_name" type="select" multiple="true"> ... <option value="x">x_label</option> ... <option value="y" selected="true">y_label</option> ... <option value="z" selected="true">z_label</option> ... </param> ... ''')) >>> print(p.name) _name >>> sorted(p.to_dict(trans).items()) [('argument', None), ('display', None), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'SelectToolParameter'), ('multiple', True), ('name', '_name'), ('optional', True), ('options', [('x_label', 'x', False), ('y_label', 'y', True), ('z_label', 'z', True)]), ('refresh_on_change', False), ('textable', False), ('type', 'select'), ('value', ['y', 'z'])] >>> print(p.to_param_dict_string(["y", "z"])) y,z
- get_legal_names(trans, other_values)[source]
determine a mapping from names to values for all legal options
- from_json(value, trans, other_values=None, require_legal_value=True)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- to_param_dict_string(value, other_values=None)[source]
Called via __str__ when used in the Cheetah template
- to_json(value, app, use_security)[source]
Convert a value to a string representation suitable for persisting
- to_python(value, app)[source]
Convert a value created with to_json back to an object representation
- to_text(value)[source]
Convert a value to a text representation suitable for displaying to the user >>> p = ToolParameter(None, XML(‘<param name=”_name” />’)) >>> print(p.to_text(None)) Not available. >>> print(p.to_text(‘’)) Empty. >>> print(p.to_text(‘text’)) text >>> print(p.to_text(True)) True >>> print(p.to_text(False)) False >>> print(p.to_text(0)) 0
Submodules
galaxy.tools.parameters.basic module
Basic tool parameters.
- exception galaxy.tools.parameters.basic.ParameterValueError(message_suffix, parameter_name, parameter_value=<object object>, is_dynamic=None)[source]
Bases:
ValueError
- class galaxy.tools.parameters.basic.ToolParameter(tool, input_source, context=None)[source]
Bases:
Dictifiable
Describes a parameter accepted by a tool. This is just a simple stub at the moment but in the future should encapsulate more complex parameters (lists of valid choices, validation logic, …)
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None) >>> p = ToolParameter(None, XML('<param argument="--parameter-name" type="text" value="default" />')) >>> assert p.name == 'parameter_name' >>> assert sorted(p.to_dict(trans).items()) == [('argument', '--parameter-name'), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'ToolParameter'), ('name', 'parameter_name'), ('optional', False), ('refresh_on_change', False), ('type', 'text'), ('value', None)]
- dict_collection_visible_keys = ['name', 'argument', 'type', 'label', 'help', 'refresh_on_change']
- from_json(value, trans=None, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- get_required_enctype()[source]
If this parameter needs the form to have a specific encoding return it, otherwise return None (indicating compatibility with any encoding)
- to_json(value, app, use_security) str [source]
Convert a value to a string representation suitable for persisting
- to_python(value, app)[source]
Convert a value created with to_json back to an object representation
- to_text(value) str [source]
Convert a value to a text representation suitable for displaying to the user >>> p = ToolParameter(None, XML(‘<param name=”_name” />’)) >>> print(p.to_text(None)) Not available. >>> print(p.to_text(‘’)) Empty. >>> print(p.to_text(‘text’)) text >>> print(p.to_text(True)) True >>> print(p.to_text(False)) False >>> print(p.to_text(0)) 0
- to_param_dict_string(value, other_values=None) str [source]
Called via __str__ when used in the Cheetah template
- class galaxy.tools.parameters.basic.SimpleTextToolParameter(tool, input_source)[source]
Bases:
ToolParameter
- class galaxy.tools.parameters.basic.TextToolParameter(tool, input_source)[source]
Bases:
SimpleTextToolParameter
Parameter that can take on any text value.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None) >>> p = TextToolParameter(None, XML('<param name="_name" type="text" value="default" />')) >>> print(p.name) _name >>> sorted(p.to_dict(trans).items()) [('area', False), ('argument', None), ('datalist', []), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'TextToolParameter'), ('name', '_name'), ('optional', True), ('refresh_on_change', False), ('type', 'text'), ('value', 'default')]
- class galaxy.tools.parameters.basic.IntegerToolParameter(tool, input_source)[source]
Bases:
TextToolParameter
Parameter that takes an integer value.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch(), workflow_building_mode=True) >>> p = IntegerToolParameter(None, XML('<param name="_name" type="integer" value="10" />')) >>> print(p.name) _name >>> assert sorted(p.to_dict(trans).items()) == [('area', False), ('argument', None), ('datalist', []), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('max', None), ('min', None), ('model_class', 'IntegerToolParameter'), ('name', '_name'), ('optional', False), ('refresh_on_change', False), ('type', 'integer'), ('value', u'10')] >>> assert type(p.from_json("10", trans)) == int >>> with assert_throws_param_value_error("parameter '_name': an integer or workflow parameter is required"): ... p.from_json("_string", trans)
- dict_collection_visible_keys = ['name', 'argument', 'type', 'label', 'help', 'refresh_on_change', 'min', 'max']
- from_json(value, trans, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- class galaxy.tools.parameters.basic.FloatToolParameter(tool, input_source)[source]
Bases:
TextToolParameter
Parameter that takes a real number value.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch(), workflow_building_mode=True) >>> p = FloatToolParameter(None, XML('<param name="_name" type="float" value="3.141592" />')) >>> print(p.name) _name >>> assert sorted(p.to_dict(trans).items()) == [('area', False), ('argument', None), ('datalist', []), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('max', None), ('min', None), ('model_class', 'FloatToolParameter'), ('name', '_name'), ('optional', False), ('refresh_on_change', False), ('type', 'float'), ('value', u'3.141592')] >>> assert type(p.from_json("36.1", trans)) == float >>> with assert_throws_param_value_error("parameter '_name': an integer or workflow parameter is required"): ... p.from_json("_string", trans)
- dict_collection_visible_keys = ['name', 'argument', 'type', 'label', 'help', 'refresh_on_change', 'min', 'max']
- from_json(value, trans, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- class galaxy.tools.parameters.basic.BooleanToolParameter(tool, input_source)[source]
Bases:
ToolParameter
Parameter that takes one of two values.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch()) >>> p = BooleanToolParameter(None, XML('<param name="_name" type="boolean" checked="yes" truevalue="_truevalue" falsevalue="_falsevalue" />')) >>> print(p.name) _name >>> assert sorted(p.to_dict(trans).items()) == [('argument', None), ('falsevalue', '_falsevalue'), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'BooleanToolParameter'), ('name', '_name'), ('optional', False), ('refresh_on_change', False), ('truevalue', '_truevalue'), ('type', 'boolean'), ('value', True)] >>> print(p.from_json('true')) True >>> print(p.to_param_dict_string(True)) _truevalue >>> print(p.from_json('false')) False >>> print(p.to_param_dict_string(False)) _falsevalue >>> value = p.to_json('false', trans.app, use_security=False) >>> assert isinstance(value, bool) >>> assert value == False >>> value = p.to_json(True, trans.app, use_security=False) >>> assert isinstance(value, bool) >>> assert value == True
- from_json(value, trans=None, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- to_python(value, app=None)[source]
Convert a value created with to_json back to an object representation
- to_json(value, app, use_security)[source]
Convert a value to a string representation suitable for persisting
- to_param_dict_string(value, other_values=None)[source]
Called via __str__ when used in the Cheetah template
- to_dict(trans, other_values=None)[source]
to_dict tool parameter. This can be overridden by subclasses.
- property legal_values
- class galaxy.tools.parameters.basic.FileToolParameter(tool, input_source)[source]
Bases:
ToolParameter
Parameter that takes an uploaded file as a value.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch()) >>> p = FileToolParameter(None, XML('<param name="_name" type="file"/>')) >>> print(p.name) _name >>> sorted(p.to_dict(trans).items()) [('argument', None), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'FileToolParameter'), ('name', '_name'), ('optional', False), ('refresh_on_change', False), ('type', 'file'), ('value', None)]
- from_json(value, trans=None, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- class galaxy.tools.parameters.basic.FTPFileToolParameter(tool, input_source)[source]
Bases:
ToolParameter
Parameter that takes a file uploaded via FTP as a value.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch(), user=None) >>> p = FTPFileToolParameter(None, XML('<param name="_name" type="ftpfile"/>')) >>> print(p.name) _name >>> sorted(p.to_dict(trans).items()) [('argument', None), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'FTPFileToolParameter'), ('multiple', True), ('name', '_name'), ('optional', True), ('refresh_on_change', False), ('type', 'ftpfile'), ('value', None)]
- property visible
Return true if the parameter should be rendered on the form
- to_param_dict_string(value, other_values=None)[source]
Called via __str__ when used in the Cheetah template
- from_json(value, trans=None, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- to_json(value, app, use_security)[source]
Convert a value to a string representation suitable for persisting
- class galaxy.tools.parameters.basic.HiddenToolParameter(tool, input_source)[source]
Bases:
ToolParameter
Parameter that takes one of two values.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch()) >>> p = HiddenToolParameter(None, XML('<param name="_name" type="hidden" value="_value"/>')) >>> print(p.name) _name >>> assert sorted(p.to_dict(trans).items()) == [('argument', None), ('help', ''), ('hidden', True), ('is_dynamic', False), ('label', ''), ('model_class', 'HiddenToolParameter'), ('name', '_name'), ('optional', False), ('refresh_on_change', False), ('type', 'hidden'), ('value', u'_value')]
- class galaxy.tools.parameters.basic.ColorToolParameter(tool, input_source)[source]
Bases:
ToolParameter
Parameter that stores a color.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch()) >>> p = ColorToolParameter(None, XML('<param name="_name" type="color" value="#ffffff"/>')) >>> print(p.name) _name >>> print(p.to_param_dict_string("#ffffff")) #ffffff >>> assert sorted(p.to_dict(trans).items()) == [('argument', None), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'ColorToolParameter'), ('name', '_name'), ('optional', False), ('refresh_on_change', False), ('type', 'color'), ('value', u'#ffffff')] >>> p = ColorToolParameter(None, XML('<param name="_name" type="color"/>')) >>> print(p.get_initial_value(trans, {})) #000000 >>> p = ColorToolParameter(None, XML('<param name="_name" type="color" value="#ffffff" rgb="True"/>')) >>> print(p.to_param_dict_string("#ffffff")) (255, 255, 255) >>> with assert_throws_param_value_error("parameter '_name': Failed to convert 'None' to RGB."): ... p.to_param_dict_string(None)
- class galaxy.tools.parameters.basic.BaseURLToolParameter(tool, input_source)[source]
Bases:
HiddenToolParameter
Returns a parameter that contains its value prepended by the current server base url. Used in all redirects.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch()) >>> p = BaseURLToolParameter(None, XML('<param name="_name" type="base_url" value="_value"/>')) >>> print(p.name) _name >>> assert sorted(p.to_dict(trans).items()) == [('argument', None), ('help', ''), ('hidden', True), ('is_dynamic', False), ('label', ''), ('model_class', 'BaseURLToolParameter'), ('name', '_name'), ('optional', False), ('refresh_on_change', False), ('type', 'base_url'), ('value', u'_value')]
- galaxy.tools.parameters.basic.iter_to_string(iterable: Iterable[Any]) Generator[str, None, None] [source]
- class galaxy.tools.parameters.basic.SelectToolParameter(tool, input_source, context=None)[source]
Bases:
ToolParameter
Parameter that takes on one (or many) or a specific set of values.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch(), workflow_building_mode=False) >>> p = SelectToolParameter(None, XML( ... ''' ... <param name="_name" type="select"> ... <option value="x">x_label</option> ... <option value="y" selected="true">y_label</option> ... <option value="z">z_label</option> ... </param> ... ''')) >>> print(p.name) _name >>> sorted(p.to_dict(trans).items()) [('argument', None), ('display', None), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'SelectToolParameter'), ('multiple', False), ('name', '_name'), ('optional', False), ('options', [('x_label', 'x', False), ('y_label', 'y', True), ('z_label', 'z', False)]), ('refresh_on_change', False), ('textable', False), ('type', 'select'), ('value', 'y')] >>> p = SelectToolParameter(None, XML( ... ''' ... <param name="_name" type="select" multiple="true"> ... <option value="x">x_label</option> ... <option value="y" selected="true">y_label</option> ... <option value="z" selected="true">z_label</option> ... </param> ... ''')) >>> print(p.name) _name >>> sorted(p.to_dict(trans).items()) [('argument', None), ('display', None), ('help', ''), ('hidden', False), ('is_dynamic', False), ('label', ''), ('model_class', 'SelectToolParameter'), ('multiple', True), ('name', '_name'), ('optional', True), ('options', [('x_label', 'x', False), ('y_label', 'y', True), ('z_label', 'z', True)]), ('refresh_on_change', False), ('textable', False), ('type', 'select'), ('value', ['y', 'z'])] >>> print(p.to_param_dict_string(["y", "z"])) y,z
- get_legal_names(trans, other_values)[source]
determine a mapping from names to values for all legal options
- from_json(value, trans, other_values=None, require_legal_value=True)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- to_param_dict_string(value, other_values=None)[source]
Called via __str__ when used in the Cheetah template
- to_json(value, app, use_security)[source]
Convert a value to a string representation suitable for persisting
- to_python(value, app)[source]
Convert a value created with to_json back to an object representation
- to_text(value)[source]
Convert a value to a text representation suitable for displaying to the user >>> p = ToolParameter(None, XML(‘<param name=”_name” />’)) >>> print(p.to_text(None)) Not available. >>> print(p.to_text(‘’)) Empty. >>> print(p.to_text(‘text’)) text >>> print(p.to_text(True)) True >>> print(p.to_text(False)) False >>> print(p.to_text(0)) 0
- class galaxy.tools.parameters.basic.GenomeBuildParameter(*args, **kwds)[source]
Bases:
SelectToolParameter
Select list that sets the last used genome build for the current history as “selected”.
>>> # Create a mock transaction with 'hg17' as the current build >>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch(genome_build='hg17'), db_builds=read_dbnames(None)) >>> p = GenomeBuildParameter(None, XML('<param name="_name" type="genomebuild" value="hg17" />')) >>> print(p.name) _name >>> d = p.to_dict(trans) >>> o = d['options'] >>> [i for i in o if i[2] == True] [('Human May 2004 (NCBI35/hg17) (hg17)', 'hg17', True)] >>> [i for i in o if i[1] == 'hg18'] [('Human Mar. 2006 (NCBI36/hg18) (hg18)', 'hg18', False)] >>> p.is_dynamic True
- class galaxy.tools.parameters.basic.SelectTagParameter(tool, input_source)[source]
Bases:
SelectToolParameter
Select set that is composed of a set of tags available for an input.
- from_json(value, trans, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- get_tag_list(other_values)[source]
Generate a select list containing the tags of the associated dataset (if found).
- class galaxy.tools.parameters.basic.ColumnListParameter(tool, input_source)[source]
Bases:
SelectToolParameter
Select list that consists of either the total number of columns or only those columns that contain numerical values in the associated DataToolParameter.
# TODO: we need better testing here, but not sure how to associate a DatatoolParameter with a ColumnListParameter # from a twill perspective…
>>> # Mock up a history (not connected to database) >>> from galaxy.model import History, HistoryDatasetAssociation >>> from galaxy.util.bunch import Bunch >>> from galaxy.model.mapping import init >>> sa_session = init("/tmp", "sqlite:///:memory:", create_tables=True).session >>> hist = History() >>> with sa_session.begin(): ... sa_session.add(hist) >>> hda = hist.add_dataset(HistoryDatasetAssociation(id=1, extension='interval', create_dataset=True, sa_session=sa_session)) >>> dtp = DataToolParameter(None, XML('<param name="blah" type="data" format="interval"/>')) >>> print(dtp.name) blah >>> clp = ColumnListParameter(None, XML('<param name="numerical_column" type="data_column" data_ref="blah" numerical="true"/>')) >>> print(clp.name) numerical_column
- to_json(value, app, use_security)[source]
Convert a value to a string representation suitable for persisting
- from_json(value, trans, other_values=None)[source]
Label convention prepends column number with a ‘c’, but tool uses the integer. This removes the ‘c’ when entered into a workflow.
- get_column_list(trans, other_values)[source]
Generate a select list containing the columns of the associated dataset (if found).
- get_options(trans, other_values)[source]
Show column labels rather than c1..cn if use_header_names=True
- class galaxy.tools.parameters.basic.DrillDownSelectToolParameter(tool, input_source, context=None)[source]
Bases:
SelectToolParameter
Parameter that takes on one (or many) of a specific set of values. Creating a hierarchical select menu, which allows users to ‘drill down’ a tree-like set of options.
>>> from galaxy.util.bunch import Bunch >>> trans = Bunch(app=None, history=Bunch(genome_build='hg17'), db_builds=read_dbnames(None)) >>> p = DrillDownSelectToolParameter(None, XML( ... ''' ... <param name="_name" type="drill_down" display="checkbox" hierarchy="recurse" multiple="true"> ... <options> ... <option name="Heading 1" value="heading1"> ... <option name="Option 1" value="option1"/> ... <option name="Option 2" value="option2"/> ... <option name="Heading 2" value="heading2"> ... <option name="Option 3" value="option3"/> ... <option name="Option 4" value="option4"/> ... </option> ... </option> ... <option name="Option 5" value="option5"/> ... </options> ... </param> ... ''')) >>> print(p.name) _name >>> d = p.to_dict(trans) >>> assert d['multiple'] == True >>> assert d['display'] == 'checkbox' >>> assert d['options'][0]['name'] == 'Heading 1' >>> assert d['options'][0]['value'] == 'heading1' >>> assert d['options'][0]['options'][0]['name'] == 'Option 1' >>> assert d['options'][0]['options'][0]['value'] == 'option1' >>> assert d['options'][0]['options'][1]['name'] == 'Option 2' >>> assert d['options'][0]['options'][1]['value'] == 'option2' >>> assert d['options'][0]['options'][2]['name'] == 'Heading 2' >>> assert d['options'][0]['options'][2]['value'] == 'heading2' >>> assert d['options'][0]['options'][2]['options'][0]['name'] == 'Option 3' >>> assert d['options'][0]['options'][2]['options'][0]['value'] == 'option3' >>> assert d['options'][0]['options'][2]['options'][1]['name'] == 'Option 4' >>> assert d['options'][0]['options'][2]['options'][1]['value'] == 'option4' >>> assert d['options'][1]['name'] == 'Option 5' >>> assert d['options'][1]['value'] == 'option5'
- from_json(value, trans, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- to_param_dict_string(value, other_values=None)[source]
Called via __str__ when used in the Cheetah template
- to_text(value)[source]
Convert a value to a text representation suitable for displaying to the user >>> p = ToolParameter(None, XML(‘<param name=”_name” />’)) >>> print(p.to_text(None)) Not available. >>> print(p.to_text(‘’)) Empty. >>> print(p.to_text(‘text’)) text >>> print(p.to_text(True)) True >>> print(p.to_text(False)) False >>> print(p.to_text(0)) 0
- class galaxy.tools.parameters.basic.BaseDataToolParameter(tool, input_source, trans)[source]
Bases:
ToolParameter
- to_json(value, app, use_security)[source]
Convert a value to a string representation suitable for persisting
- galaxy.tools.parameters.basic.src_id_to_item(sa_session: Session, value: MutableMapping[str, Any], security: IdEncodingHelper) DatasetCollectionElement | HistoryDatasetAssociation | HistoryDatasetCollectionAssociation | LibraryDatasetDatasetAssociation [source]
- class galaxy.tools.parameters.basic.DataToolParameter(tool, input_source, trans=None)[source]
Bases:
BaseDataToolParameter
Parameter that takes on one (or many) or a specific set of values.
- TODO: There should be an alternate display that allows single selects to be
displayed as radio buttons and multiple selects as a set of checkboxes
TODO: The following must be fixed to test correctly for the new security_check tag in the DataToolParameter (the last test below is broken) Nate’s next pass at the dataset security stuff will dramatically alter this anyway.
- from_json(value, trans, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- to_param_dict_string(value, other_values=None)[source]
Called via __str__ when used in the Cheetah template
- to_text(value)[source]
Convert a value to a text representation suitable for displaying to the user >>> p = ToolParameter(None, XML(‘<param name=”_name” />’)) >>> print(p.to_text(None)) Not available. >>> print(p.to_text(‘’)) Empty. >>> print(p.to_text(‘text’)) text >>> print(p.to_text(True)) True >>> print(p.to_text(False)) False >>> print(p.to_text(0)) 0
- class galaxy.tools.parameters.basic.DataCollectionToolParameter(tool, input_source, trans=None)[source]
Bases:
BaseDataToolParameter
- property collection_types
- from_json(value, trans, other_values=None)[source]
Convert a value from an HTML POST into the parameters preferred value format.
- to_text(value)[source]
Convert a value to a text representation suitable for displaying to the user >>> p = ToolParameter(None, XML(‘<param name=”_name” />’)) >>> print(p.to_text(None)) Not available. >>> print(p.to_text(‘’)) Empty. >>> print(p.to_text(‘text’)) text >>> print(p.to_text(True)) True >>> print(p.to_text(False)) False >>> print(p.to_text(0)) 0
- class galaxy.tools.parameters.basic.HiddenDataToolParameter(tool, elem)[source]
Bases:
HiddenToolParameter
,DataToolParameter
Hidden parameter that behaves as a DataToolParameter. As with all hidden parameters, this is a HACK.
- class galaxy.tools.parameters.basic.BaseJsonToolParameter(tool, input_source, context=None)[source]
Bases:
ToolParameter
Class of parameter that tries to keep values as close to JSON as possible. In particular value_to_basic is overloaded to prevent params_to_strings from double encoding JSON and to_python using loads to produce values.
- class galaxy.tools.parameters.basic.DirectoryUriToolParameter(tool, input_source, context=None)[source]
Bases:
SimpleTextToolParameter
galaxy.files URIs for directories.
- class galaxy.tools.parameters.basic.RulesListToolParameter(tool, input_source, context=None)[source]
Bases:
BaseJsonToolParameter
Parameter that allows for the creation of a list of rules using the Galaxy rules DSL.
- to_dict(trans, other_values=None)[source]
to_dict tool parameter. This can be overridden by subclasses.
- to_text(value)[source]
Convert a value to a text representation suitable for displaying to the user >>> p = ToolParameter(None, XML(‘<param name=”_name” />’)) >>> print(p.to_text(None)) Not available. >>> print(p.to_text(‘’)) Empty. >>> print(p.to_text(‘text’)) text >>> print(p.to_text(True)) True >>> print(p.to_text(False)) False >>> print(p.to_text(0)) 0
galaxy.tools.parameters.dataset_matcher module
galaxy.tools.parameters.dynamic_options module
Support for generating the options for a SelectToolParameter dynamically (based on the values of other parameters or other aspects of the current state)
- class galaxy.tools.parameters.dynamic_options.Filter(d_option, elem)[source]
Bases:
object
A filter takes the current options list and modifies it.
- class galaxy.tools.parameters.dynamic_options.StaticValueFilter(d_option, elem)[source]
Bases:
Filter
Filters a list of options on a column by a static value.
Type: static_value
- Required Attributes:
value: static value to compare to column: column in options to compare with
- Optional Attributes:
- keep: Keep columns matching value (True)
Discard columns matching value (False)
- class galaxy.tools.parameters.dynamic_options.RegexpFilter(d_option, elem)[source]
Bases:
Filter
Filters a list of options on a column by a regular expression.
Type: regexp
- Required Attributes:
value: regular expression to compare to column: column in options to compare with
- Optional Attributes:
- keep: Keep columns matching the regexp (True)
Discard columns matching the regexp (False)
- class galaxy.tools.parameters.dynamic_options.DataMetaFilter(d_option, elem)[source]
Bases:
Filter
Filters a list of options on a column by a dataset metadata value.
Type: data_meta
When no ‘from’ source has been specified in the <options> tag, this will populate the options list with (meta_value, meta_value, False). Otherwise, options which do not match the metadata value in the column are discarded.
Required Attributes:
ref: Name of input dataset
key: Metadata key to use for comparison
column: column in options to compare with (not required when not associated with input options)
Optional Attributes:
multiple: Option values are multiple, split column by separator (True)
separator: When multiple split by this (,)
- class galaxy.tools.parameters.dynamic_options.ParamValueFilter(d_option, elem)[source]
Bases:
Filter
Filters a list of options on a column by the value of another input.
Type: param_value
Required Attributes:
ref: Name of input value
column: column in options to compare with
Optional Attributes:
- keep: Keep columns matching value (True)
Discard columns matching value (False)
ref_attribute: Period (.) separated attribute chain of input (ref) to use as value for filter
- class galaxy.tools.parameters.dynamic_options.UniqueValueFilter(d_option, elem)[source]
Bases:
Filter
Filters a list of options to be unique by a column value.
Type: unique_value
- Required Attributes:
column: column in options to compare with
- class galaxy.tools.parameters.dynamic_options.MultipleSplitterFilter(d_option, elem)[source]
Bases:
Filter
Turns a single line of options into multiple lines, by splitting a column and creating a line for each item.
Type: multiple_splitter
- Required Attributes:
column: column in options to compare with
- Optional Attributes:
separator: Split column by this (,)
- class galaxy.tools.parameters.dynamic_options.AttributeValueSplitterFilter(d_option, elem)[source]
Bases:
Filter
Filters a list of attribute-value pairs to be unique attribute names.
Type: attribute_value_splitter
- Required Attributes:
column: column in options to compare with
- Optional Attributes:
pair_separator: Split column by this (,) name_val_separator: Split name-value pair by this ( whitespace )
- class galaxy.tools.parameters.dynamic_options.AdditionalValueFilter(d_option, elem)[source]
Bases:
Filter
Adds a single static value to an options list.
Type: add_value
- Required Attributes:
value: value to appear in select list
- Optional Attributes:
name: Display name to appear in select list (value) index: Index of option list to add value (APPEND)
- class galaxy.tools.parameters.dynamic_options.RemoveValueFilter(d_option, elem)[source]
Bases:
Filter
Removes a value from an options list.
Type: remove_value
Required Attributes:
value: value to remove from select list or ref: param to refer to or meta_ref: dataset to refer to key: metadata key to compare to
- class galaxy.tools.parameters.dynamic_options.SortByColumnFilter(d_option, elem)[source]
Bases:
Filter
Sorts an options list by a column
Type: sort_by
- Required Attributes:
column: column to sort by
- class galaxy.tools.parameters.dynamic_options.DynamicOptions(elem: Element, tool_param)[source]
Bases:
object
Handles dynamically generated SelectToolParameter options
- property tool_data_table
- property missing_tool_data_table_name
- get_dependency_names()[source]
Return the names of parameters these options depend on – both data and other param types.
- get_fields_by_value(value, trans, other_values)[source]
Return a list of fields with column ‘value’ matching provided value.
- class galaxy.tools.parameters.dynamic_options.FromUrlOptions(from_url: str, request_method: typing_extensions.Literal['GET', 'POST'], request_body: str | NoneType, request_headers: str | NoneType, postprocess_expression: str | NoneType)[source]
Bases:
object
- __init__(from_url: str, request_method: typing_extensions.Literal[GET, POST], request_body: str | None, request_headers: str | None, postprocess_expression: str | None) None
- request_method: typing_extensions.Literal[GET, POST]
- galaxy.tools.parameters.dynamic_options.strip_or_none(maybe_string: Element | None) str | None [source]
- galaxy.tools.parameters.dynamic_options.parse_from_url_options(elem: Element) FromUrlOptions | None [source]
galaxy.tools.parameters.grouping module
Constructs for grouping tool parameters
- class galaxy.tools.parameters.grouping.Group[source]
Bases:
Dictifiable
- dict_collection_visible_keys = ['name', 'type']
- property visible
- value_to_basic(value, app, use_security=False)[source]
Convert value to a (possibly nested) representation using only basic types (dict, list, tuple, string_types, int, long, float, bool, None)
- class galaxy.tools.parameters.grouping.Repeat[source]
Bases:
Group
- dict_collection_visible_keys = ['name', 'type', 'title', 'help', 'default', 'min', 'max']
- property title
- property title_plural
- property label
- value_to_basic(value, app, use_security=False)[source]
Convert value to a (possibly nested) representation using only basic types (dict, list, tuple, string_types, int, long, float, bool, None)
- class galaxy.tools.parameters.grouping.Section[source]
Bases:
Group
- dict_collection_visible_keys = ['name', 'type', 'title', 'help', 'expanded']
- property title_plural
- property label
- value_to_basic(value, app, use_security=False)[source]
Convert value to a (possibly nested) representation using only basic types (dict, list, tuple, string_types, int, long, float, bool, None)
- class galaxy.tools.parameters.grouping.UploadDataset[source]
Bases:
Group
- property title_plural
- value_to_basic(value, app, use_security=False)[source]
Convert value to a (possibly nested) representation using only basic types (dict, list, tuple, string_types, int, long, float, bool, None)
- class galaxy.tools.parameters.grouping.Conditional[source]
Bases:
Group
- value_from: Callable[[ExpressionContext, Conditional, Tool], Mapping[str, str]]
- property label
- value_to_basic(value, app, use_security=False)[source]
Convert value to a (possibly nested) representation using only basic types (dict, list, tuple, string_types, int, long, float, bool, None)
galaxy.tools.parameters.history_query module
galaxy.tools.parameters.input_translation module
Tool Input Translation.
- class galaxy.tools.parameters.input_translation.ToolInputTranslator[source]
Bases:
object
Handles Tool input translation. This is used for data source tools
>>> from galaxy.util import Params, XML >>> translator = ToolInputTranslator.from_element(XML( ... ''' ... <request_param_translation> ... <request_param galaxy_name="URL_method" remote_name="URL_method" missing="post" /> ... <request_param galaxy_name="URL" remote_name="URL" missing="" > ... <append_param separator="&" first_separator="?" join="="> ... <value name="_export" missing="1" /> ... <value name="GALAXY_URL" missing="0" /> ... </append_param> ... </request_param> ... <request_param galaxy_name="dbkey" remote_name="db" missing="?" /> ... <request_param galaxy_name="organism" remote_name="org" missing="unknown species" /> ... <request_param galaxy_name="table" remote_name="hgta_table" missing="unknown table" /> ... <request_param galaxy_name="description" remote_name="hgta_regionType" missing="no description" /> ... <request_param galaxy_name="data_type" remote_name="hgta_outputType" missing="tabular" > ... <value_translation> ... <value galaxy_value="tabular" remote_value="primaryTable" /> ... <value galaxy_value="tabular" remote_value="selectedFields" /> ... <value galaxy_value="wig" remote_value="wigData" /> ... <value galaxy_value="interval" remote_value="tab" /> ... <value galaxy_value="html" remote_value="hyperlinks" /> ... <value galaxy_value="fasta" remote_value="sequence" /> ... </value_translation> ... </request_param> ... </request_param_translation> ... ''')) >>> params = Params({'db':'hg17', 'URL':'URL_value', 'org':'Human', 'hgta_outputType':'primaryTable'}) >>> translator.translate(params) >>> print(sorted(params.__dict__.keys())) ['URL', 'URL_method', 'data_type', 'db', 'dbkey', 'description', 'hgta_outputType', 'org', 'organism', 'table'] >>> params.get('URL', None) in ['URL_value?GALAXY_URL=0&_export=1', 'URL_value?_export=1&GALAXY_URL=0'] True
galaxy.tools.parameters.meta module
- class galaxy.tools.parameters.meta.WorkflowParameterExpansion(param_combinations, param_keys, input_combinations)
Bases:
tuple
- input_combinations
Alias for field number 2
- param_combinations
Alias for field number 0
- param_keys
Alias for field number 1
- galaxy.tools.parameters.meta.expand_workflow_inputs(param_inputs, inputs=None)[source]
Expands incoming encoded multiple payloads, into the set of all individual payload combinations >>> expansion = expand_workflow_inputs({‘1’: {‘input’: {‘batch’: True, ‘product’: True, ‘values’: [{‘hid’: ‘1’}, {‘hid’: ‘2’}] }}}) >>> print([“%s” % (p[‘1’][‘input’][‘hid’]) for p in expansion.param_combinations]) [‘1’, ‘2’] >>> expansion = expand_workflow_inputs({‘1’: {‘input’: {‘batch’: True, ‘values’: [{‘hid’: ‘1’}, {‘hid’: ‘2’}] }}}) >>> print([“%s” % (p[‘1’][‘input’][‘hid’]) for p in expansion.param_combinations]) [‘1’, ‘2’] >>> expansion = expand_workflow_inputs({‘1’: {‘input’: {‘batch’: True, ‘values’: [{‘hid’: ‘1’}, {‘hid’: ‘2’}] }}, ‘2’: {‘input’: {‘batch’: True, ‘values’: [{‘hid’: ‘3’}, {‘hid’: ‘4’}] }}}) >>> print([“%s%s” % (p[‘1’][‘input’][‘hid’], p[‘2’][‘input’][‘hid’]) for p in expansion.param_combinations]) [‘13’, ‘24’] >>> expansion = expand_workflow_inputs({‘1’: {‘input’: {‘batch’: True, ‘product’: True, ‘values’: [{‘hid’: ‘1’}, {‘hid’: ‘2’}] }}, ‘2’: {‘input’: {‘batch’: True, ‘values’: [{‘hid’: ‘3’}, {‘hid’: ‘4’}, {‘hid’: ‘5’}] }}}) >>> print([“%s%s” % (p[‘1’][‘input’][‘hid’], p[‘2’][‘input’][‘hid’]) for p in expansion.param_combinations]) [‘13’, ‘23’, ‘14’, ‘24’, ‘15’, ‘25’] >>> expansion = expand_workflow_inputs({‘1’: {‘input’: {‘batch’: True, ‘product’: True, ‘values’: [{‘hid’: ‘1’}, {‘hid’: ‘2’}] }}, ‘2’: {‘input’: {‘batch’: True, ‘product’: True, ‘values’: [{‘hid’: ‘3’}, {‘hid’: ‘4’}, {‘hid’: ‘5’}] }}, ‘3’: {‘input’: {‘batch’: True, ‘product’: True, ‘values’: [{‘hid’: ‘6’}, {‘hid’: ‘7’}, {‘hid’: ‘8’}] }}}) >>> print([“%s%s%s” % (p[‘1’][‘input’][‘hid’], p[‘2’][‘input’][‘hid’], p[‘3’][‘input’][‘hid’]) for p in expansion.param_combinations]) [‘136’, ‘137’, ‘138’, ‘146’, ‘147’, ‘148’, ‘156’, ‘157’, ‘158’, ‘236’, ‘237’, ‘238’, ‘246’, ‘247’, ‘248’, ‘256’, ‘257’, ‘258’] >>> expansion = expand_workflow_inputs(None, inputs={‘myinput’: {‘batch’: True, ‘product’: True, ‘values’: [{‘hid’: ‘1’}, {‘hid’: ‘2’}] }}) >>> print([“%s” % (p[‘myinput’][‘hid’]) for p in expansion.input_combinations]) [‘1’, ‘2’]
galaxy.tools.parameters.sanitize module
Tool Parameter specific sanitizing.
- class galaxy.tools.parameters.sanitize.ToolParameterSanitizer[source]
Bases:
object
Handles tool parameter specific sanitizing.
>>> from galaxy.util import XML >>> sanitizer = ToolParameterSanitizer.from_element(XML( ... ''' ... <sanitizer invalid_char=""> ... <valid initial="string.ascii_letters"/> ... </sanitizer> ... ''')) >>> sanitizer.sanitize_param(''.join(sorted(c for c in string.printable))) == ''.join(sorted(c for c in string.ascii_letters)) True >>> slash = chr(92) >>> sanitizer = ToolParameterSanitizer.from_element(XML( ... ''' ... <sanitizer> ... <valid initial="none"> ... <add preset="string.printable"/> ... <remove value="""/> ... <remove value="%s"/> ... </valid> ... <mapping initial="none"> ... <add source=""" target="%s""/> ... <add source="%s" target="%s%s"/> ... </mapping> ... </sanitizer> ... ''' % (slash, slash, slash, slash, slash))) >>> text = '%s"$rm&#!' % slash >>> [c for c in sanitizer.sanitize_param(text)] == [slash, slash, slash, '"', '$', 'r', 'm', '&', '#', '!'] True
- VALID_PRESET = {'default': 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789 -=_.()/+*^,:?!', 'none': ''}
- MAPPING_PRESET = {'default': {'\t': '__tc__', '\n': '__cn__', '\r': '__cr__', '"': '__dq__', '#': '__pd__', "'": '__sq__', '<': '__lt__', '>': '__gt__', '@': '__at__', '[': '__ob__', ']': '__cb__', '{': '__oc__', '}': '__cc__'}, 'none': {}}
- DEFAULT_INVALID_CHAR = 'X'
galaxy.tools.parameters.validation module
Classes related to parameter validation.
- class galaxy.tools.parameters.validation.Validator(message, negate=False)[source]
Bases:
ABC
A validator checks that a value meets some conditions OR raises ValueError
- requires_dataset_metadata = False
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- abstract validate(value, trans=None, message=None, value_to_show=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.RegexValidator(message, expression, negate)[source]
Bases:
Validator
Validator that evaluates a regular expression
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.ExpressionValidator(message, expression, negate)[source]
Bases:
Validator
Validator that evaluates a python expression using the value
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.InRangeValidator(message, range_min, range_max, exclude_min=False, exclude_max=False, negate=False)[source]
Bases:
ExpressionValidator
Validator that ensures a number is in a specified range
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- __init__(message, range_min, range_max, exclude_min=False, exclude_max=False, negate=False)[source]
When the optional exclude_min and exclude_max attributes are set to true, the range excludes the end points (i.e., min < value < max), while if set to False (the default), then range includes the end points (1.e., min <= value <= max). Combinations of exclude_min and exclude_max values are allowed.
- class galaxy.tools.parameters.validation.LengthValidator(message, length_min, length_max, negate)[source]
Bases:
InRangeValidator
Validator that ensures the length of the provided string (value) is in a specific range
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- __init__(message, length_min, length_max, negate)[source]
When the optional exclude_min and exclude_max attributes are set to true, the range excludes the end points (i.e., min < value < max), while if set to False (the default), then range includes the end points (1.e., min <= value <= max). Combinations of exclude_min and exclude_max values are allowed.
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.DatasetOkValidator(message, negate=False)[source]
Bases:
Validator
Validator that checks if a dataset is in an ‘ok’ state
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.DatasetEmptyValidator(message, negate=False)[source]
Bases:
Validator
Validator that checks if a dataset has a positive file size.
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.DatasetExtraFilesPathEmptyValidator(message, negate=False)[source]
Bases:
Validator
Validator that checks if a dataset’s extra_files_path exists and is not empty.
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.MetadataValidator(message=None, check='', skip='', negate='false')[source]
Bases:
Validator
Validator that checks for missing metadata
- requires_dataset_metadata = True
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.MetadataEqualValidator(metadata_name=None, value=None, message=None, negate='false')[source]
Bases:
Validator
Validator that checks for a metadata value for equality
metadata values that are lists are converted as comma separated string everything else is converted to the string representation
- requires_dataset_metadata = True
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.UnspecifiedBuildValidator(message, negate=False)[source]
Bases:
Validator
Validator that checks for dbkey not equal to ‘?’
- requires_dataset_metadata = True
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.NoOptionsValidator(message, negate=False)[source]
Bases:
Validator
Validator that checks for empty select list
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.EmptyTextfieldValidator(message, negate=False)[source]
Bases:
Validator
Validator that checks for empty text field
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.MetadataInFileColumnValidator(filename, metadata_name, metadata_column, message='Value for metadata not found.', line_startswith=None, split='\t', negate='false')[source]
Bases:
Validator
Validator that checks if the value for a dataset’s metadata item exists in a file.
Deprecated: DataTables are now the preferred way.
note: this is covered in a framework test (validation_dataset_metadata_in_file)
- requires_dataset_metadata = True
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- __init__(filename, metadata_name, metadata_column, message='Value for metadata not found.', line_startswith=None, split='\t', negate='false')[source]
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.ValueInDataTableColumnValidator(tool_data_table, column, message='Value not found.', negate='false')[source]
Bases:
Validator
Validator that checks if a value is in a tool data table column.
note: this is covered in a framework test (validation_value_in_datatable)
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.ValueNotInDataTableColumnValidator(tool_data_table, metadata_column, message='Value already present.', negate='false')[source]
Bases:
ValueInDataTableColumnValidator
Validator that checks if a value is NOT in a tool data table column. Equivalent to ValueInDataTableColumnValidator with negate=”true”.
note: this is covered in a framework test (validation_value_in_datatable)
- __init__(tool_data_table, metadata_column, message='Value already present.', negate='false')[source]
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.MetadataInDataTableColumnValidator(tool_data_table, metadata_name, metadata_column, message='Value for metadata not found.', negate='false')[source]
Bases:
ValueInDataTableColumnValidator
Validator that checks if the value for a dataset’s metadata item exists in a file.
note: this is covered in a framework test (validation_metadata_in_datatable)
- requires_dataset_metadata = True
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- __init__(tool_data_table, metadata_name, metadata_column, message='Value for metadata not found.', negate='false')[source]
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.MetadataNotInDataTableColumnValidator(tool_data_table, metadata_name, metadata_column, message='Value for metadata not found.', negate='false')[source]
Bases:
MetadataInDataTableColumnValidator
Validator that checks if the value for a dataset’s metadata item doesn’t exists in a file. Equivalent to MetadataInDataTableColumnValidator with negate=”true”.
note: this is covered in a framework test (validation_metadata_in_datatable)
- requires_dataset_metadata = True
- __init__(tool_data_table, metadata_name, metadata_column, message='Value for metadata not found.', negate='false')[source]
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
- class galaxy.tools.parameters.validation.MetadataInRangeValidator(metadata_name, message, range_min, range_max, exclude_min, exclude_max, negate)[source]
Bases:
InRangeValidator
validator that ensures metadata is in a specified range
note: this is covered in a framework test (validation_metadata_in_range)
- requires_dataset_metadata = True
- classmethod from_element(param, elem)[source]
Initialize the appropriate Validator class
example call validation.Validator.from_element(ToolParameter_object, Validator_object)
needs to be implemented in the subclasses and should return the corresponding Validator object by a call to cls( … ) which calls the __init__ method of the corresponding validator
param cls the Validator class param param the element to be evaluated (which contains the validator) param elem the validator element return an object of a Validator subclass that corresponds to the type attribute of the validator element
- __init__(metadata_name, message, range_min, range_max, exclude_min, exclude_max, negate)[source]
When the optional exclude_min and exclude_max attributes are set to true, the range excludes the end points (i.e., min < value < max), while if set to False (the default), then range includes the end points (1.e., min <= value <= max). Combinations of exclude_min and exclude_max values are allowed.
- validate(value, trans=None)[source]
validate a value
needs to be implemented in classes derived from validator. the implementation needs to call super().validate() giving result as a bool (which should be true if the validation is positive and false otherwise) and the value that is validated.
the Validator.validate function will then negate the value depending on self.negate and return None if - value is True and negate is False - value is False and negate is True and raise a ValueError otherwise.
return None if positive validation, otherwise a ValueError is raised
galaxy.tools.parameters.wrapped module
- class galaxy.tools.parameters.wrapped.LegacyUnprefixedDict(dict=None, **kwargs)[source]
Bases:
UserDict
Track and provide access to prefixed and unprefixed tool parameter values.
- class galaxy.tools.parameters.wrapped.WrappedParameters(trans, tool, incoming, input_datasets=None)[source]
Bases:
object
- property params
- galaxy.tools.parameters.wrapped.make_dict_copy(from_dict)[source]
Makes a copy of input dictionary from_dict such that all values that are dictionaries result in creation of a new dictionary ( a sort of deepcopy ). We may need to handle other complex types ( e.g., lists, etc ), but not sure… Yes, we need to handle lists (and now are)…