2018-11-11 17:35:37 +00:00
|
|
|
import 'dart:io';
|
|
|
|
import 'package:angel_framework/angel_framework.dart';
|
|
|
|
import 'package:angel_framework/http.dart';
|
|
|
|
import 'package:angel_shelf/angel_shelf.dart';
|
2019-10-14 15:28:50 +00:00
|
|
|
import 'package:logging/logging.dart';
|
|
|
|
import 'package:pretty_logging/pretty_logging.dart';
|
2018-11-11 17:35:37 +00:00
|
|
|
import 'package:shelf_static/shelf_static.dart';
|
|
|
|
|
|
|
|
main() async {
|
2019-10-14 15:28:50 +00:00
|
|
|
Logger.root
|
|
|
|
..level = Level.ALL
|
|
|
|
..onRecord.listen(prettyLog);
|
2019-10-14 16:38:30 +00:00
|
|
|
|
2019-10-14 15:28:50 +00:00
|
|
|
var app = Angel(logger: Logger('angel_shelf_demo'));
|
|
|
|
var http = AngelHttp(app);
|
2018-11-11 17:35:37 +00:00
|
|
|
|
|
|
|
// `shelf` request handler
|
|
|
|
var shelfHandler = createStaticHandler('.',
|
|
|
|
defaultDocument: 'index.html', listDirectories: true);
|
|
|
|
|
|
|
|
// Use `embedShelf` to adapt a `shelf` handler for use within Angel.
|
|
|
|
var wrappedHandler = embedShelf(shelfHandler);
|
|
|
|
|
|
|
|
// A normal Angel route.
|
|
|
|
app.get('/angel', (req, ResponseContext res) {
|
|
|
|
res.write('Hooray for `package:angel_shelf`!');
|
|
|
|
return false; // End execution of handlers, so we don't proxy to dartlang.org when we don't need to.
|
|
|
|
});
|
|
|
|
|
2019-10-14 15:28:50 +00:00
|
|
|
// Pass any other request through to the static file handler
|
2018-11-11 17:35:37 +00:00
|
|
|
app.fallback(wrappedHandler);
|
|
|
|
|
|
|
|
await http.startServer(InternetAddress.loopbackIPv4, 8080);
|
2019-10-14 15:28:50 +00:00
|
|
|
print('Running at ${http.uri}');
|
2018-11-11 17:35:37 +00:00
|
|
|
}
|