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 {
    var app = new Angel();
    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');
}