The openstack_dashboard.dashboards.identity.projects.tables ModuleΒΆ

class openstack_dashboard.dashboards.identity.projects.tables.CreateProject(attrs=None, **kwargs)[source]

Bases: horizon.tables.actions.LinkAction

allowed(request, project)[source]
base_options = {'__module__': 'openstack_dashboard.dashboards.identity.projects.tables', 'render': <function render at 0x99b03e4>, 'update': <function update at 0x9935614>, 'policy_rules': (('identity', 'identity:create_project'),), 'get_link_url': <function get_link_url at 0x99b0614>, 'ajax': False, 'allowed': <function allowed at 0xd975fb4>, 'base_options': {'__module__': 'horizon.tables.actions', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'allowed': <function allowed at 0x96c209c>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'base_options': {...}, '__doc__': 'Common base class for all ``Action`` classes.', '__init__': <function __init__ at 0x920fbfc>}, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, '__init__': <function __init__ at 0x99b064c>, 'icon': 'plus', 'name': 'create', 'url': 'horizon:identity:projects:create', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x99b03ac>, '_allowed': <function _allowed at 0x99352cc>, 'classes': ('ajax-modal',), '__repr__': <function __repr__ at 0x9935294>, 'get_ajax_update_url': <function get_ajax_update_url at 0x99b041c>, 'verbose_name': <django.utils.functional.__proxy__ object at 0xdcfe9ec>, '__doc__': 'A table action which is simply a link rather than a form POST.\n\n .. attribute:: name\n\n Required. The short name or "slug" representing this\n action. This name should not be changed at runtime.\n\n .. attribute:: verbose_name\n\n A string which will be rendered as the link text. (Required)\n\n .. attribute:: url\n\n A string or a callable which resolves to a url to be used as the link\n target. You must either define the ``url`` attribute or override\n the ``get_link_url`` method on the class.\n\n .. attribute:: allowed_data_types\n\n A list that contains the allowed data types of the action. If the\n datum\'s type is in this list, the action will be shown on the row\n for the datum.\n\n Defaults to be an empty list (``[]``). When set to empty, the action\n will accept any kind of data.\n '}
classes = ('ajax-modal',)
icon = 'plus'
name = 'create'
policy_rules = (('identity', 'identity:create_project'),)
url = 'horizon:identity:projects:create'
verbose_name = <django.utils.functional.__proxy__ object at 0xdcfe9ec>
class openstack_dashboard.dashboards.identity.projects.tables.DeleteTenantsAction(**kwargs)[source]

Bases: openstack_dashboard.policy.PolicyTargetMixin, horizon.tables.actions.DeleteAction

static action_past(count)[source]
static action_present(count)[source]
allowed(request, project)[source]
base_options = {'policy_target_attrs': (('target.project.domain_id', 'domain_id'),), '__module__': 'openstack_dashboard.dashboards.identity.projects.tables', 'handle': <function handle at 0xdc780d4>, 'update': <function update at 0xa1364fc>, 'policy_rules': (('identity', 'identity:delete_project'),), 'get_success_url': <function get_success_url at 0xa136534>, 'get_param_name': <function get_param_name at 0x9935fb4>, 'allowed': <function allowed at 0xdc78064>, 'help_text': <django.utils.functional.__proxy__ object at 0x9afaa0c>, 'base_options': {'__module__': 'horizon.tables.actions', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'allowed': <function allowed at 0x96c209c>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'base_options': {...}, '__doc__': 'Common base class for all ``Action`` classes.', '__init__': <function __init__ at 0x920fbfc>}, '__init__': <function __init__ at 0xa1365dc>, 'name': 'delete', 'action_present': <staticmethod object at 0xdc8a59c>, 'action_past': <staticmethod object at 0xdc8a194>, 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0xa136684>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x980979c>, '_get_action_name': <function _get_action_name at 0x98096bc>, '__repr__': <function __repr__ at 0x9935294>, 'action': <function action at 0xa136614>, 'get_default_attrs': <function get_default_attrs at 0xa13656c>, '__doc__': 'A table action used to perform delete operations on table data.\n\n .. attribute:: name\n\n A short name or "slug" representing this action.\n Defaults to \'delete\'\n\n .. method:: action_present\n\n Method accepting an integer/long parameter and returning the display\n forms of the name properly pluralised (depending on the integer) and\n translated in a string or tuple/list.\n\n .. attribute:: action_present (Deprecated)\n\n A string containing the transitive verb describing the delete action.\n Defaults to \'Delete\'\n\n NOTE: action_present attribute is bad for translations and should be\n avoided. Please use the action_present method instead.\n This form is kept for legacy.\n\n .. method:: action_past\n\n Method accepting an integer/long parameter and returning the display\n forms of the name properly pluralised (depending on the integer) and\n translated in a string or tuple/list.\n\n .. attribute:: action_past (Deprecated)\n\n A string set to the past tense of action_present.\n Defaults to \'Deleted\'\n\n NOTE: action_past attribute is bad for translations and should be\n avoided. Please use the action_past method instead.\n This form is kept for legacy.\n\n .. attribute:: data_type_singular (Deprecated)\n\n A string used to name the data to be deleted.\n\n .. attribute:: data_type_plural (Deprecated)\n\n Optional. Plural of ``data_type_singular``.\n Defaults to ``data_type_singular`` appended with an \'s\'. Relying on\n the default is bad for translations and should not be done, so it\'s\n absence will raise a DeprecationWarning. It is currently kept as\n optional for legacy code.\n\n NOTE: data_type_singular and data_type_plural attributes are bad for\n translations and should not be used. Please use the action_present and\n action_past methods. This form is kept temporarily for legacy code but\n will be removed.\n ', 'delete': <function delete at 0xdc7809c>}
delete(request, obj_id)[source]
handle(table, request, obj_ids)[source]
policy_rules = (('identity', 'identity:delete_project'),)
policy_target_attrs = (('target.project.domain_id', 'domain_id'),)
class openstack_dashboard.dashboards.identity.projects.tables.ModifyQuotas(attrs=None, **kwargs)[source]

Bases: horizon.tables.actions.LinkAction

allowed(request, datum)[source]
base_options = {'__module__': 'openstack_dashboard.dashboards.identity.projects.tables', 'render': <function render at 0x99b03e4>, 'update': <function update at 0x9935614>, 'policy_rules': (('compute', 'compute_extension:quotas:update'),), 'get_link_url': <function get_link_url at 0xd975994>, 'ajax': False, 'allowed': <function allowed at 0xd975aac>, 'base_options': {'__module__': 'horizon.tables.actions', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'allowed': <function allowed at 0x96c209c>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'base_options': {...}, '__doc__': 'Common base class for all ``Action`` classes.', '__init__': <function __init__ at 0x920fbfc>}, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, '__init__': <function __init__ at 0x99b064c>, 'icon': 'pencil', 'name': 'quotas', 'url': 'horizon:identity:projects:update', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x99b03ac>, '_allowed': <function _allowed at 0x99352cc>, 'classes': ('ajax-modal',), '__repr__': <function __repr__ at 0x9935294>, 'get_ajax_update_url': <function get_ajax_update_url at 0x99b041c>, 'verbose_name': <django.utils.functional.__proxy__ object at 0xdc91bec>, '__doc__': 'A table action which is simply a link rather than a form POST.\n\n .. attribute:: name\n\n Required. The short name or "slug" representing this\n action. This name should not be changed at runtime.\n\n .. attribute:: verbose_name\n\n A string which will be rendered as the link text. (Required)\n\n .. attribute:: url\n\n A string or a callable which resolves to a url to be used as the link\n target. You must either define the ``url`` attribute or override\n the ``get_link_url`` method on the class.\n\n .. attribute:: allowed_data_types\n\n A list that contains the allowed data types of the action. If the\n datum\'s type is in this list, the action will be shown on the row\n for the datum.\n\n Defaults to be an empty list (``[]``). When set to empty, the action\n will accept any kind of data.\n '}
classes = ('ajax-modal',)
get_link_url(project)[source]
icon = 'pencil'
name = 'quotas'
policy_rules = (('compute', 'compute_extension:quotas:update'),)
url = 'horizon:identity:projects:update'
verbose_name = <django.utils.functional.__proxy__ object at 0xdc91bec>
class openstack_dashboard.dashboards.identity.projects.tables.RescopeTokenToProject(attrs=None, **kwargs)[source]

Bases: horizon.tables.actions.LinkAction

allowed(request, project)[source]
base_options = {'__module__': 'openstack_dashboard.dashboards.identity.projects.tables', 'render': <function render at 0x99b03e4>, 'update': <function update at 0x9935614>, 'get_link_url': <function get_link_url at 0xd975e64>, 'ajax': False, 'allowed': <function allowed at 0xd975e2c>, 'base_options': {'__module__': 'horizon.tables.actions', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'allowed': <function allowed at 0x96c209c>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'base_options': {...}, '__doc__': 'Common base class for all ``Action`` classes.', '__init__': <function __init__ at 0x920fbfc>}, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, '__init__': <function __init__ at 0x99b064c>, 'name': 'rescope', 'url': 'switch_tenants', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x99b03ac>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'get_ajax_update_url': <function get_ajax_update_url at 0x99b041c>, 'verbose_name': <django.utils.functional.__proxy__ object at 0xda072ac>, '__doc__': 'A table action which is simply a link rather than a form POST.\n\n .. attribute:: name\n\n Required. The short name or "slug" representing this\n action. This name should not be changed at runtime.\n\n .. attribute:: verbose_name\n\n A string which will be rendered as the link text. (Required)\n\n .. attribute:: url\n\n A string or a callable which resolves to a url to be used as the link\n target. You must either define the ``url`` attribute or override\n the ``get_link_url`` method on the class.\n\n .. attribute:: allowed_data_types\n\n A list that contains the allowed data types of the action. If the\n datum\'s type is in this list, the action will be shown on the row\n for the datum.\n\n Defaults to be an empty list (``[]``). When set to empty, the action\n will accept any kind of data.\n '}
get_link_url(project)[source]
name = 'rescope'
url = 'switch_tenants'
verbose_name = <django.utils.functional.__proxy__ object at 0xda072ac>
class openstack_dashboard.dashboards.identity.projects.tables.TenantFilterAction(**kwargs)[source]

Bases: horizon.tables.actions.FilterAction

base_options = {'__module__': 'openstack_dashboard.dashboards.identity.projects.tables', 'is_api_filter': <function is_api_filter at 0x9809b1c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'allowed': <function allowed at 0x96c209c>, 'base_options': {'__module__': 'horizon.tables.actions', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'allowed': <function allowed at 0x96c209c>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'base_options': {...}, '__doc__': 'Common base class for all ``Action`` classes.', '__init__': <function __init__ at 0x920fbfc>}, '__init__': <function __init__ at 0x9809d14>, 'filter': <function filter at 0xdc78144>, 'name': 'filter', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'get_param_name': <function get_param_name at 0x9809a04>, '__doc__': 'A base class representing a filter action for a table.\n\n .. attribute:: name\n\n The short name or "slug" representing this action. Defaults to\n ``"filter"``.\n\n .. attribute:: verbose_name\n\n A descriptive name used for display purposes. Defaults to the\n value of ``name`` with the first letter of each word capitalized.\n\n .. attribute:: param_name\n\n A string representing the name of the request parameter used for the\n search term. Default: ``"q"``.\n\n .. attribute:: filter_type\n\n A string representing the type of this filter. If this is set to\n ``"server"`` then ``filter_choices`` must also be provided.\n Default: ``"query"``.\n\n .. attribute:: filter_choices\n\n Required for server type filters. A tuple of tuples representing the\n filter options. Tuple composition should evaluate to (string, string,\n boolean), representing the filter parameter, display value, and whether\n or not it should be applied to the API request as an API query\n attribute. API type filters do not need to be accounted for in the\n filter method since the API will do the filtering. However, server\n type filters in general will need to be performed in the filter method.\n By default this attribute is not provided.\n\n .. attribute:: needs_preloading\n\n If True, the filter function will be called for the initial\n GET request with an empty ``filter_string``, regardless of the\n value of ``method``.\n ', 'data_type_filter': <function data_type_filter at 0x9809c6c>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'assign_type_string': <function assign_type_string at 0x9809d4c>, 'associate_with_table': <function associate_with_table at 0x9935ed4>}
filter(table, tenants, filter_string)[source]

Really naive case-insensitive search.

class openstack_dashboard.dashboards.identity.projects.tables.TenantsTable(request, data=None, needs_form_wrapper=None, **kwargs)[source]

Bases: horizon.tables.base.DataTable

class Meta[source]

Bases: object

name = 'tenants'
pagination_param = 'tenant_marker'
row_actions = (<class 'openstack_dashboard.dashboards.identity.projects.tables.UpdateMembersLink'>, <class 'openstack_dashboard.dashboards.identity.projects.tables.UpdateGroupsLink'>, <class 'openstack_dashboard.dashboards.identity.projects.tables.UpdateProject'>, <class 'openstack_dashboard.dashboards.identity.projects.tables.UsageLink'>, <class 'openstack_dashboard.dashboards.identity.projects.tables.ModifyQuotas'>, <class 'openstack_dashboard.dashboards.identity.projects.tables.DeleteTenantsAction'>, <class 'openstack_dashboard.dashboards.identity.projects.tables.RescopeTokenToProject'>)
row_class

alias of UpdateRow

table_actions = (<class 'openstack_dashboard.dashboards.identity.projects.tables.TenantFilterAction'>, <class 'openstack_dashboard.dashboards.identity.projects.tables.CreateProject'>, <class 'openstack_dashboard.dashboards.identity.projects.tables.DeleteTenantsAction'>)
verbose_name = <django.utils.functional.__proxy__ object at 0xdbdcd6c>
TenantsTable.base_actions = OrderedDict([('create', <CreateProject: create>), ('delete', <DeleteTenantsAction: delete>), ('filter', <TenantFilterAction: filter>), ('groups', <UpdateGroupsLink: groups>), ('quotas', <ModifyQuotas: quotas>), ('rescope', <RescopeTokenToProject: rescope>), ('update', <UpdateProject: update>), ('usage', <UsageLink: usage>), ('users', <UpdateMembersLink: users>)])
TenantsTable.base_columns = OrderedDict([('name', <Column: name>), ('description', <Column: description>), ('id', <Column: id>), ('enabled', <Column: enabled>)])
TenantsTable.get_project_detail_link(project)[source]
class openstack_dashboard.dashboards.identity.projects.tables.UpdateCell[source]

Bases: horizon.tables.actions.UpdateAction

allowed(request, project, cell)[source]
update_cell(request, datum, project_id, cell_name, new_cell_value)[source]
class openstack_dashboard.dashboards.identity.projects.tables.UpdateGroupsLink(attrs=None, **kwargs)[source]

Bases: horizon.tables.actions.LinkAction

allowed(request, project)[source]
base_options = {'__module__': 'openstack_dashboard.dashboards.identity.projects.tables', 'render': <function render at 0x99b03e4>, 'update': <function update at 0x9935614>, 'policy_rules': (('identity', 'identity:list_groups'),), 'get_link_url': <function get_link_url at 0xd975f44>, 'ajax': False, 'allowed': <function allowed at 0xd975f0c>, 'base_options': {'__module__': 'horizon.tables.actions', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'allowed': <function allowed at 0x96c209c>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'base_options': {...}, '__doc__': 'Common base class for all ``Action`` classes.', '__init__': <function __init__ at 0x920fbfc>}, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, '__init__': <function __init__ at 0x99b064c>, 'icon': 'pencil', 'name': 'groups', 'url': 'horizon:identity:projects:update', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x99b03ac>, '_allowed': <function _allowed at 0x99352cc>, 'classes': ('ajax-modal',), '__repr__': <function __repr__ at 0x9935294>, 'get_ajax_update_url': <function get_ajax_update_url at 0x99b041c>, 'verbose_name': <django.utils.functional.__proxy__ object at 0xda0750c>, '__doc__': 'A table action which is simply a link rather than a form POST.\n\n .. attribute:: name\n\n Required. The short name or "slug" representing this\n action. This name should not be changed at runtime.\n\n .. attribute:: verbose_name\n\n A string which will be rendered as the link text. (Required)\n\n .. attribute:: url\n\n A string or a callable which resolves to a url to be used as the link\n target. You must either define the ``url`` attribute or override\n the ``get_link_url`` method on the class.\n\n .. attribute:: allowed_data_types\n\n A list that contains the allowed data types of the action. If the\n datum\'s type is in this list, the action will be shown on the row\n for the datum.\n\n Defaults to be an empty list (``[]``). When set to empty, the action\n will accept any kind of data.\n '}
classes = ('ajax-modal',)
get_link_url(project)[source]
icon = 'pencil'
name = 'groups'
policy_rules = (('identity', 'identity:list_groups'),)
url = 'horizon:identity:projects:update'
verbose_name = <django.utils.functional.__proxy__ object at 0xda0750c>
class openstack_dashboard.dashboards.identity.projects.tables.UpdateMembersLink(attrs=None, **kwargs)[source]

Bases: horizon.tables.actions.LinkAction

allowed(request, project)[source]
base_options = {'__module__': 'openstack_dashboard.dashboards.identity.projects.tables', 'render': <function render at 0x99b03e4>, 'update': <function update at 0x9935614>, 'policy_rules': (('identity', 'identity:list_users'), ('identity', 'identity:list_roles')), 'get_link_url': <function get_link_url at 0xd975e9c>, 'ajax': False, 'allowed': <function allowed at 0xd975ed4>, 'base_options': {'__module__': 'horizon.tables.actions', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'allowed': <function allowed at 0x96c209c>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'base_options': {...}, '__doc__': 'Common base class for all ``Action`` classes.', '__init__': <function __init__ at 0x920fbfc>}, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, '__init__': <function __init__ at 0x99b064c>, 'icon': 'pencil', 'name': 'users', 'url': 'horizon:identity:projects:update', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x99b03ac>, '_allowed': <function _allowed at 0x99352cc>, 'classes': ('ajax-modal',), '__repr__': <function __repr__ at 0x9935294>, 'get_ajax_update_url': <function get_ajax_update_url at 0x99b041c>, 'verbose_name': <django.utils.functional.__proxy__ object at 0xda93ccc>, '__doc__': 'A table action which is simply a link rather than a form POST.\n\n .. attribute:: name\n\n Required. The short name or "slug" representing this\n action. This name should not be changed at runtime.\n\n .. attribute:: verbose_name\n\n A string which will be rendered as the link text. (Required)\n\n .. attribute:: url\n\n A string or a callable which resolves to a url to be used as the link\n target. You must either define the ``url`` attribute or override\n the ``get_link_url`` method on the class.\n\n .. attribute:: allowed_data_types\n\n A list that contains the allowed data types of the action. If the\n datum\'s type is in this list, the action will be shown on the row\n for the datum.\n\n Defaults to be an empty list (``[]``). When set to empty, the action\n will accept any kind of data.\n '}
classes = ('ajax-modal',)
get_link_url(project)[source]
icon = 'pencil'
name = 'users'
policy_rules = (('identity', 'identity:list_users'), ('identity', 'identity:list_roles'))
url = 'horizon:identity:projects:update'
verbose_name = <django.utils.functional.__proxy__ object at 0xda93ccc>
class openstack_dashboard.dashboards.identity.projects.tables.UpdateProject(attrs=None, **kwargs)[source]

Bases: openstack_dashboard.policy.PolicyTargetMixin, horizon.tables.actions.LinkAction

allowed(request, project)[source]
base_options = {'policy_target_attrs': (('target.project.domain_id', 'domain_id'),), '__module__': 'openstack_dashboard.dashboards.identity.projects.tables', 'render': <function render at 0x99b03e4>, 'update': <function update at 0x9935614>, 'policy_rules': (('identity', 'identity:update_project'),), 'get_link_url': <function get_link_url at 0x99b0614>, 'ajax': False, 'allowed': <function allowed at 0xd975844>, 'base_options': {'__module__': 'horizon.tables.actions', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'allowed': <function allowed at 0x96c209c>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'base_options': {...}, '__doc__': 'Common base class for all ``Action`` classes.', '__init__': <function __init__ at 0x920fbfc>}, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, '__init__': <function __init__ at 0x99b064c>, 'icon': 'pencil', 'name': 'update', 'url': 'horizon:identity:projects:update', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x99b03ac>, '_allowed': <function _allowed at 0x99352cc>, 'classes': ('ajax-modal',), '__repr__': <function __repr__ at 0x9935294>, 'get_ajax_update_url': <function get_ajax_update_url at 0x99b041c>, 'verbose_name': <django.utils.functional.__proxy__ object at 0xdce474c>, '__doc__': 'A table action which is simply a link rather than a form POST.\n\n .. attribute:: name\n\n Required. The short name or "slug" representing this\n action. This name should not be changed at runtime.\n\n .. attribute:: verbose_name\n\n A string which will be rendered as the link text. (Required)\n\n .. attribute:: url\n\n A string or a callable which resolves to a url to be used as the link\n target. You must either define the ``url`` attribute or override\n the ``get_link_url`` method on the class.\n\n .. attribute:: allowed_data_types\n\n A list that contains the allowed data types of the action. If the\n datum\'s type is in this list, the action will be shown on the row\n for the datum.\n\n Defaults to be an empty list (``[]``). When set to empty, the action\n will accept any kind of data.\n '}
classes = ('ajax-modal',)
icon = 'pencil'
name = 'update'
policy_rules = (('identity', 'identity:update_project'),)
policy_target_attrs = (('target.project.domain_id', 'domain_id'),)
url = 'horizon:identity:projects:update'
verbose_name = <django.utils.functional.__proxy__ object at 0xdce474c>
class openstack_dashboard.dashboards.identity.projects.tables.UpdateRow(table, datum=None)[source]

Bases: horizon.tables.base.Row

ajax = True
get_data(request, project_id)[source]
class openstack_dashboard.dashboards.identity.projects.tables.UsageLink(attrs=None, **kwargs)[source]

Bases: horizon.tables.actions.LinkAction

allowed(request, project)[source]
base_options = {'__module__': 'openstack_dashboard.dashboards.identity.projects.tables', 'render': <function render at 0x99b03e4>, 'update': <function update at 0x9935614>, 'policy_rules': (('compute', 'compute_extension:simple_tenant_usage:show'),), 'get_link_url': <function get_link_url at 0x99b0614>, 'ajax': False, 'allowed': <function allowed at 0xd9756bc>, 'base_options': {'__module__': 'horizon.tables.actions', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'update': <function update at 0x9935614>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x9935ed4>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'allowed': <function allowed at 0x96c209c>, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, 'base_options': {...}, '__doc__': 'Common base class for all ``Action`` classes.', '__init__': <function __init__ at 0x920fbfc>}, 'get_default_attrs': <function get_default_attrs at 0x99350d4>, '__init__': <function __init__ at 0x99b064c>, 'icon': 'stats', 'name': 'usage', 'url': 'horizon:identity:projects:usage', 'data_type_matched': <function data_type_matched at 0x920fbc4>, 'get_default_classes': <function get_default_classes at 0x993548c>, 'get_policy_target': <function get_policy_target at 0x920faac>, 'associate_with_table': <function associate_with_table at 0x99b03ac>, '_allowed': <function _allowed at 0x99352cc>, '__repr__': <function __repr__ at 0x9935294>, 'get_ajax_update_url': <function get_ajax_update_url at 0x99b041c>, 'verbose_name': <django.utils.functional.__proxy__ object at 0xda073ac>, '__doc__': 'A table action which is simply a link rather than a form POST.\n\n .. attribute:: name\n\n Required. The short name or "slug" representing this\n action. This name should not be changed at runtime.\n\n .. attribute:: verbose_name\n\n A string which will be rendered as the link text. (Required)\n\n .. attribute:: url\n\n A string or a callable which resolves to a url to be used as the link\n target. You must either define the ``url`` attribute or override\n the ``get_link_url`` method on the class.\n\n .. attribute:: allowed_data_types\n\n A list that contains the allowed data types of the action. If the\n datum\'s type is in this list, the action will be shown on the row\n for the datum.\n\n Defaults to be an empty list (``[]``). When set to empty, the action\n will accept any kind of data.\n '}
icon = 'stats'
name = 'usage'
policy_rules = (('compute', 'compute_extension:simple_tenant_usage:show'),)
url = 'horizon:identity:projects:usage'
verbose_name = <django.utils.functional.__proxy__ object at 0xda073ac>