2018-08-04 03:05:51 +00:00
|
|
|
import 'dart:async';
|
|
|
|
import 'dart:io';
|
|
|
|
|
|
|
|
import 'package:angel_framework/angel_framework.dart';
|
|
|
|
import 'package:angel_hot/angel_hot.dart';
|
|
|
|
import 'package:logging/logging.dart';
|
|
|
|
import 'package:star_wars/src/pretty_logging.dart' as star_wars;
|
|
|
|
import 'package:star_wars/star_wars.dart' as star_wars;
|
|
|
|
|
|
|
|
main() async {
|
|
|
|
Future<Angel> createServer() async {
|
2019-01-23 19:52:02 +00:00
|
|
|
var app = new Angel();
|
2018-08-04 03:05:51 +00:00
|
|
|
app.logger = new Logger('star_wars')..onRecord.listen(star_wars.prettyLog);
|
|
|
|
await app.configure(star_wars.configureServer);
|
|
|
|
return app;
|
|
|
|
}
|
|
|
|
|
|
|
|
hierarchicalLoggingEnabled = true;
|
|
|
|
|
|
|
|
var hot = new HotReloader(createServer, [new Directory('lib')]);
|
|
|
|
|
|
|
|
var server = await hot.startServer('127.0.0.1', 3000);
|
|
|
|
var serverUrl =
|
|
|
|
new Uri(scheme: 'http', host: server.address.address, port: server.port);
|
|
|
|
var graphiQLUrl = serverUrl.replace(path: '/graphiql');
|
|
|
|
print('Listening at $serverUrl');
|
|
|
|
print('GraphiQL endpoint: $graphiQLUrl');
|
|
|
|
}
|