log_dialog.py 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. #!/usr/bin/python2
  2. #
  3. # The Qubes OS Project, http://www.qubes-os.org
  4. #
  5. # Copyright (C) 2012 Agnieszka Kostrzewa <agnieszka.kostrzewa@gmail.com>
  6. # Copyright (C) 2012 Marek Marczykowski <marmarek@mimuw.edu.pl>
  7. #
  8. # This program is free software; you can redistribute it and/or
  9. # modify it under the terms of the GNU General Public License
  10. # as published by the Free Software Foundation; either version 2
  11. # of the License, or (at your option) any later version.
  12. #
  13. # This program is distributed in the hope that it will be useful,
  14. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. # GNU General Public License for more details.
  17. #
  18. # You should have received a copy of the GNU General Public License
  19. # along with this program; if not, write to the Free Software
  20. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  21. #
  22. #
  23. import sys
  24. import os
  25. import fcntl
  26. from PyQt4.QtCore import *
  27. from PyQt4.QtGui import *
  28. from qubes.qubes import QubesException
  29. import qubesmanager.resources_rc
  30. from ui_logdlg import *
  31. # Display only this size of log
  32. LOG_DISPLAY_SIZE = 1024*1024
  33. class LogDialog(Ui_LogDialog, QDialog):
  34. def __init__(self, app, log_path, parent=None):
  35. super(LogDialog, self).__init__(parent)
  36. self.app = app
  37. self.log_path = log_path
  38. self.setupUi(self)
  39. self.setWindowTitle(log_path)
  40. self.connect(self.copy_to_qubes_clipboard, SIGNAL("clicked()"), self.copy_to_qubes_clipboard_triggered)
  41. self.__init_log_text__()
  42. def __init_log_text__(self):
  43. self.displayed_text = ""
  44. log = open(self.log_path)
  45. log.seek(0, os.SEEK_END)
  46. if log.tell() > LOG_DISPLAY_SIZE:
  47. self.displayed_text = "(Showing only last %d bytes of file)\n" % LOG_DISPLAY_SIZE
  48. log.seek(-LOG_DISPLAY_SIZE, os.SEEK_END)
  49. else:
  50. log.seek(0, os.SEEK_SET)
  51. self.displayed_text += log.read()
  52. log.close()
  53. self.log_text.setPlainText(self.displayed_text)
  54. def copy_to_qubes_clipboard_triggered(self):
  55. copy_text_to_qubes_clipboard(self.displayed_text)
  56. ########################COPY TEXT TO QUBES CLIPBOARD
  57. def copy_text_to_qubes_clipboard(text):
  58. #inter-appviewer lock
  59. try:
  60. fd = os.open("/var/run/qubes/appviewer.lock", os.O_RDWR|os.O_CREAT, 0666)
  61. fcntl.flock(fd, fcntl.LOCK_EX)
  62. except IOError:
  63. QMessageBox.warning (None, "Warning!", "Error while accessing Qubes clipboard!")
  64. return
  65. qubes_clipboard = open("/var/run/qubes/qubes-clipboard.bin", 'w')
  66. qubes_clipboard.write(text)
  67. qubes_clipboard.close()
  68. qubes_clip_source = open("/var/run/qubes/qubes-clipboard.bin.source", 'w')
  69. qubes_clip_source.write("dom0")
  70. qubes_clip_source.close()
  71. try:
  72. fcntl.flock(fd, fcntl.LOCK_UN)
  73. os.close(fd)
  74. except IOError:
  75. QMessageBox.warning (None, "Warning!", "Error while writing to Qubes clipboard!")
  76. return