summaryrefslogtreecommitdiffhomepage
path: root/applications
diff options
context:
space:
mode:
authorJo-Philipp Wich <jo@mein.io>2019-10-16 21:32:03 +0200
committerGitHub <noreply@github.com>2019-10-16 21:32:03 +0200
commitcbd6b5e5517fb3286e31a367fd9aaeb29410882e (patch)
tree5a26058ff25dc1e91ed3734f376509292a1c8133 /applications
parent3d11af11a72740aefee26c299de379a2780d2f79 (diff)
parent43f6ca451766a4a32587a85a38cb45e6479fb92e (diff)
Merge pull request #3125 from ysc3839/cifsd
[RFC] luci-app-cifsd: add new package
Diffstat (limited to 'applications')
-rw-r--r--applications/luci-app-cifsd/Makefile10
-rw-r--r--applications/luci-app-cifsd/htdocs/luci-static/resources/view/cifsd.js96
-rw-r--r--applications/luci-app-cifsd/luasrc/controller/cifsd.lua11
-rw-r--r--applications/luci-app-cifsd/root/usr/share/rpcd/acl.d/luci-app-cifsd.json15
4 files changed, 132 insertions, 0 deletions
diff --git a/applications/luci-app-cifsd/Makefile b/applications/luci-app-cifsd/Makefile
new file mode 100644
index 000000000..ef725a705
--- /dev/null
+++ b/applications/luci-app-cifsd/Makefile
@@ -0,0 +1,10 @@
+# This is free software, licensed under the Apache License, Version 2.0 .
+
+include $(TOPDIR)/rules.mk
+
+LUCI_TITLE:=Network Shares - CIFSD CIFS/SMB kernel fileserver
+LUCI_DEPENDS:=+cifsd-tools
+
+include ../../luci.mk
+
+# call BuildPackage - OpenWrt buildroot signature
diff --git a/applications/luci-app-cifsd/htdocs/luci-static/resources/view/cifsd.js b/applications/luci-app-cifsd/htdocs/luci-static/resources/view/cifsd.js
new file mode 100644
index 000000000..de346c1db
--- /dev/null
+++ b/applications/luci-app-cifsd/htdocs/luci-static/resources/view/cifsd.js
@@ -0,0 +1,96 @@
+'use strict';
+'require fs';
+'require form';
+'require tools.widgets as widgets';
+
+return L.view.extend({
+ load: function() {
+ return Promise.all([
+ L.resolveDefault(fs.stat('/sbin/block'), null),
+ L.resolveDefault(fs.stat('/etc/config/fstab'), null),
+ ]);
+ },
+ render: function(stats) {
+ var m, s, o;
+
+ m = new form.Map('cifsd', _('Network Shares'));
+
+ s = m.section(form.TypedSection, 'globals');
+ s.anonymous = true;
+
+ s.tab('general', _('General Settings'));
+ s.tab('template', _('Edit Template'));
+
+ s.taboption('general', widgets.NetworkSelect, 'interface', _('Interface'),
+ _('Listen only on the given interface or, if unspecified, on lan'));
+
+ o = s.taboption('general', form.Value, 'workgroup', _('Workgroup'));
+ o.placeholder = 'WORKGROUP';
+
+ o = s.taboption('general', form.Value, 'description', _('Description'));
+ o.placeholder = 'Cifsd on OpenWrt';
+
+ o = s.taboption('template', form.TextValue, '_tmpl',
+ _('Edit the template that is used for generating the samba configuration.'),
+ _("This is the content of the file '/etc/cifs/smb.conf.template' from which your samba configuration will be generated. \
+ Values enclosed by pipe symbols ('|') should not be changed. They get their values from the 'General Settings' tab."));
+ o.rows = 20;
+ o.cfgvalue = function(section_id) {
+ return fs.trimmed('/etc/cifs/smb.conf.template');
+ };
+ o.write = function(section_id, formvalue) {
+ return fs.write('/etc/cifs/smb.conf.template', formvalue.trim().replace(/\r\n/g, '\n') + '\n');
+ };
+
+
+ s = m.section(form.TableSection, 'share', _('Shared Directories'),
+ _('Please add directories to share. Each directory refers to a folder on a mounted device.'));
+ s.anonymous = true;
+ s.addremove = true;
+
+ s.option(form.Value, 'name', _('Name'));
+ o = s.option(form.Value, 'path', _('Path'));
+ if (stats[0] && stats[1]) {
+ o.titleref = L.url('admin', 'system', 'mounts');
+ }
+
+ o = s.option(form.Flag, 'browseable', _('Browse-able'));
+ o.enabled = 'yes';
+ o.disabled = 'no';
+ o.default = 'yes';
+
+ o = s.option(form.Flag, 'read_only', _('Read-only'));
+ o.enabled = 'yes';
+ o.disabled = 'no';
+ o.default = 'yes';
+
+ s.option(form.Flag, 'force_root', _('Force Root'));
+
+ o = s.option(form.Value, 'users', _('Allowed users'));
+ o.rmempty = true;
+
+ o = s.option(form.Flag, 'guest_ok', _('Allow guests'));
+ o.enabled = 'yes';
+ o.disabled = 'no';
+ o.default = 'no';
+
+ o = s.option(form.Flag, 'inherit_owner', _('Inherit owner'));
+ o.enabled = 'yes';
+ o.disabled = 'no';
+ o.default = 'no';
+
+ s.option(form.Flag, 'hide_dot_files', _('Hide dot files'));
+
+ o = s.option(form.Value, 'create_mask', _('Create mask'));
+ o.rmempty = true;
+ o.maxlength = 4;
+ o.placeholder = '0666';
+
+ o = s.option(form.Value, 'dir_mask', _('Directory mask'));
+ o.rmempty = true;
+ o.maxlength = 4;
+ o.placeholder = '0777';
+
+ return m.render();
+ }
+});
diff --git a/applications/luci-app-cifsd/luasrc/controller/cifsd.lua b/applications/luci-app-cifsd/luasrc/controller/cifsd.lua
new file mode 100644
index 000000000..de3f9b0f9
--- /dev/null
+++ b/applications/luci-app-cifsd/luasrc/controller/cifsd.lua
@@ -0,0 +1,11 @@
+-- Licensed to the public under the Apache License 2.0.
+
+module("luci.controller.cifsd", package.seeall)
+
+function index()
+ if not nixio.fs.access("/etc/config/cifsd") then
+ return
+ end
+
+ entry({"admin", "services", "cifsd"}, view("cifsd"), _("Network Shares")).dependent = true
+end
diff --git a/applications/luci-app-cifsd/root/usr/share/rpcd/acl.d/luci-app-cifsd.json b/applications/luci-app-cifsd/root/usr/share/rpcd/acl.d/luci-app-cifsd.json
new file mode 100644
index 000000000..6efebe98e
--- /dev/null
+++ b/applications/luci-app-cifsd/root/usr/share/rpcd/acl.d/luci-app-cifsd.json
@@ -0,0 +1,15 @@
+{
+ "luci-app-cifsd": {
+ "description": "Grant access to LuCI app cifsd",
+ "read": {
+ "file": {
+ "/etc/cifs/smb.conf.template": [ "read" ]
+ }
+ },
+ "write": {
+ "file": {
+ "/etc/cifs/smb.conf.template": [ "write" ]
+ }
+ }
+ }
+}