summaryrefslogtreecommitdiff
path: root/src/helpers/vyos-sudo.py
diff options
context:
space:
mode:
authorDmytro Aleksandrov <alkersan@gmail.com>2019-08-14 01:21:20 +0300
committerDmytro Aleksandrov <alkersan@gmail.com>2019-08-16 20:13:20 +0300
commit3d94de9b56ef2a6030ef5cea8b307098688c949d (patch)
treebefba973601cfe835fc29bf3e085e39a0dde308a /src/helpers/vyos-sudo.py
parent58c5a7e668d0131de50e6f9711f029f9ff4a02ab (diff)
downloadvyos-1x-3d94de9b56ef2a6030ef5cea8b307098688c949d.tar.gz
vyos-1x-3d94de9b56ef2a6030ef5cea8b307098688c949d.zip
[op-mode] T1590 xml-style rewrite of 'show system' operations
Diffstat (limited to 'src/helpers/vyos-sudo.py')
-rwxr-xr-xsrc/helpers/vyos-sudo.py40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/helpers/vyos-sudo.py b/src/helpers/vyos-sudo.py
new file mode 100755
index 000000000..0101a0c95
--- /dev/null
+++ b/src/helpers/vyos-sudo.py
@@ -0,0 +1,40 @@
+#!/usr/bin/env python3
+
+# Copyright 2019 VyOS maintainers and contributors <maintainers@vyos.io>
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library 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
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library. If not, see <http://www.gnu.org/licenses/>.
+
+import getpass
+import grp
+import os
+import sys
+
+
+def is_admin() -> bool:
+ """Look if current user is in sudo group"""
+ current_user = getpass.getuser()
+ (_, _, _, admin_group_members) = grp.getgrnam('sudo')
+ return current_user in admin_group_members
+
+
+if __name__ == '__main__':
+ if len(sys.argv) < 2:
+ print('Missing command argument')
+ sys.exit(1)
+
+ if not is_admin():
+ print('This account is not authorized to run this command')
+ sys.exit(1)
+
+ os.execvp('sudo', ['sudo'] + sys.argv[1:])