Basic database operations
This commit is contained in:
parent
08e450bd51
commit
40ec00a4ad
3 changed files with 71 additions and 6 deletions
53
blog
53
blog
|
@ -1,9 +1,54 @@
|
||||||
#!/usr/bin/env raku
|
#!/usr/bin/env raku
|
||||||
|
use v6.e.PREVIEW;
|
||||||
|
|
||||||
use DB;
|
use DB;
|
||||||
|
|
||||||
my $example-post = DB::MarkdownPost.new:
|
my %*SUB-MAIN-OPTS =
|
||||||
source => "../Idris/advent/src/Util/Digits.md".IO,
|
:named-anywhere,
|
||||||
posted-at => DateTime.now;
|
:bundling,
|
||||||
|
;
|
||||||
|
|
||||||
say $example-post.title;
|
my IO::Path:D $blog-dir = $*PROGRAM.dirname.IO.dirname.IO;
|
||||||
|
#= The directory this script is located in
|
||||||
|
|
||||||
|
#| Load the database from the provided file
|
||||||
|
sub load-db(IO::Path $file --> DB::PostDB:D) {
|
||||||
|
my $result = DB::PostDB.from-json: $file.slurp;
|
||||||
|
if $result ~~ DB::PostDB:D {
|
||||||
|
return $result;
|
||||||
|
} else {
|
||||||
|
die "Error parsing $file as databse: $result";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#| Initalize the database
|
||||||
|
multi MAIN(
|
||||||
|
"db",
|
||||||
|
"init",
|
||||||
|
#| The path of the database file
|
||||||
|
IO::Path :$file = $blog-dir.add("db.json"),
|
||||||
|
#| Overwrite an already existing database file
|
||||||
|
Bool :$force
|
||||||
|
) {
|
||||||
|
die "Database file already exists, use --force to overwrite: {$file.Str}"
|
||||||
|
if $file.e && !$force;
|
||||||
|
|
||||||
|
my $db = DB::PostDB.new;
|
||||||
|
|
||||||
|
if $force {
|
||||||
|
$file.spurt: $db.to-json, :create-only;
|
||||||
|
} else {
|
||||||
|
$file.spurt: $db.to-json;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#| Ensure that the database loads, erroring otherwise
|
||||||
|
multi MAIN(
|
||||||
|
"db",
|
||||||
|
"verify",
|
||||||
|
#| The path of the database file
|
||||||
|
IO::Path :$file = $blog-dir.add("db.json"),
|
||||||
|
) {
|
||||||
|
load-db $file;
|
||||||
|
say "Database OK";
|
||||||
|
}
|
||||||
|
|
|
@ -1,10 +1,13 @@
|
||||||
|
use v6.e.PREVIEW;
|
||||||
|
|
||||||
#| Post database
|
#| Post database
|
||||||
unit module DB;
|
unit module DB;
|
||||||
|
|
||||||
use Pandoc;
|
use Pandoc;
|
||||||
|
use JSON::Class:auth<zef:vrurg>;
|
||||||
|
|
||||||
#| Shared post meta-data
|
#| Shared post meta-data
|
||||||
role Post {
|
role Post is json {
|
||||||
#| The location of the source file for the post
|
#| The location of the source file for the post
|
||||||
has IO::Path:D $.source is required;
|
has IO::Path:D $.source is required;
|
||||||
#| The time to display for the creation of the post
|
#| The time to display for the creation of the post
|
||||||
|
@ -18,9 +21,26 @@ role Post {
|
||||||
}
|
}
|
||||||
|
|
||||||
#| A plain markdown post
|
#| A plain markdown post
|
||||||
class MarkdownPost does Post {
|
class MarkdownPost does Post is json {
|
||||||
|
#| Marker for disambiguation between post types in json representation, the
|
||||||
|
#| cheaty way
|
||||||
|
has Bool:D $.markdown = True;
|
||||||
|
|
||||||
method title(--> Str:D) {
|
method title(--> Str:D) {
|
||||||
markdown-title($!source)
|
markdown-title($!source)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# #| A literate idris post in markdown format
|
||||||
|
# class IdrisPost does Post {
|
||||||
|
|
||||||
|
# method title(--> Str:D) {
|
||||||
|
# markdown-title($!source)
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
|
||||||
|
#| The top level posts database
|
||||||
|
class PostDB is json(:pretty) {
|
||||||
|
#| The inner list of posts
|
||||||
|
has Post:D @.posts = [];
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue