Mercurial Hosting > luan
changeset 1429:82415c9c0015
move versioning into Lucene
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Sun, 24 Nov 2019 23:07:21 -0700 (2019-11-25) |
parents | d21a7cf8fa9e |
children | 103d0ce70385 |
files | examples/blog/src/lib/Db.luan examples/blog/src/lib/Post.luan examples/blog/src/private/tools/backup.html.luan examples/blog/src/private/tools/lucene.html.luan examples/blog/test.luan examples/blog/test.sh scripts/test.luan src/luan/modules/lucene/Lucene.luan src/luan/modules/lucene/Versioning.luan |
diffstat | 9 files changed, 47 insertions(+), 144 deletions(-) [+] |
line wrap: on
line diff
--- a/examples/blog/src/lib/Db.luan Sun Nov 24 21:02:38 2019 -0700 +++ b/examples/blog/src/lib/Db.luan Sun Nov 24 23:07:21 2019 -0700 @@ -10,8 +10,6 @@ local logger = Logging.logger "Db" -local Db = {} - local postgres_spec = Hosted.postgres_spec() --logger.info(stringify(postgres_spec)) @@ -19,25 +17,23 @@ return doc end -function Db.new(lucene_dir) - local dir = Io.uri(lucene_dir) - local db = Lucene.index( dir, { - version = "2" - default_type = Lucene.type.english - default_fields = {"subject","content"} - completer = completer - postgres_spec = postgres_spec - } ) - +local dir = Io.uri("site:/private/local/lucene") +local Db = Lucene.index( dir, { + default_type = Lucene.type.english + default_fields = {"subject","content"} + completer = completer + postgres_spec = postgres_spec +} ) + -- this is how you index a field -- db.indexed_fields.post_date = Lucene.type.long - return db -end - -Db.db = Db.new("site:/private/local/lucene") - -Db.db.restore_from_postgres() -Thread.schedule( Db.db.check, { delay=0, repeating_delay=Time.period{hours=1}, id="blog-db-check" } ) +Db.restore_from_postgres() +Db.update{ + [1] = function() + logger.info "update" + end +} +Thread.schedule( Db.check, { delay=0, repeating_delay=Time.period{hours=1}, id="blog-db-check" } ) return Db
--- a/examples/blog/src/lib/Post.luan Sun Nov 24 21:02:38 2019 -0700 +++ b/examples/blog/src/lib/Post.luan Sun Nov 24 23:07:21 2019 -0700 @@ -6,7 +6,7 @@ local now = Time.now or error() local String = require "luan:String.luan" local trim = String.trim or error() -local db = require("site:/lib/Db.luan").db or error() +local Db = require "site:/lib/Db.luan" local Post = {} @@ -33,7 +33,7 @@ content = this.content date = this.date } - db.save(doc) + Db.save(doc) this.id = doc.id end @@ -41,12 +41,12 @@ end function Post.get_by_id(id) - local doc = db.get_document("id:"..id) + local doc = Db.get_document("id:"..id) return doc and from_doc(doc) end function Post.get_all() - local docs = db.search("type:post",1,1000,{sort="id desc"}) + local docs = Db.search("type:post",1,1000,{sort="id desc"}) local posts = {} for _, doc in ipairs(docs) do posts[#posts+1] = from_doc(doc) @@ -59,7 +59,7 @@ if #query == 0 then return Post.get_all() end - local docs = db.search(query,1,1000) + local docs = Db.search(query,1,1000) local posts = {} for _, doc in ipairs(docs) do posts[#posts+1] = from_doc(doc) @@ -68,7 +68,7 @@ end function Post.delete_by_id(id) - db.delete("id:"..id) + Db.delete("id:"..id) end return Post
--- a/examples/blog/src/private/tools/backup.html.luan Sun Nov 24 21:02:38 2019 -0700 +++ b/examples/blog/src/private/tools/backup.html.luan Sun Nov 24 23:07:21 2019 -0700 @@ -2,13 +2,13 @@ local error = Luan.error local Io = require "luan:Io.luan" local Http = require "luan:http/Http.luan" -local db = require("site:/lib/Db.luan").db or error() +local Db = require "site:/lib/Db.luan" return function() local backup = Io.uri "site:/private/local/backup.zip" backup.delete() - db.zip(backup) + Db.zip(backup) Io.stdout = Http.response.text_writer() %>
--- a/examples/blog/src/private/tools/lucene.html.luan Sun Nov 24 21:02:38 2019 -0700 +++ b/examples/blog/src/private/tools/lucene.html.luan Sun Nov 24 23:07:21 2019 -0700 @@ -1,6 +1,6 @@ local Luan = require "luan:Luan.luan" local error = Luan.error local Web_search = require "luan:lucene/Web_search.luan" -local db = require("site:/lib/Db.luan").db or error() +local Db = require "site:/lib/Db.luan" -return Web_search.of(db) +return Web_search.of(Db)
--- a/examples/blog/test.luan Sun Nov 24 21:02:38 2019 -0700 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,58 +0,0 @@ -local Luan = require "luan:Luan.luan" -local error = Luan.error -local to_string = Luan.to_string or error() -local Http = require "luan:http/Http.luan" -local Http_test = require "luan:http/Http_test.luan" -local init = Http_test.init or error() -local get_page = Http_test.get_page or error() -local Io = require "luan:Io.luan" -local print = Io.print or error() -local String = require "luan:String.luan" -local matches = String.matches or error() - -local Db = require "site:/lib/Db.luan" -Db.db = Db.new("site:/private/local/lucene_test") -Db.db.delete_all() - -local Post = require "site:/lib/Post.luan" -local page - -print 'go' - -init() -print '/' -get_page '/' - -init() -print '/new.html' -get_page '/new.html' - -init() -Http.request.parameters.subject = 'test' -Http.request.parameters.content = 'this is a test' -Http.request.parameters.save = 'whatever' -print '/new.html submit' -get_page '/new.html' -local posts = Post.get_all() -#posts == 1 or error() -local post_id = to_string(posts[1].id) - -init() -Http.request.parameters.post = post_id -print '/edit.html' -get_page '/edit.html' - -init() -Http.request.parameters.post = post_id -Http.request.parameters.subject = 'test' -Http.request.parameters.content = 'this is an edit' -Http.request.parameters.save = 'whatever' -print '/edit.html submit' -get_page '/edit.html' - -init() -print '/ again' -page = get_page '/' -matches(page,'this is an edit') or error() - -print 'done'
--- a/examples/blog/test.sh Sun Nov 24 21:02:38 2019 -0700 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,1 +0,0 @@ -luan luan:http/test.luan src test.luan 2>&1 | tee err
--- a/scripts/test.luan Sun Nov 24 21:02:38 2019 -0700 +++ b/scripts/test.luan Sun Nov 24 23:07:21 2019 -0700 @@ -12,7 +12,6 @@ local Http_test = require "luan:http/Http_test.luan" local Server = require "luan:http/Server.luan" local Lucene = require "luan:lucene/Lucene.luan" -local Versioning = require "luan:lucene/Versioning.luan" local Mail = require "luan:mail/Mail.luan" local error = Luan.error
--- a/src/luan/modules/lucene/Lucene.luan Sun Nov 24 21:02:38 2019 -0700 +++ b/src/luan/modules/lucene/Lucene.luan Sun Nov 24 23:07:21 2019 -0700 @@ -2,10 +2,13 @@ local Luan = require "luan:Luan.luan" local error = Luan.error local ipairs = Luan.ipairs or error() +local pairs = Luan.pairs or error() local type = Luan.type or error() local set_metatable = Luan.set_metatable or error() local Boot = require "luan:Boot.luan" local Html = require "luan:Html.luan" +local Number = require "luan:Number.luan" +local integer = Number.integer or error() local Io = require "luan:Io.luan" local uri = Io.uri or error() local String = require "luan:String.luan" @@ -159,6 +162,25 @@ end index.restore = Boot.no_security(index.restore) + function index.update(steps) + local version = 0 + for i in pairs(steps) do + if version < i then + version = i + end + end + local doc = index.get_document"type:version" or { type="version", version=integer(0) } + while doc.version < version do + doc.version = integer(doc.version + 1) + logger.error("step "..doc.version) + index.run_in_transaction( function() + local step = steps[doc.version] or error("missing step "..doc.version) + step() + index.save(doc) + end ) + end + end + local function multi_error() error "multiple lucene instances" end
--- a/src/luan/modules/lucene/Versioning.luan Sun Nov 24 21:02:38 2019 -0700 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,55 +0,0 @@ -local Luan = require "luan:Luan.luan" -local error = Luan.error -local pairs = Luan.pairs or error() -local Number = require "luan:Number.luan" -local integer = Number.integer or error() -local long = Number.long or error() -local String = require "luan:String.luan" -local matches = String.matches or error() -local sub = String.sub or error() -local string_to_number = String.to_number or error() -local Table = require "luan:Table.luan" -local copy = Table.copy or error() -local Lucene = require "luan:lucene/Lucene.luan" -local Logging = require "luan:logging/Logging.luan" - -local logger = Logging.logger "lucene versioning" - - -local Versioning = {} - -function Versioning.update(db,steps,version) - local doc = db.get_document"type:version" or { type="version", version=integer(0) } - while doc.version < version do - doc.version = integer(doc.version + 1) - logger.error("step "..doc.version) - db.run_in_transaction( function() - local step = steps[doc.version] - step and step(db) - db.save(doc) - end ) - end -end - - --- hack to deal with latest changes -function Versioning.a_big_step(db) - db.indexed_fields["id index"] = Lucene.type.string - db.advanced_search( Lucene.quote"id index" .. ":*", function(_,doc_fn) - local doc = doc_fn() - for field, value in pairs(copy(doc)) do - if matches(field," index$") then - local new_field = sub(field,1,-7) - db.indexed_fields[new_field] or error("field '"..new_field.."' not indexed") - doc[new_field] = value - doc[field] = nil - end - end - doc.id = long(string_to_number(doc.id)) - db.save(doc) - end ) - db.indexed_fields["type index"] = Lucene.type.string - db.delete( Lucene.quote"type index" .. ":*" ) -end - -return Versioning