mirror of
https://github.com/freedombox/FreedomBox.git
synced 2026-01-28 08:03:36 +00:00
First draft to add owncloud support.
This commit is contained in:
parent
444365ec78
commit
fe33c348b4
48
actions/owncloud-setup
Executable file
48
actions/owncloud-setup
Executable file
@ -0,0 +1,48 @@
|
||||
#!/bin/sh
|
||||
|
||||
if [ -e /etc/apache2/conf-enabled/owncloud.conf ] ; then
|
||||
owncloud_enable=true
|
||||
else
|
||||
owncloud_enable=false
|
||||
fi
|
||||
owncloud_enable_cur=$owncloud_enable
|
||||
export owncloud_enable
|
||||
|
||||
|
||||
while [ "$1" ] ; do
|
||||
arg="$1"
|
||||
shift
|
||||
case "$arg" in
|
||||
enable|noenable) # Not using disable for consistency with other options
|
||||
if [ 'enable' = "$arg" ] ; then
|
||||
owncloud_enable=true
|
||||
else
|
||||
owncloud_enable=false
|
||||
fi
|
||||
export owncloud_enable
|
||||
;;
|
||||
status)
|
||||
printstatus() {
|
||||
if $2 ; then
|
||||
echo $1
|
||||
else
|
||||
echo no$1
|
||||
fi
|
||||
}
|
||||
printstatus enable $owncloud_enable_cur
|
||||
exit 0
|
||||
;;
|
||||
*)
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
if [ "$owncloud_enable" != "$owncloud_enable_cur" ] ; then
|
||||
if $owncloud_enable ; then
|
||||
apt-get install -y owncloud
|
||||
a2enconf owncloud
|
||||
else
|
||||
a2disconf owncloud
|
||||
fi
|
||||
service apache2 restart
|
||||
fi
|
||||
@ -1,6 +1,9 @@
|
||||
import cherrypy
|
||||
from gettext import gettext as _
|
||||
from modules.auth import require
|
||||
from plugin_mount import PagePlugin
|
||||
from forms import Form
|
||||
from privilegedactions import privilegedaction_run
|
||||
import cfg
|
||||
|
||||
class Apps(PagePlugin):
|
||||
@ -9,6 +12,7 @@ class Apps(PagePlugin):
|
||||
self.register_page("apps")
|
||||
self.menu = cfg.main_menu.add_item("Apps", "icon-download-alt", "/apps", 80)
|
||||
self.menu.add_item("Photo Gallery", "icon-picture", "/apps/photos", 35)
|
||||
self.menu.add_item("Owncloud", "icon-picture", "/apps/owncloud", 35)
|
||||
|
||||
@cherrypy.expose
|
||||
def index(self):
|
||||
@ -33,3 +37,48 @@ investment in the sentimental value of your family snaps? Keep those
|
||||
photos local, backed up, easily accessed and free from the whims of
|
||||
some other websites business model.</p>
|
||||
""")
|
||||
|
||||
@cherrypy.expose
|
||||
@require()
|
||||
def owncloud(self, submitted=False, **kwargs):
|
||||
checkedinfo = {
|
||||
'enable' : False,
|
||||
}
|
||||
|
||||
if submitted:
|
||||
opts = []
|
||||
for k in kwargs.keys():
|
||||
if 'on' == kwargs[k]:
|
||||
shortk = k.split("owncloud_").pop()
|
||||
cfg.log.info('found: %s, short %s ' % (k, shortk))
|
||||
checkedinfo[shortk] = True
|
||||
|
||||
for key in checkedinfo.keys():
|
||||
if checkedinfo[key]:
|
||||
opts.append(key)
|
||||
else:
|
||||
opts.append('no'+key)
|
||||
privilegedaction_run("owncloud-setup", opts)
|
||||
|
||||
output, error = privilegedaction_run("owncloud-setup", ['status'])
|
||||
if error:
|
||||
raise Exception("something is wrong: " + error)
|
||||
for option in output.split():
|
||||
checkedinfo[option] = True
|
||||
|
||||
main="""
|
||||
"""
|
||||
form = Form(title="Configuration",
|
||||
action="/apps/owncloud",
|
||||
name="configure_owncloud",
|
||||
message='')
|
||||
form.checkbox(_("Enable Owncloud"), name="owncloud_enable", id="owncloud_enable", checked=checkedinfo['enable'])
|
||||
form.hidden(name="submitted", value="True")
|
||||
form.html(_("<p>When enabled, the owncloud installation will be available from /owncloud/ on the web server.</p>"))
|
||||
form.submit(_("Update setup"))
|
||||
main += form.render()
|
||||
sidebar_right="""
|
||||
<strong>Owncloud</strong><p>gives you universal access to your files through a web interface or WebDAV. It also provides a platform to easily view & sync your contacts, calendars and bookmarks across all your devices and enables basic editing right on the web. Installation has minimal server requirements, doesn’t need special permissions and is quick. ownCloud is extendable via a simple but powerful API for applications and plugins.
|
||||
</p>
|
||||
"""
|
||||
return self.fill_template(title="Owncloud", main=main, sidebar_right=sidebar_right)
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user