summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2011-01-26 14:56:23 -0600
committerJesse Luehrs <doy@tozt.net>2011-01-26 14:56:23 -0600
commit0d2b29fd9d932f909f46209d17963752379ea545 (patch)
treee27792b5aa077339b22d8d6c6bd9597d296f519a /lib
parentaf5867fd48b84c7ea1cba67574294334bb2cc19e (diff)
downloadnarwhal-0d2b29fd9d932f909f46209d17963752379ea545.tar.gz
narwhal-0d2b29fd9d932f909f46209d17963752379ea545.zip
initial sketch
Diffstat (limited to 'lib')
-rw-r--r--lib/Narwhal.pm43
-rw-r--r--lib/Narwhal/Component/Redirect.pm31
-rw-r--r--lib/Narwhal/Component/Wiki.pm65
-rw-r--r--lib/Narwhal/Page.pm12
4 files changed, 151 insertions, 0 deletions
diff --git a/lib/Narwhal.pm b/lib/Narwhal.pm
index e69de29..240b504 100644
--- a/lib/Narwhal.pm
+++ b/lib/Narwhal.pm
@@ -0,0 +1,43 @@
+package Narwhal;
+use OX;
+
+config kioku_dsn => 'dbi:SQLite:narwhal.db';
+config kioku_extra_args => sub { { create => 1 } };
+config template_root => sub {
+ shift->param('app_root')->subdir('root', 'templates')
+}, (app_root => depends_on('/app_root'));
+
+component Redirect => 'Narwhal::Component::Redirect';
+
+component Wiki => 'Narwhal::Component::Wiki', (
+ kioku => depends_on('/Component/Kioku'),
+ tt => depends_on('/Component/TT'),
+);
+
+# turn these two into specialized classes later
+component TT => 'Template', (
+ INCLUDE_PATH => depends_on('/Config/template_root'),
+);
+
+component Kioku => 'KiokuX::Model', (
+ dsn => depends_on('/Config/kioku_dsn'),
+ extra_args => depends_on('/Config/kioku_extra_args'),
+);
+
+router as {
+ route '/' => 'redirect.permanent', (
+ to => '/page/main',
+ );
+ route '/page/:page_name' => 'wiki.page', (
+ page_name => { isa => 'Str' },
+ );
+ route '/edit/:page_name' => 'wiki.edit', (
+ page_name => { isa => 'Str' },
+ );
+}, (
+ redirect => depends_on('/Component/Redirect'),
+ wiki => depends_on('/Component/Wiki'),
+);
+
+no OX;
+1;
diff --git a/lib/Narwhal/Component/Redirect.pm b/lib/Narwhal/Component/Redirect.pm
new file mode 100644
index 0000000..58a8478
--- /dev/null
+++ b/lib/Narwhal/Component/Redirect.pm
@@ -0,0 +1,31 @@
+package Narwhal::Component::Redirect;
+use Moose;
+
+sub permanent {
+ my $self = shift;
+ my ($req) = @_;
+ my $res = $req->new_response(301);
+ $res->location($self->_get_location($req));
+ return $res;
+}
+
+sub temporary {
+ my $self = shift;
+ my ($req) = @_;
+ my $res = $req->new_response(302);
+ $res->location($self->_get_location($req));
+ return $res;
+}
+
+sub _get_location {
+ my $self = shift;
+ my ($req) = @_;
+ my $to = $req->env->{'plack.router.match'}->route->defaults->{to};
+ die "must supply a location to redirect to" unless $to;
+ return $to;
+}
+
+__PACKAGE__->meta->make_immutable;
+no Moose;
+
+1;
diff --git a/lib/Narwhal/Component/Wiki.pm b/lib/Narwhal/Component/Wiki.pm
new file mode 100644
index 0000000..5b89816
--- /dev/null
+++ b/lib/Narwhal/Component/Wiki.pm
@@ -0,0 +1,65 @@
+package Narwhal::Component::Wiki;
+use Moose;
+
+use Narwhal::Page;
+
+has kioku => (
+ isa => 'KiokuX::Model',
+ required => 1,
+ handles => 'KiokuDB::Role::API',
+);
+
+has tt => (
+ isa => 'Template',
+ required => 1,
+ handles => ['process'],
+);
+
+has scope => (
+ is => 'ro',
+ isa => 'KiokuDB::LiveObjects::Scope',
+ lazy => 1,
+ default => sub { shift->new_scope },
+);
+
+sub BUILD {
+ my $self = shift;
+ $self->scope;
+}
+
+sub page {
+ my $self = shift;
+ my ($req, $page) = @_;
+ my $page_obj = $self->lookup("page:$page");
+ return $req->new_response(404)
+ unless $page_obj;
+ my $out;
+ $self->process('page.tt', { uri_for => sub { '/' . $req->uri_for({@_}) }, text => $page_obj->text, page => $page }, \$out);
+ return $req->new_response(200, [], $out);
+}
+
+sub edit {
+ my $self = shift;
+ my ($req, $page) = @_;
+ if ($req->method eq 'POST') {
+ my $page_obj = Narwhal::Page->new(text => $req->param('text'));
+ $self->txn_do(sub {
+ $self->delete("page:$page");
+ $self->insert("page:$page" => $page_obj);
+ });
+ my $res = $req->new_response(303);
+ $res->location('/' . $req->uri_for({controller => 'wiki', action => 'page', page_name => $page}));
+ return $res;
+ }
+ else {
+ my $page_obj = $self->lookup("page:$page");
+ my $out;
+ $self->process('edit.tt', { uri_for => sub { '/' . $req->uri_for({@_}) }, text => ($page_obj ? $page_obj->text : ''), page => $page }, \$out);
+ return $req->new_response(200, [], $out);
+ }
+}
+
+__PACKAGE__->meta->make_immutable;
+no Moose;
+
+1;
diff --git a/lib/Narwhal/Page.pm b/lib/Narwhal/Page.pm
new file mode 100644
index 0000000..d3e0a4d
--- /dev/null
+++ b/lib/Narwhal/Page.pm
@@ -0,0 +1,12 @@
+package Narwhal::Page;
+use Moose;
+
+has text => (
+ is => 'ro',
+ isa => 'Str',
+);
+
+__PACKAGE__->meta->make_immutable;
+no Moose;
+
+1;