summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--cli/cli.py30
-rw-r--r--cli/objects/server.py77
2 files changed, 104 insertions, 3 deletions
diff --git a/cli/cli.py b/cli/cli.py
index dd6b723..02cae6b 100644
--- a/cli/cli.py
+++ b/cli/cli.py
@@ -13,6 +13,7 @@ from cli.objects.images import OgImage
from cli.objects.disks import OgDisk
from cli.objects.poweroff import OgPoweroff
from cli.objects.reboot import OgReboot
+from cli.objects.server import OgServer
import argparse
import requests
import sys
@@ -68,7 +69,8 @@ class OgCLI():
def list(self, args):
choices = ['clients', 'scopes', 'modes', 'hardware',
- 'client', 'images', 'disks']
+ 'client', 'images', 'disks', 'server',
+ 'servers']
parser = argparse.ArgumentParser(prog='ogcli list')
parser.add_argument('item', choices=choices)
parsed_args = parser.parse_args([args[0]])
@@ -87,15 +89,19 @@ class OgCLI():
OgImage.list_images(self.rest)
elif parsed_args.item == 'disks':
OgDisk.list_disks(self.rest, args[1:])
+ elif parsed_args.item in ['server', 'servers']:
+ OgServer.list_servers(self.rest)
def set(self, args):
- choices = ['modes', 'mode']
+ choices = ['modes', 'mode', 'server']
parser = argparse.ArgumentParser(prog='ogcli set')
parser.add_argument('item', choices=choices)
parsed_args = parser.parse_args([args[0]])
- if parsed_args.item in choices:
+ if parsed_args.item in ['modes', 'mode']:
OgModes.set_modes(self.rest, args[1:])
+ elif parsed_args.item == 'server':
+ OgServer.set_server(self.rest, args[1:])
def send(self, args):
choices = ['reboot', 'refresh', 'poweroff', 'wol']
@@ -147,3 +153,21 @@ class OgCLI():
if parsed_args.update_obj == 'image':
OgImage.update_image(self.rest, args[1:])
+
+ def delete(self, args):
+ choices = ['server']
+ parser = argparse.ArgumentParser(prog='ogcli remove')
+ parser.add_argument('delete_obj', choices=choices)
+ parsed_args = parser.parse_args([args[0]])
+
+ if parsed_args.delete_obj == 'server':
+ OgServer.delete_server(self.rest, args[1:])
+
+ def add(self, args):
+ choices = ['server']
+ parser = argparse.ArgumentParser(prog='ogcli remove')
+ parser.add_argument('add_obj', choices=choices)
+ parsed_args = parser.parse_args([args[0]])
+
+ if parsed_args.add_obj == 'server':
+ OgServer.add_server(self.rest, args[1:])
diff --git a/cli/objects/server.py b/cli/objects/server.py
new file mode 100644
index 0000000..a8ed345
--- /dev/null
+++ b/cli/objects/server.py
@@ -0,0 +1,77 @@
+# Copyright (C) 2023 Soleta Networks <info@soleta.eu>
+#
+# 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.
+
+import argparse
+
+from cli.utils import *
+
+class OgServer():
+
+ @staticmethod
+ def list_servers(rest):
+ r = rest.get('/server')
+ print_json(r.text)
+
+ @staticmethod
+ def add_server(rest, args):
+ parser = argparse.ArgumentParser()
+ parser.add_argument('--address',
+ nargs='?',
+ required=True,
+ help='valid ogserver ip address')
+ parsed_args = parser.parse_args(args)
+ payload = {'address': parsed_args.address}
+ rest.post('/server', payload=payload)
+
+ @staticmethod
+ def delete_server(rest, args):
+ parser = argparse.ArgumentParser()
+ parser.add_argument('--id',
+ nargs='?',
+ required=True,
+ help='server id in the database')
+ parsed_args = parser.parse_args(args)
+ payload = {'id': parsed_args.id}
+ rest.delete('/server', payload=payload)
+
+ @staticmethod
+ def set_server(rest, args):
+ parser = argparse.ArgumentParser()
+ parser.add_argument('--id',
+ nargs='?',
+ required=True,
+ help='server id in the database')
+ group = parser.add_argument_group('clients', 'Client selection args')
+ group.add_argument('--room-id',
+ type=int,
+ action='append',
+ default=[],
+ required=False,
+ help='Clients from given room id')
+ group.add_argument('--client-ip',
+ action='append',
+ default=[],
+ required=False,
+ help='Any valid client IP')
+ parsed_args = parser.parse_args(args)
+
+ r = rest.get('/scopes')
+ scopes = r.json()
+ ips = set()
+
+ for room in parsed_args.room_id:
+ room_scope = scope_lookup(room, 'room', scopes)
+ ips.update(ips_in_scope(room_scope))
+ for l in parsed_args.client_ip:
+ ips.add(l)
+ if not ips:
+ print('No clients specified.')
+ return
+
+ parsed_args = parser.parse_args(args)
+ payload = {'id': parsed_args.id, 'clients': list(ips)}
+ rest.post('/client/server', payload=payload)