2018-06-13 16:23:49 -04:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
import argparse
|
2018-07-09 15:07:24 -04:00
|
|
|
import errno
|
2018-06-13 16:23:49 -04:00
|
|
|
import os
|
|
|
|
import socket
|
|
|
|
import subprocess
|
|
|
|
import sys
|
|
|
|
|
|
|
|
path = os.path.dirname(os.path.realpath(__file__))
|
|
|
|
path = os.path.realpath(os.path.join(path, '..', 'lib', 'python'))
|
|
|
|
if path.startswith('/opt'):
|
|
|
|
# if installed into system path, do not muck with things
|
|
|
|
sys.path.append(path)
|
|
|
|
|
|
|
|
import confluent.client as client
|
|
|
|
import confluent.tlvdata as tlvdata
|
|
|
|
|
|
|
|
try:
|
|
|
|
input = raw_input
|
|
|
|
except NameError:
|
|
|
|
pass
|
|
|
|
|
|
|
|
def make_certificate():
|
|
|
|
umask = os.umask(0077)
|
2018-07-09 15:07:24 -04:00
|
|
|
try:
|
|
|
|
os.makedirs('/etc/confluent/cfg')
|
|
|
|
except OSError as e:
|
|
|
|
if e.errno == errno.EEXIST and os.path.isdir('/etc/confluent/cfg'):
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
raise
|
2018-06-13 16:23:49 -04:00
|
|
|
if subprocess.check_call(
|
|
|
|
'openssl ecparam -name secp384r1 -genkey -out '
|
|
|
|
'/etc/confluent/privkey.pem'.split(' ')):
|
|
|
|
raise Exception('Error generating private key')
|
|
|
|
|
|
|
|
if subprocess.check_call('openssl req -new -x509 -key '
|
|
|
|
'/etc/confluent/privkey.pem -days 7300 -out '
|
|
|
|
'/etc/confluent/srvcert.pem -subj /CN='
|
|
|
|
'{0}'.format(socket.gethostname()).split(' ')):
|
|
|
|
raise Exception('Error generating certificate')
|
|
|
|
print('Certificate generated successfully')
|
|
|
|
os.umask(umask)
|
|
|
|
|
|
|
|
|
|
|
|
def show_invitation(name):
|
2018-06-19 11:05:38 -04:00
|
|
|
if not os.path.exists('/etc/confluent/srvcert.pem'):
|
|
|
|
make_certificate()
|
2018-06-13 16:23:49 -04:00
|
|
|
s = client.Command().connection
|
|
|
|
tlvdata.send(s, {'collective': {'operation': 'invite', 'name': name}})
|
2018-06-26 14:35:23 -04:00
|
|
|
invite = tlvdata.recv(s)['collective']
|
|
|
|
if 'error' in invite:
|
|
|
|
sys.stderr.write(invite['error'] + '\n')
|
|
|
|
return
|
2018-07-09 13:33:56 -04:00
|
|
|
print('{0}'.format(invite['invitation']))
|
2018-06-13 16:23:49 -04:00
|
|
|
|
|
|
|
|
|
|
|
def join_collective(server, invitation):
|
2018-06-19 11:05:38 -04:00
|
|
|
if not os.path.exists('/etc/confluent/srvcert.pem'):
|
|
|
|
make_certificate()
|
2018-06-13 16:23:49 -04:00
|
|
|
s = client.Command().connection
|
|
|
|
while not invitation:
|
|
|
|
invitation = raw_input('Paste the invitation here: ')
|
|
|
|
tlvdata.send(s, {'collective': {'operation': 'join',
|
|
|
|
'invitation': invitation,
|
|
|
|
'server': server}})
|
|
|
|
res = tlvdata.recv(s)
|
|
|
|
print(res.get('collective',
|
|
|
|
{'status': 'Unknown response: ' + repr(res)})['status'])
|
|
|
|
|
|
|
|
|
2018-07-09 15:07:24 -04:00
|
|
|
def show_collective():
|
|
|
|
s = client.Command().connection
|
|
|
|
tlvdata.send(s, {'collective': {'operation': 'show'}})
|
|
|
|
res = tlvdata.recv(s)
|
2018-07-19 16:39:13 -04:00
|
|
|
if 'error' in res['collective']:
|
2018-07-19 16:48:30 -04:00
|
|
|
print(res['collective']['error'])
|
2018-07-19 16:39:13 -04:00
|
|
|
return
|
|
|
|
print('Leader: {0}'.format(res['collective']['leader']))
|
|
|
|
if 'active' in res['collective']:
|
|
|
|
if res['collective']['active']:
|
|
|
|
print('Active collective members:')
|
|
|
|
for member in res['collective']['active']:
|
|
|
|
print(' {0}'.format(member))
|
|
|
|
if res['collective']['offline']:
|
|
|
|
print('Offline collective members:')
|
|
|
|
for member in res['collective']['offline']:
|
|
|
|
print(' {0}'.format(member))
|
|
|
|
else:
|
|
|
|
print('Run collective show on leader for more data')
|
2018-07-09 15:07:24 -04:00
|
|
|
|
2018-06-13 16:23:49 -04:00
|
|
|
def main():
|
|
|
|
a = argparse.ArgumentParser(description='Confluent server utility')
|
|
|
|
sp = a.add_subparsers(dest='command')
|
|
|
|
gc = sp.add_parser('gencert', help='Generate Confluent Certificates for '
|
|
|
|
'collective mode and remote CLI access')
|
2018-07-09 15:07:24 -04:00
|
|
|
sl = sp.add_parser('show', help='Show information about the collective')
|
2018-06-13 16:23:49 -04:00
|
|
|
ic = sp.add_parser('invite', help='Generate a invitation to allow a new '
|
|
|
|
'confluent instance to join as a '
|
|
|
|
'collective member')
|
|
|
|
ic.add_argument('name', help='Name of server to invite to join the '
|
|
|
|
'collective')
|
|
|
|
jc = sp.add_parser('join', help='Join a collective')
|
|
|
|
jc.add_argument('server', help='A server currently in the collective')
|
|
|
|
jc.add_argument('-i', help='Invitation provided by runniing invite on an '
|
|
|
|
'existing collective member')
|
|
|
|
cmdset = a.parse_args()
|
|
|
|
if cmdset.command == 'gencert':
|
|
|
|
make_certificate()
|
|
|
|
elif cmdset.command == 'invite':
|
|
|
|
show_invitation(cmdset.name)
|
|
|
|
elif cmdset.command == 'join':
|
|
|
|
join_collective(cmdset.server, cmdset.i)
|
2018-07-09 15:07:24 -04:00
|
|
|
elif cmdset.command == 'show':
|
|
|
|
show_collective()
|
2018-06-13 16:23:49 -04:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|