summaryrefslogtreecommitdiffstats
path: root/logfiles-model.lua
diff options
context:
space:
mode:
Diffstat (limited to 'logfiles-model.lua')
-rw-r--r--logfiles-model.lua68
1 files changed, 40 insertions, 28 deletions
diff --git a/logfiles-model.lua b/logfiles-model.lua
index 04c3386..fb19ec1 100644
--- a/logfiles-model.lua
+++ b/logfiles-model.lua
@@ -80,65 +80,77 @@ local do_grep = function(filecontent, grep)
end
end
-mymodule.get_filedetails = function (path, grep)
+mymodule.get_filedetails = function(self, clientdata)
+ local retval = cfe({ type="group", value={}, label="Logfile details" })
+ retval.value.filename = cfe({ label="File name", key=true })
+ retval.value.grep = cfe({ label="Grep", key=true })
+ self.handle_clientdata(retval, clientdata)
+
local success = false
local available_files = mymodule.get()
for i,file in ipairs(available_files.value) do
- if file.value.filename.value == path then
+ if file.value.filename.value == retval.value.filename.value then
success = true
break
end
end
- local file = path
+ local file = retval.value.filename.value
if success then
- local st = fs.stat(path)
+ local st = fs.stat(file)
while st.type == "link" do
st = fs.stat(posix.readlink(st.path))
end
file = st.path
end
local filedetails = modelfunctions.getfiledetails(file, function(filename) return success end)
- filedetails.value.filename.value = path
- if not filedetails.errtxt then
- do_grep(filedetails.value.filecontent, grep)
+ for n,v in pairs(filedetails.value) do
+ if n ~= "filename" then
+ retval.value[n] = v
+ end
+ end
+ if filedetails.errtxt then
+ retval.errtxt = filedetails.errtxt
+ else
+ do_grep(retval.value.filecontent, retval.value.grep.value)
end
- filedetails.value.grep = cfe({ value=grep or "", label="Grep" })
- return filedetails
+ return retval
end
-mymodule.tail = function(path, offset, grep)
- local filename = cfe({ value=path, label="File name", errtxt="File not found" })
- local filesize = cfe({ value="0", label="File size" })
- local filecontent = cfe({ type="longtext", label="File content" })
- local fileoffset = cfe({ value="0", label="File offset" })
- local filegrep = cfe({ value=grep or "", label="Grep" })
+mymodule.tail = function(self, clientdata)
+ local retval = cfe({ type="group", value={}, label="Tail Logfile" })
+ retval.value.filename = cfe({ label="File name", errtxt="File not found", key=true })
+ retval.value.offset = cfe({ value="0", label="File offset", key=true })
+ retval.value.grep = cfe({ label="Grep", key=true })
+ self.handle_clientdata(retval, clientdata)
+
+ retval.value.filesize = cfe({ value="0", label="File size" })
+ retval.value.filecontent = cfe({ type="longtext", label="File content" })
local available_files = mymodule.get()
for i,file in ipairs(available_files.value) do
- if ( file.value.filename.value == path ) then
- filename.errtxt = nil
- local f = io.open(path)
- if tonumber(offset) then
- fileoffset.value = offset
- offset = tonumber(offset)
+ if ( file.value.filename.value == retval.value.filename.value ) then
+ retval.value.filename.errtxt = nil
+ local f = io.open(retval.value.filename.value)
+ if tonumber(retval.value.offset.value) then
+ local offset = tonumber(retval.value.offset.value)
if offset < 0 then
f:seek("end", offset)
else
f:seek("set", offset)
end
- filecontent.value = f:read("*all")
- filesize.value = f:seek()
+ retval.value.filecontent.value = f:read("*all")
+ retval.value.filesize.value = f:seek()
else
- filesize.value = f:seek("end")
- fileoffset.value = filesize.value
+ retval.value.filesize.value = f:seek("end")
+ retval.value.offset.value = retval.value.filesize.value
end
f:close()
- do_grep(filecontent, grep)
+ do_grep(retval.value.filecontent, retval.value.grep.value)
break
end
end
-
- return cfe({ type="group", value={filename=filename, filecontent=filecontent, filesize=filesize, fileoffset=fileoffset, grep=filegrep}, label="Tail File" })
+
+ return retval
end
mymodule.get = function ()