Merge branch 'master' into improved_config
This commit is contained in:
		| @@ -28,7 +28,7 @@ class SimpleView(HTTPMethodView): | ||||
|   def delete(self, request): | ||||
|       return text('I am delete method') | ||||
|  | ||||
| app.add_route(SimpleView(), '/') | ||||
| app.add_route(SimpleView.as_view(), '/') | ||||
|  | ||||
| ``` | ||||
|  | ||||
| @@ -40,6 +40,19 @@ class NameView(HTTPMethodView): | ||||
|   def get(self, request, name): | ||||
|     return text('Hello {}'.format(name)) | ||||
|  | ||||
| app.add_route(NameView(), '/<name>') | ||||
| app.add_route(NameView.as_view(), '/<name>') | ||||
|  | ||||
| ``` | ||||
|  | ||||
| If you want to add decorator for class, you could set decorators variable | ||||
|  | ||||
| ``` | ||||
| class ViewWithDecorator(HTTPMethodView): | ||||
|   decorators = [some_decorator_here] | ||||
|  | ||||
|   def get(self, request, name): | ||||
|     return text('Hello I have a decorator') | ||||
|  | ||||
| app.add_route(ViewWithDecorator.as_view(), '/url') | ||||
|  | ||||
| ``` | ||||
|   | ||||
							
								
								
									
										70
									
								
								docs/custom_protocol.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								docs/custom_protocol.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| # Custom Protocol | ||||
|  | ||||
| You can change the behavior of protocol by using custom protocol.   | ||||
| If you want to use custom protocol, you should put subclass of [protocol class](https://docs.python.org/3/library/asyncio-protocol.html#protocol-classes) in the protocol keyword argument of `sanic.run()`. The constructor of custom protocol class gets following keyword arguments from Sanic. | ||||
|  | ||||
| * loop   | ||||
| `loop` is an asyncio compatible event loop. | ||||
|  | ||||
| * connections   | ||||
| `connections` is a `set object`  to  store protocol objects. | ||||
| When Sanic receives `SIGINT` or `SIGTERM`, Sanic executes `protocol.close_if_idle()` for a `protocol objects` stored in connections. | ||||
|  | ||||
| * signal   | ||||
| `signal` is a `sanic.server.Signal object` with `stopped attribute`. | ||||
| When Sanic receives `SIGINT` or `SIGTERM`, `signal.stopped` becomes `True`. | ||||
|  | ||||
| * request_handler   | ||||
| `request_handler` is a coroutine that takes a `sanic.request.Request` object and a `response callback` as arguments. | ||||
|  | ||||
| * error_handler   | ||||
| `error_handler` is a `sanic.exceptions.Handler` object. | ||||
|  | ||||
| * request_timeout   | ||||
| `request_timeout` is seconds for timeout. | ||||
|  | ||||
| * request_max_size   | ||||
| `request_max_size` is bytes of max request size. | ||||
|  | ||||
| ## Example | ||||
| By default protocol, an error occurs, if the handler does not return an `HTTPResponse object`.   | ||||
| In this example, By rewriting `write_response()`, if the handler returns `str`, it will be converted to an `HTTPResponse object`. | ||||
|  | ||||
| ```python | ||||
| from sanic import Sanic | ||||
| from sanic.server import HttpProtocol | ||||
| from sanic.response import text | ||||
|  | ||||
| app = Sanic(__name__) | ||||
|  | ||||
|  | ||||
| class CustomHttpProtocol(HttpProtocol): | ||||
|  | ||||
|     def __init__(self, *, loop, request_handler, error_handler, | ||||
|                  signal, connections, request_timeout, request_max_size): | ||||
|         super().__init__( | ||||
|             loop=loop, request_handler=request_handler, | ||||
|             error_handler=error_handler, signal=signal, | ||||
|             connections=connections, request_timeout=request_timeout, | ||||
|             request_max_size=request_max_size) | ||||
|  | ||||
|     def write_response(self, response): | ||||
|         if isinstance(response, str): | ||||
|             response = text(response) | ||||
|         self.transport.write( | ||||
|             response.output(self.request.version) | ||||
|         ) | ||||
|         self.transport.close() | ||||
|  | ||||
|  | ||||
| @app.route('/') | ||||
| async def string(request): | ||||
|     return 'string' | ||||
|  | ||||
|  | ||||
| @app.route('/1') | ||||
| async def response(request): | ||||
|     return text('response') | ||||
|  | ||||
| app.run(host='0.0.0.0', port=8000, protocol=CustomHttpProtocol) | ||||
| ``` | ||||
| @@ -33,12 +33,12 @@ async def handler1(request): | ||||
| 	return text('OK') | ||||
| app.add_route(handler1, '/test') | ||||
|  | ||||
| async def handler(request, name): | ||||
| async def handler2(request, name): | ||||
| 	return text('Folder - {}'.format(name)) | ||||
| app.add_route(handler, '/folder/<name>') | ||||
| app.add_route(handler2, '/folder/<name>') | ||||
|  | ||||
| async def person_handler(request, name): | ||||
| async def person_handler2(request, name): | ||||
| 	return text('Person - {}'.format(name)) | ||||
| app.add_route(handler, '/person/<name:[A-z]>') | ||||
| app.add_route(person_handler2, '/person/<name:[A-z]>') | ||||
|  | ||||
| ``` | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Tim Mundt
					Tim Mundt