當前位置: 首頁>>代碼示例>>Python>>正文


Python InputFilter.filter_int方法代碼示例

本文整理匯總了Python中dNG.data.text.input_filter.InputFilter.filter_int方法的典型用法代碼示例。如果您正苦於以下問題:Python InputFilter.filter_int方法的具體用法?Python InputFilter.filter_int怎麽用?Python InputFilter.filter_int使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在dNG.data.text.input_filter.InputFilter的用法示例。


在下文中一共展示了InputFilter.filter_int方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: execute_resource_thumbnail

# 需要導入模塊: from dNG.data.text.input_filter import InputFilter [as 別名]
# 或者: from dNG.data.text.input_filter.InputFilter import filter_int [as 別名]
    def execute_resource_thumbnail(self):
        """
Action for "resource_thumbnail"

:since: v0.2.00
        """

        rid = InputFilter.filter_control_chars(self.request.get_dsd("urid", ""))
        mimetype = InputFilter.filter_control_chars(self.request.get_dsd("umimetype", ""))
        width = InputFilter.filter_int(self.request.get_dsd("uwidth", 0))
        height = InputFilter.filter_int(self.request.get_dsd("uheight", 0))
        depth = InputFilter.filter_int(self.request.get_dsd("udepth", 24))

        if (width < 1 or height < 1): raise TranslatableException("pas_http_core_400", 400)

        resource = Resource.load_cds_id(rid, self.get_client_settings())

        if (resource is not None and resource.is_supported("thumbnail_source_vfs_url")):
            Image._add_dlna_headers(self.request, self.response, resource)

            self._stream_transformed_vfs_url(resource.get_thumbnail_source_vfs_url(),
                                             mimetype,
                                             width,
                                             height,
                                             depth,
                                             AbstractImage.RESIZE_SCALED_CROP
                                            )
開發者ID:dNG-git,項目名稱:pas_upnp,代碼行數:29,代碼來源:image.py

示例2: execute_device_icon

# 需要導入模塊: from dNG.data.text.input_filter import InputFilter [as 別名]
# 或者: from dNG.data.text.input_filter.InputFilter import filter_int [as 別名]
    def execute_device_icon(self):
        """
Action for "device_icon"

:since: v0.2.00
        """

        usn = InputFilter.filter_control_chars(self.request.get_dsd("uusn", ""))
        mimetype = InputFilter.filter_control_chars(self.request.get_dsd("umimetype", ""))
        width = InputFilter.filter_int(self.request.get_dsd("uwidth", 0))
        height = InputFilter.filter_int(self.request.get_dsd("uheight", 0))
        depth = InputFilter.filter_int(self.request.get_dsd("udepth", 24))

        if (width < 1 or height < 1): raise TranslatableException("pas_http_core_400", 400)

        upnp_control_point = ControlPoint.get_instance()

        if (usn != ""):
            device = upnp_control_point.get_device(Device.get_identifier(usn))
            if (device is None): raise TranslatableException("pas_http_core_400", 400)
            file_path_name = device.get_icon_file_path_name()

            if (file_path_name is not None):
                self._stream_transformed_vfs_url("file:///{0}".format(quote(file_path_name, "/")),
                                                 mimetype,
                                                 width,
                                                 height,
                                                 depth
                                                )
開發者ID:dNG-git,項目名稱:pas_upnp,代碼行數:31,代碼來源:image.py

示例3: execute_delete

# 需要導入模塊: from dNG.data.text.input_filter import InputFilter [as 別名]
# 或者: from dNG.data.text.input_filter.InputFilter import filter_int [as 別名]
	def execute_delete(self):
	#
		"""
Action for "delete"

:since: v0.1.00
		"""

		form_field_id = InputFilter.filter_control_chars(self.request.get_dsd("oform_field_id", "")).strip()
		form_field_entry_position = InputFilter.filter_int(self.request.get_dsd("oform_field_entry_position", -1))

		if (form_field_entry_position > -1):
		#
			form_store = self._get_form_store()
			form_store_dict = form_store.get_value_dict()
			form_store_field_id = "form_api_dynamic_{0}".format(form_field_id)

			entry_list = form_store_dict.get(form_store_field_id, [ ])
			if (len(entry_list) > form_field_entry_position): del(entry_list[form_field_entry_position])

			form_store_dict[form_store_field_id] = entry_list
			form_store.set_value_dict(form_store_dict)
		#

		redirect_request = PredefinedHttpRequest()
		redirect_request.set_module(self.request.get_module())
		redirect_request.set_service(self.request.get_service())
		redirect_request.set_action("get")
		redirect_request.set_dsd_dict(self.request.get_dsd_dict())

		self.request.redirect(redirect_request)
開發者ID:dNG-git,項目名稱:pas_http_dynamic_form,代碼行數:33,代碼來源:abstract.py

示例4: execute_list_root_containers

# 需要導入模塊: from dNG.data.text.input_filter import InputFilter [as 別名]
# 或者: from dNG.data.text.input_filter.InputFilter import filter_int [as 別名]
    def execute_list_root_containers(self):
        """
Action for "list_root_containers"

:since: v0.2.00
        """

        page = InputFilter.filter_int(self.request.get_dsd("mpage", 1))

        L10n.init("mp_core")

        session = (self.request.get_session() if (self.request.is_supported("session")) else None)
        user_profile = (None if (session is None) else session.get_user_profile())

        if (user_profile is None
            or (not user_profile.is_type("ad"))
           ): raise TranslatableError("core_access_denied", 403)

        if (self.response.is_supported("html_css_files")): self.response.add_theme_css_file("mini_default_sprite.min.css")

        Link.set_store("servicemenu",
                       (Link.TYPE_RELATIVE_URL | Link.TYPE_JS_REQUIRED),
                       L10n.get("mp_core_root_container_new"),
                       { "m": "mp", "s": "root_container", "a": "new" },
                       icon = "mini-default-option",
                       priority = 3
                      )

        content = { "title": L10n.get("mp_core_root_container_list"),
                    "entries": MpEntry.get_root_containers_count(),
                    "page": page
                  }

        self.response.init()
        self.response.set_title(content['title'])
        self.response.add_oset_content("mp.container", content)
開發者ID:dNG-git,項目名稱:mp_core,代碼行數:38,代碼來源:index.py

示例5: execute_error

# 需要導入模塊: from dNG.data.text.input_filter import InputFilter [as 別名]
# 或者: from dNG.data.text.input_filter.InputFilter import filter_int [as 別名]
    def execute_error(self):
        """
Action for "error"

:since: v1.0.0
        """

        code = InputFilter.filter_int(self.request.get_parameter("code", "500"))

        if (L10n.is_defined("errors_pas_http_core_{0:d}".format(code))):
            if (self.response.is_supported("headers")):
                self.response.set_header("HTTP",
                                         ("HTTP/2.0 {0:d} {1}".format(code, self.error_messages[code])
                                          if (code in self.error_messages) else
                                          "HTTP/2.0 500 Internal Server Error"
                                         ),
                                         True
                                        )
            #

            self.response.handle_error("pas_http_core_{0:d}".format(code))
        else:
            if (self.response.is_supported("headers")): self.response.set_header("HTTP", "HTTP/2.0 500 Internal Server Error", True)
            self.response.handle_critical_error("core_unknown_error")
開發者ID:dNG-git,項目名稱:pas_http_core,代碼行數:26,代碼來源:http.py

示例6: execute_list

# 需要導入模塊: from dNG.data.text.input_filter import InputFilter [as 別名]
# 或者: from dNG.data.text.input_filter.InputFilter import filter_int [as 別名]
    def execute_list(self):
        """
Action for "list"

:since: v0.2.00
        """

        page = InputFilter.filter_int(self.request.get_dsd("tpage", 1))

        L10n.init("pas_http_tasks")

        session = (self.request.get_session() if (self.request.is_supported("session")) else None)
        user_profile = (None if (session is None) else session.get_user_profile())

        if (user_profile is None or (not user_profile.is_type("ad"))): raise TranslatableError("core_access_denied", 403)

        tasks_count = DatabaseTask.get_list_count()

        hookable_settings = HookableSettings("dNG.pas.http.tasks.List.getLimit")
        limit = hookable_settings.get("pas_http_tasks_list_limit", 40)

        pages = (1 if (tasks_count == 0) else ceil(float(tasks_count) / limit))
        offset = (0 if (page < 1 or page > pages) else (page - 1) * limit)

        tasks_list = DatabaseTask.load_list(offset = offset, limit = limit)

        content = { "title": L10n.get("pas_http_tasks_database_entries_list"), "tasks_count": tasks_count }

        if (tasks_count > 0):
            details_renderer_attributes = { "type": CustomTable.COLUMN_RENDERER_CALLBACK_OSET,
                                            "callback": self._get_details_cell_content,
                                            "oset_template_name": "tasks.details_column",
                                            "oset_row_attributes": [ "id", "tid", "name", "hook", "time_updated" ]
                                          }

            status_renderer_attributes = { "type": CustomTable.COLUMN_RENDERER_CALLBACK_OSET,
                                           "callback": self._get_status_cell_content,
                                           "oset_template_name": "tasks.status_column",
                                           "oset_row_attributes": [ "status", "time_started", "timeout" ]
                                         }

            time_scheduled_renderer_attributes = { "type": CustomTable.COLUMN_RENDERER_OSET,
                                                   "oset_template_name": "tasks.time_scheduled_column"
                                                 }

            table = CustomTable()
            table.add_column("details", L10n.get("pas_http_tasks_entry_details"), 50, renderer = details_renderer_attributes)
            table.add_column("status", L10n.get("pas_http_tasks_entry_status"), 30, renderer = status_renderer_attributes)
            table.add_column("time_scheduled", L10n.get("pas_http_tasks_entry_time_scheduled"), 20, renderer = time_scheduled_renderer_attributes)

            table.set_limit(limit)
            table.set_row_count(tasks_count)

            for task in tasks_list:
                task_data = task.get_data_attributes("id",
                                                     "tid",
                                                     "name",
                                                     "status",
                                                     "hook",
                                                     "time_started",
                                                     "time_scheduled",
                                                     "time_updated",
                                                     "timeout"
                                                    )

                table.add_row(**task_data)
            #

            content['tasks'] = { "object": table,
                                 "dsd_page_key": "tpage",
                                 "page": page
                               }
        #

        self.response.init(True)
        self.response.set_expires_relative(+5)
        self.response.set_title(content['title'])

        self.response.add_oset_content("tasks.list", content)
開發者ID:dNG-git,項目名稱:pas_http_tasks,代碼行數:81,代碼來源:index.py

示例7: execute_list

# 需要導入模塊: from dNG.data.text.input_filter import InputFilter [as 別名]
# 或者: from dNG.data.text.input_filter.InputFilter import filter_int [as 別名]
    def execute_list(self):
        """
Action for "list"

:since: v0.2.00
        """

        cid = InputFilter.filter_file_path(self.request.get_dsd("ccid", ""))
        page = InputFilter.filter_int(self.request.get_dsd("cpage", 1))

        if (cid == ""): cid = Settings.get("pas_http_contentor_category_default", "")

        L10n.init("pas_http_contentor")
        L10n.init("pas_http_datalinker")

        try: category = Category.load_id(cid)
        except NothingMatchedException as handled_exception: raise TranslatableError("pas_http_contentor_cid_invalid", 404, _exception = handled_exception)

        session = (self.request.get_session() if (self.request.is_supported("session")) else None)
        if (session is not None): category.set_permission_session(session)

        if (not category.is_readable()):
            if (session is None or session.get_user_profile() is None): raise TranslatableError("pas_http_contentor_cid_invalid", 404)
            else: raise TranslatableError("core_access_denied", 403)
        #

        if (self.response.is_supported("html_css_files")): self.response.add_theme_css_file("mini_default_sprite.min.css")

        if (category.is_writable()):
            Link.set_store("servicemenu",
                           (Link.TYPE_RELATIVE_URL | Link.TYPE_JS_REQUIRED),
                           L10n.get("pas_http_contentor_document_new"),
                           { "m": "contentor", "s": "document", "a": "new", "dsd": { "ccid": cid } },
                           icon = "mini-default-option",
                           priority = 3
                          )
        #

        if (category.is_manageable()):
            Link.set_store("servicemenu",
                           (Link.TYPE_RELATIVE_URL | Link.TYPE_JS_REQUIRED),
                           L10n.get("pas_http_contentor_category_manage"),
                           { "m": "contentor", "s": "category", "a": "manage", "dsd": { "ccid": cid } },
                           icon = "mini-default-option",
                           priority = 3
                          )
        #

        category_data = category.get_data_attributes("id", "id_main", "title", "time_sortable", "sub_entries", "entry_type")

        content = { "id": category_data['id'],
                    "title": category_data['title'],
                    "time": category_data['time_sortable'],
                    "sub_entries_count": category_data['sub_entries']
                  }

        if (category_data['sub_entries'] > 0): content['sub_entries'] = { "id": category_data['id'], "page": page }

        category_parent = category.load_parent()

        if (category_parent is not None
            and ((not isinstance(category_parent, OwnableInstance))
                 or category_parent.is_readable_for_session_user(session)
                )
           ):
            category_parent_data = category_parent.get_data_attributes("id", "id_main", "title")

            if (category_parent_data['id'] != cid):
                content['parent'] = { "id": category_parent_data['id'],
                                      "main_id": category_parent_data['id_main'],
                                      "title": category_parent_data['title']
                                    }
            #
        #

        self.response.init(True)
        self.response.set_expires_relative(+15)
        self.response.set_title(category_data['title'])
        self.response.add_oset_content("contentor.{0}_list".format(category_data['entry_type']), content)

        if (self.response.is_supported("html_canonical_url")):
            link_parameters = { "__virtual__": "/contentor/view",
                                "dsd": { "ccid": cid, "cpage": page }
                              }

            self.response.set_html_canonical_url(Link().build_url(Link.TYPE_VIRTUAL_PATH, link_parameters))
開發者ID:dNG-git,項目名稱:pas_http_contentor,代碼行數:88,代碼來源:index.py

示例8: execute_list

# 需要導入模塊: from dNG.data.text.input_filter import InputFilter [as 別名]
# 或者: from dNG.data.text.input_filter.InputFilter import filter_int [as 別名]
	def execute_list(self):
	#
		"""
Action for "list"

:since: v0.1.00
		"""

		lid = InputFilter.filter_file_path(self.request.get_dsd("dlid", ""))
		page = InputFilter.filter_int(self.request.get_dsd("dpage", 1))
		sort_value = InputFilter.filter_control_chars(self.request.get_dsd("dsort", ""))

		if (lid == ""): lid = Settings.get("pas_http_discuss_list_default", "")

		L10n.init("pas_http_datalinker")
		L10n.init("pas_http_discuss")
		L10n.init("pas_http_subscription")

		try: _list = List.load_id(lid)
		except NothingMatchedException as handled_exception: raise TranslatableError("pas_http_discuss_lid_invalid", 404, _exception = handled_exception)

		session = (self.request.get_session() if (self.request.is_supported("session")) else None)
		if (session is not None): _list.set_permission_session(session)

		if (not _list.is_readable()):
		#
			if (session is None or session.get_user_profile() is None): raise TranslatableError("pas_http_discuss_lid_invalid", 404)
			else: raise TranslatableError("core_access_denied", 403)
		#

		if (self.response.is_supported("html_css_files")): self.response.add_theme_css_file("mini_default_sprite.min.css")

		is_hybrid_list = _list.is_hybrid_list()

		if (is_hybrid_list and _list.is_writable()):
		#
			Link.set_store("servicemenu",
			               (Link.TYPE_RELATIVE_URL | Link.TYPE_JS_REQUIRED),
			               L10n.get("pas_http_discuss_topic_new"),
			               { "m": "discuss", "s": "topic", "a": "new", "dsd": { "dlid": lid } },
			               icon = "mini-default-option",
			               priority = 3
			              )
		#

		subscription_handler = (_list.get_subscription_handler() if (is_hybrid_list) else None)

		if (subscription_handler is not None and subscription_handler.is_subscribable_for_session_user(session)):
		#
			source = "m=discuss;dsd=dlid+{0}++dpage+{1}".format(lid, page)
			subscription_dsd = { "oid": lid, "source": source }

			if (subscription_handler.is_subscribed_by_session_user(session)):
			#
				Link.set_store("servicemenu",
				               Link.TYPE_RELATIVE_URL,
				               L10n.get("pas_http_subscription_unsubscribe"),
				               { "m": "subscription", "s": "datalinker", "a": "unsubscribe", "dsd": subscription_dsd },
				               icon = "mini-default-option",
				               priority = 3
				              )
			#
			else:
			#
				Link.set_store("servicemenu",
				               Link.TYPE_RELATIVE_URL,
				               L10n.get("pas_http_subscription_subscribe"),
				               { "m": "subscription", "s": "datalinker", "a": "subscribe", "dsd": subscription_dsd },
				               icon = "mini-default-option",
				               priority = 3
				              )
			#
		#

		if (_list.is_manageable()):
		#
			Link.set_store("servicemenu",
			               (Link.TYPE_RELATIVE_URL | Link.TYPE_JS_REQUIRED),
			               L10n.get("pas_http_discuss_list_manage"),
			               { "m": "discuss", "s": "list", "a": "manage", "dsd": { "dlid": lid } },
			               icon = "mini-default-option",
			               priority = 3
			              )
		#

		list_data = _list.get_data_attributes("id",
		                                      "id_main",
		                                      "title",
		                                      "time_sortable",
		                                      "sub_entries",
		                                      "hybrid_list",
		                                      "description",
		                                      "topics",
		                                      "posts"
		                                     )

		content = { "id": list_data['id'],
		            "title": list_data['title'],
		            "description": list_data['description'],
		            "time": list_data['time_sortable'],
#.........這裏部分代碼省略.........
開發者ID:dNG-git,項目名稱:pas_http_discuss,代碼行數:103,代碼來源:index.py

示例9: execute_topic

# 需要導入模塊: from dNG.data.text.input_filter import InputFilter [as 別名]
# 或者: from dNG.data.text.input_filter.InputFilter import filter_int [as 別名]
	def execute_topic(self):
	#
		"""
Action for "topic"

:since: v0.1.00
		"""

		tid = InputFilter.filter_file_path(self.request.get_dsd("dtid", ""))
		page = InputFilter.filter_int(self.request.get_dsd("dpage", 1))

		L10n.init("pas_http_datalinker")
		L10n.init("pas_http_discuss")

		try: topic = Topic.load_id(tid)
		except NothingMatchedException as handled_exception: raise TranslatableError("pas_http_discuss_tid_invalid", 404, _exception = handled_exception)

		session = (self.request.get_session() if (self.request.is_supported("session")) else None)
		if (session is not None): topic.set_permission_session(session)

		if (not topic.is_readable()):
		#
			if (session is None or session.get_user_profile() is None): raise TranslatableError("pas_http_discuss_tid_invalid", 404)
			else: raise TranslatableError("core_access_denied", 403)
		#

		if (self.response.is_supported("html_css_files")): self.response.add_theme_css_file("mini_default_sprite.min.css")

		if (topic.is_writable()):
		#
			Link.set_store("servicemenu",
			               (Link.TYPE_RELATIVE_URL | Link.TYPE_JS_REQUIRED),
			               L10n.get("pas_http_discuss_post_new"),
			               { "m": "discuss", "s": "post", "a": "new", "dsd": { "dtid": tid } },
			               icon = "mini-default-option",
			               priority = 3
			              )
		#

		subscription_handler = topic.get_subscription_handler()

		if (subscription_handler is not None and subscription_handler.is_subscribable_for_session_user(session)):
		#
			if (subscription_handler.is_subscribed_by_session_user(session)):
			#
				Link.set_store("servicemenu",
				               Link.TYPE_RELATIVE_URL,
				               L10n.get("pas_http_discuss_topic_unsubscribe"),
				               { "m": "discuss", "s": "topic_subscription", "a": "unsubscribe", "dsd": { "dtid": tid } },
				               icon = "mini-default-option",
				               priority = 3
				              )
			#
			else:
			#
				Link.set_store("servicemenu",
				               Link.TYPE_RELATIVE_URL,
				               L10n.get("pas_http_discuss_topic_subscribe"),
				               { "m": "discuss", "s": "topic_subscription", "a": "subscribe", "dsd": { "dtid": tid } },
				               icon = "mini-default-option",
				               priority = 3
				              )
			#
		#

		topic_parent = topic.load_parent()
		is_list = isinstance(topic_parent, List)

		if (isinstance(topic_parent, OwnableInstance)):
		#
			if (not topic_parent.is_readable_for_session_user(session)): raise TranslatableError("core_access_denied", 403)

			if (topic_parent.is_writable_for_session_user(session)):
			#
				topic_parent_id = topic_parent.get_id()

				dsd_parameters = ({ "dlid": topic_parent_id }
				                  if (is_list) else
				                  { "doid": tid }
				                 )

				Link.set_store("servicemenu",
				               (Link.TYPE_RELATIVE_URL | Link.TYPE_JS_REQUIRED),
				               L10n.get("pas_http_discuss_topic_new"),
				               { "m": "discuss", "s": "topic", "a": "new", "dsd": dsd_parameters },
				               icon = "mini-default-option",
				               priority = 3
				              )
			#

			if (is_list and topic_parent.is_manageable_for_session_user(session)):
			#
				Link.set_store("servicemenu",
				               (Link.TYPE_RELATIVE_URL | Link.TYPE_JS_REQUIRED),
				               L10n.get("pas_http_discuss_list_manage"),
				               { "m": "discuss", "s": "list", "a": "manage", "dsd": { "dlid": topic_parent_id } },
				               icon = "mini-default-option",
				               priority = 3
				              )
			#
#.........這裏部分代碼省略.........
開發者ID:dNG-git,項目名稱:pas_http_discuss,代碼行數:103,代碼來源:index.py


注:本文中的dNG.data.text.input_filter.InputFilter.filter_int方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。