liquid_feedback_frontend
view app/main/draft/diff.lua @ 9:0ee1e0c42d4c
Version beta5
Minor security fix: Added missing security filter for admin section. Reading of member listing including login names was possible for all users. Write access has not been possible though.
Changing of name and login is possible while a history of these changes is written and accessible by all users.
Statistics shown in area list
Trimming of user input also converts multiple whitespaces to single space character.
Minor security fix: Added missing security filter for admin section. Reading of member listing including login names was possible for all users. Write access has not been possible though.
Changing of name and login is possible while a history of these changes is written and accessible by all users.
Statistics shown in area list
Trimming of user input also converts multiple whitespaces to single space character.
| author | bsw | 
|---|---|
| date | Mon Jan 04 12:00:00 2010 +0100 (2010-01-04) | 
| parents | 5c601807d397 | 
| children | 72c5e0ee7c98 | 
 line source
     1 slot.put_into("title", _"Diff")
     3 local old_draft_id = param.get("old_draft_id", atom.integer)
     4 local new_draft_id = param.get("new_draft_id", atom.integer)
     6 if old_draft_id > new_draft_id then
     7   local tmp = old_draft_id
     8   old_draft_id = new_draft_id
     9   new_draft_id = tmp
    10 end
    12 local old_draft = Draft:by_id(old_draft_id)
    13 local new_draft = Draft:by_id(new_draft_id)
    15 local key = multirand.string(26, "123456789bcdfghjklmnpqrstvwxyz");
    17 local old_draft_filename = encode.file_path(request.get_app_basepath(), 'tmp', "diff-" .. key .. "-old.tmp")
    18 local new_draft_filename = encode.file_path(request.get_app_basepath(), 'tmp', "diff-" .. key .. "-new.tmp")
    20 local old_draft_file = assert(io.open(old_draft_filename, "w"))
    21 old_draft_file:write(old_draft.content)
    22 old_draft_file:write("\n")
    23 old_draft_file:close()
    25 local new_draft_file = assert(io.open(new_draft_filename, "w"))
    26 new_draft_file:write(new_draft.content)
    27 new_draft_file:write("\n")
    28 new_draft_file:close()
    30 local output, err, status = os.pfilter(nil, "sh", "-c", "diff -U 100000 '" .. old_draft_filename .. "' '" .. new_draft_filename .. "' | grep -v ^--- | grep -v ^+++ | grep -v ^@")
    32 os.remove(old_draft_filename)
    33 os.remove(new_draft_filename)
    35 if not status then
    36   ui.field.text{ value = _"The drafts do not differ" }
    37 else
    38   slot.put('<table class="diff">')
    39   slot.put('<tr><th width="50%">' .. _"Old draft revision" .. '</th><th width="50%">' .. _"New draft revision" .. '</th></tr>')
    40   local last_state = "unchanged"
    41   local lines = {}
    42   local removed_lines = nil
    43   output = output .. " "
    44   output = output:gsub("[^\n\r]+", function(line)
    45     local state = "unchanged"
    46     local char = line:sub(1,1)
    47     line = line:sub(2)
    48     state = "unchanged"
    49     if char == "-" then
    50       state = "-"
    51     elseif char == "+" then
    52       state = "+"
    53     end
    54     if last_state == "unchanged" then
    55       if state == "unchanged" then
    56         lines[#lines+1] = line
    57       elseif (state == "-") or (state == "+") then
    58         local text = table.concat(lines, "<br />")
    59         slot.put("<tr><td>", text, "</td><td>", text, "</td></tr>")
    60         lines = { line }
    61       end
    62     elseif last_state == "-" then
    63       if state == "-" then
    64         lines[#lines+1] = line
    65       elseif state == "+" then
    66         removed_lines = lines
    67         lines = { line }
    68       elseif state == "unchanged" then
    69         local text = table.concat(lines,"<br />")
    70         slot.put('<tr><td class="removed">', text, "</td><td></td></tr>")
    71         lines = { line }
    72       end
    73     elseif last_state == "+" then
    74       if state == "+" then
    75         lines[#lines+1] = line
    76       elseif (state == "-") or (state == "unchanged") then
    77         if removed_lines then
    78           local text = table.concat(lines, "<br />")
    79           local removed_text = table.concat(removed_lines, "<br />")
    80           slot.put('<tr><td class="removed">', removed_text, '</td><td class="added">', text, "</td></tr>")
    81         else
    82           local text = table.concat(lines, "<br />")
    83           slot.put('<tr><td></td><td class="added">', text, "</td></tr>")
    84         end
    85         removed_lines = nil
    86         lines = { line }
    87       end
    88     end
    89     last_state = state
    90   end)
    91   slot.put("</table>")
    92 end 
