From a721957cc46983f3026a30ea2dc814f5eafed1c2 Mon Sep 17 00:00:00 2001 From: "Jose M. Guisado" Date: Wed, 23 Aug 2023 15:39:36 +0200 Subject: cli: add server commands 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 } --- cli/objects/server.py | 77 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) create mode 100644 cli/objects/server.py (limited to 'cli/objects') 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 +# +# 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) -- cgit v1.2.3-18-g5258