From ba1caee706c51e25a6ee325f4c338aa4d2d31292 Mon Sep 17 00:00:00 2001 From: dakkar Date: Sun, 17 Dec 2017 19:09:31 +0000 Subject: split pieces into modules --- lib/Ultramarine/Controller.pm6 | 34 +++++++++++++++++++++++++++++ lib/Ultramarine/Model/License.pm6 | 11 ++++++++++ lib/Ultramarine/Server.pm | 46 +++++++++++++++++++++++++++++++++++++++ 3 files changed, 91 insertions(+) create mode 100644 lib/Ultramarine/Controller.pm6 create mode 100644 lib/Ultramarine/Model/License.pm6 create mode 100644 lib/Ultramarine/Server.pm (limited to 'lib') diff --git a/lib/Ultramarine/Controller.pm6 b/lib/Ultramarine/Controller.pm6 new file mode 100644 index 0000000..29433fd --- /dev/null +++ b/lib/Ultramarine/Controller.pm6 @@ -0,0 +1,34 @@ +use v6.d.PREVIEW; +use Cro::HTTP::Router; + +class Ultramarine::Controller { + has $.license is required; + has $.authorisation is required; + + sub respond(*@body) { + response.status = 200; + response.set-body(@body); + } + + submethod inner-routes() { + return route { + # this needs to be here, not in the Server because its + # short-circuited "unauthorised" response will be emited + # in an 'after' middleware, but the + # ResponseSerializerExtension is applied just before those + # middlewares, so our serialised won't be seen by the + # "unauthorised" response + before $!authorisation; + post -> 'ping.view' { respond [] } + post -> 'getLicense.view' { + respond [ license => [ |%($!license.status) ] ], + } + } + } + + method routes() { + return route { + include rest => self.inner-routes(), + } + } +} diff --git a/lib/Ultramarine/Model/License.pm6 b/lib/Ultramarine/Model/License.pm6 new file mode 100644 index 0000000..2ceeaa5 --- /dev/null +++ b/lib/Ultramarine/Model/License.pm6 @@ -0,0 +1,11 @@ +use v6.d.PREVIEW; + +class Ultramarine::Model::License { + method status() { + return { + :valid, + :email, + :licenseExpires<2019-01-01:00:00:00>, + } + } +} diff --git a/lib/Ultramarine/Server.pm b/lib/Ultramarine/Server.pm new file mode 100644 index 0000000..ec7220c --- /dev/null +++ b/lib/Ultramarine/Server.pm @@ -0,0 +1,46 @@ +use v6.d.PREVIEW; +use Cro::HTTP::Server; +use Cro::HTTP::Request; +use Cro::HTTP::Response; + +class Ultramarine::Server { + has $.authentication is required; + has @.serialisers is required; + has $.set-content-type is required; + has $.controller is required; + has $.host = 'localhost'; + has $.port = 8080; + has $.do-trace = False; + + my class Trace does Cro::Transform { + has $.type is required; + + method consumes() { $!type } + method produces() { $!type } + + method transformer(Supply $input --> Supply) { + supply whenever $input -> $thing { + say $thing.trace-output,"\n"; + say (await $thing.body-text).indent(2); + emit $thing; + } + } + } + + method server() { + return Cro::HTTP::Server.new( + :$!host, + :$!port, + application => $!controller, + before => [ + $.do-trace ?? Trace.new(type=>Cro::HTTP::Request) !! (), + $.authentication, + ], + add-body-serializers => @.serialisers, + after => [ + $.set-content-type, + $.do-trace ?? Trace.new(type=>Cro::HTTP::Response) !! (), + ], + ); + } +} -- cgit v1.2.3