-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcli.py
141 lines (115 loc) · 5.22 KB
/
cli.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
import argparse
from grpc import RpcError
from cottontaildb_client import CottontailDBClient
def cli():
parser = argparse.ArgumentParser(prog='cottontaildb-client')
parser.add_argument('host', help='Cottontail DB host.')
parser.add_argument('--port', help='Cottontail DB host port.', type=int, default=1865)
args = parser.parse_args()
with CottontailDBClient(args.host, args.port) as client:
client.ping()
command_parser = get_command_parser()
running = True
while running:
try:
command = input('> ')
except EOFError:
print()
break
parts = command.split()
try:
arguments = command_parser.parse_args(parts)
except SystemExit:
continue
try:
running = process_command(client, arguments)
except RpcError as error:
print(error)
continue
print('Goodbye!')
def get_command_parser():
parser = argparse.ArgumentParser(prog='cottontaildb-client')
subparsers = parser.add_subparsers(dest='command')
# Schema
parser_schema = subparsers.add_parser('schema', help='Schema related commands.')
subparsers_schema = parser_schema.add_subparsers(dest='subcommand')
# Schema all
subparsers_schema.add_parser('all', help='List all schemas stored in Cottontail DB.')
# Schema create
parser_schema_create = subparsers_schema.add_parser('create', help='Create the schema with the given name.')
parser_schema_create.add_argument('schema_name', help='Name of schema to create.')
# Schema drop
parser_schema_drop = subparsers_schema.add_parser('drop', help='Drops the schema with the given name.')
parser_schema_drop.add_argument('schema_name', help='Name of schema to drop.')
# Schema list entities
parser_schema_list = subparsers_schema.add_parser('list', help='Lists all entities for a given schema.')
parser_schema_list.add_argument('schema_name', help='Name of schema to list entities of.')
# Entity
parser_entity = subparsers.add_parser('entity', help='Entity related commands.')
subparsers_entity = parser_entity.add_subparsers(dest='subcommand')
# Entity create
# parser_entity_create = subparsers_schema.add_parser('create', help='Creates a new entity in the database.')
# parser_entity_create.add_argument('schema_name', help='Name of schema to create entity in.')
# parser_entity_create.add_argument('entity_name', help='Name of entity to create.')
# Entity drop
parser_entity_drop = subparsers_entity.add_parser('drop', help='Drops the given entity from the database.')
parser_entity_drop.add_argument('schema_name', help='Name of schema to drop entity from.')
parser_entity_drop.add_argument('entity_name', help='Name of entity to drop.')
# Entity about
parser_entity_about = subparsers_entity.add_parser('about', help='Gives an overview of the entity and its columns.')
parser_entity_about.add_argument('schema_name', help='Name of schema containing entity.')
parser_entity_about.add_argument('entity_name', help='Name of entity to show details of.')
# System
parser_system = subparsers.add_parser('system', help='System related commands.')
subparsers_system = parser_system.add_subparsers(dest='subcommand')
# Transactions
subparsers_system.add_parser('transactions',
help='Lists all ongoing transaction in the current Cottontail DB instance.')
# Locks
subparsers_system.add_parser('locks', help='Lists all locks in the current Cottontail DB instance.')
# Stop / quit
subparsers.add_parser('stop', help='Stop client and exit.')
subparsers.add_parser('quit', help='Stop client and exit.')
subparsers.add_parser('exit', help='Stop client and exit.')
return parser
def process_command(client, args):
command = args.command
if command == 'stop' or command == 'quit' or command == 'exit':
return False
elif command == 'schema':
schema(client, args)
elif command == 'entity':
entity(client, args)
elif command == 'system':
system(client, args)
return True
def schema(client, args):
command = args.subcommand
if command == 'all':
schemas = client.list_schemas()
print('\n'.join(schemas))
elif command == 'create':
response = client.create_schema(args.schema_name)
print(response)
elif command == 'drop':
response = client.drop_schema(args.schema_name)
print(response)
elif command == 'list':
response = client.list_entities(args.schema_name)
print(response)
def entity(client, args):
command = args.subcommand
if command == 'drop':
response = client.drop_entity(args.schema_name, args.entity_name)
print(response)
elif command == 'about':
response = client.get_entity_details(args.schema_name, args.entity_name)
print(response)
def system(client, args):
command = args.subcommand
if command == 'transactions':
response = client.list_transactions()
print(response)
elif command == 'locks':
response = client.list_locks()
print(response)