platform/packages/proxy
2022-04-24 09:42:33 +08:00
..
example Published proxy and file_service 2021-06-10 16:47:05 +08:00
lib Updated websocket 2021-07-10 12:32:42 +08:00
test Updated websocket 2021-07-10 12:32:42 +08:00
.gitignore Add 'packages/proxy/' from commit 'daca263062d471ae007730fa8ecf854c09c746f8' 2020-02-15 18:22:25 -05:00
analysis_options.yaml Updated linter 2022-01-04 20:03:52 +08:00
AUTHORS.md Published proxy and file_service 2021-06-10 16:47:05 +08:00
CHANGELOG.md Updated to SDK 2.16.x 2022-04-23 12:21:39 +08:00
LICENSE Updated linter 2022-01-04 20:03:52 +08:00
melos_angel3_proxy.iml Added melos 2022-03-19 09:37:28 +08:00
pubspec.yaml Published 6.0.0 2022-04-24 09:42:33 +08:00
README.md Updated to lints linter 2022-01-05 12:03:02 +08:00

Angel3 Proxy

Pub Version (including pre-releases) Null Safety Gitter License

Angel3 middleware to forward requests to another server (i.e. webdev serve). Also supports WebSockets.

import 'package:angel3_proxy/angel3_proxy.dart';
import 'package:http/http.dart' as http;

void main() async {
  // Forward requests instead of serving statically.
  // You can also pass a URI, instead of a string.
  var proxy1 = Proxy('http://localhost:3000');
  
  // handle all methods (GET, POST, ...)
  app.fallback(proxy.handleRequest);
}

You can also restrict the proxy to serving only from a specific root:

Proxy(baseUrl, publicPath: '/remote');

Also, you can map requests to a root path on the remote server:

Proxy(baseUrl.replace(path: '/path'));

Request bodies will be forwarded as well, if they are not empty. This allows things like POST requests to function.

For a request body to be forwarded, the body must not have already been parsed.