mirror of
https://github.com/freedombox/FreedomBox.git
synced 2026-01-21 07:55:00 +00:00
- Remove apps and system modules and merge their views into main views. - Move main_menu from cfg into menu.py. - Remove dependencies of other modules on apps and system modules. - Update tests. Signed-off-by: Sunil Mohan Adapa <sunil@medhas.org>
93 lines
2.9 KiB
Python
93 lines
2.9 KiB
Python
#
|
|
# This file is part of Plinth.
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero General Public License as
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
# License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Affero General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
|
|
"""
|
|
Help module for Plinth.
|
|
"""
|
|
|
|
import os
|
|
from apt.cache import Cache
|
|
from django.http import Http404
|
|
from django.template.response import TemplateResponse
|
|
from django.utils.translation import ugettext as _, ugettext_lazy
|
|
from stronghold.decorators import public
|
|
|
|
from plinth import cfg, __version__
|
|
from plinth.menu import main_menu
|
|
|
|
|
|
def init():
|
|
"""Initialize the Help module"""
|
|
menu = main_menu.add_urlname(ugettext_lazy('Documentation'),
|
|
'glyphicon-book', 'help:index')
|
|
menu.add_urlname(ugettext_lazy('Where to Get Help'), 'glyphicon-search',
|
|
'help:index_explicit', 5)
|
|
menu.add_urlname(ugettext_lazy('Manual'), 'glyphicon-info-sign',
|
|
'help:manual', 10)
|
|
menu.add_urlname(ugettext_lazy('About'), 'glyphicon-star', 'help:about',
|
|
100)
|
|
|
|
|
|
@public
|
|
def index(request):
|
|
"""Serve the index page"""
|
|
return TemplateResponse(request, 'help_index.html',
|
|
{'title': _('Documentation and FAQ')})
|
|
|
|
|
|
@public
|
|
def about(request):
|
|
"""Serve the about page"""
|
|
cache = Cache()
|
|
plinth = cache['plinth']
|
|
context = {
|
|
'title': _('About {box_name}').format(box_name=_(cfg.box_name)),
|
|
'version': __version__,
|
|
'new_version': not plinth.candidate.is_installed
|
|
}
|
|
return TemplateResponse(request, 'help_about.html', context)
|
|
|
|
|
|
@public
|
|
def manual(request):
|
|
"""Serve the manual page from the 'doc' directory"""
|
|
try:
|
|
with open(os.path.join(cfg.doc_dir, 'freedombox-manual.part.html'),
|
|
'r', encoding='utf-8') as input_file:
|
|
content = input_file.read()
|
|
except IOError:
|
|
raise Http404
|
|
|
|
return TemplateResponse(
|
|
request, 'help_manual.html',
|
|
{'title': _('{box_name} Manual').format(box_name=_(cfg.box_name)),
|
|
'content': content})
|
|
|
|
|
|
def status_log(request):
|
|
"""Serve the last 100 lines of plinth's status log"""
|
|
num_lines = 100
|
|
with open(cfg.status_log_file, 'r') as log_file:
|
|
data = log_file.readlines()
|
|
|
|
data = ''.join(data[-num_lines:])
|
|
context = {
|
|
'num_lines': num_lines,
|
|
'data': data
|
|
}
|
|
return TemplateResponse(request, 'statuslog.html', context)
|