summaryrefslogtreecommitdiffstats
path: root/cli/objects/server.py
diff options
context:
space:
mode:
authorJose M. Guisado <jguisado@soleta.eu>2023-08-23 15:39:36 +0200
committerJose M. Guisado <jguisado@soleta.eu>2023-08-24 09:14:49 +0200
commita721957cc46983f3026a30ea2dc814f5eafed1c2 (patch)
tree84e460b97fe063676de8231a8f0fc138746b8111 /cli/objects/server.py
parent563e30893de06b2cee744694788ea2da60cb01a3 (diff)
cli: add server commandsv0.3.1
Add OgServer class inside cli/objects/server.py This OgServer class implements add, list, set and delete commands related to the server API (/server and /client/server) exposed by the ogServer. These server endpoints correspond with the "entornos" table and "identorno" foreign key in the "ordenadores" tables. To list all rows from the "entornos" table. i.e: Listing all stored addresses for the ogServer: ogcli list servers { "servers": [ { "address": "192.168.2.240", "id": 1 }, { "address": "1.1.1.1", "id": 2 } ] } To store a new ip address for the ogServer, ogCLI will reply with the new id: ogcli add server --address "10.141.10.1" {"id", "2"} To set a client's associated ogServer address using the server id: ogcli set server --id 2 --client-ip 10.141.10.100 To set the associated server of a whole room use --room-id parameter: ogcli set server --id 2 --room-id 1 To remove any existing address (which is not currently set as the ogServer addres for any client) using the server id: ogcli delete server --id 2 To determine a client's associated server just list the client's information (this requires an updated ogServer): ogcli list client --client-ip 10.141.10.100 { "boot": "oglive", "center": 1, ... "server_id": 1 }
Diffstat (limited to 'cli/objects/server.py')
-rw-r--r--cli/objects/server.py77
1 files changed, 77 insertions, 0 deletions
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)