Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
  • Loading branch information
dtkav committed Mar 19, 2019
1 parent 81ce4d6 commit 36689b5
Showing 1 changed file with 128 additions and 5 deletions.
133 changes: 128 additions & 5 deletions missioncontrol_client/__init__.py
Original file line number Diff line number Diff line change
@@ -1,18 +1,49 @@
import argparse
import json
import os

# dl
from uuid import uuid4
import io
import zlib
import socket
import datetime
from datalake.dlfile import GzippingFile

from urllib.parse import urljoin

import requests

class UTC(object):
def __init__(self, d="now"):
if d == "now":
self._d = datetime.datetime.utcnow()
else:
raise NotImplementedError()

@property
def iso(self):
return self._d.isoformat() + "Z"


class MCAPI(object):
class MCAPIv0(object):

def __init__(self, mc_base, jwt=None):
self.mc_base = mc_base
self.s = requests.session()
self.jwt = None

@classmethod
def from_environ(cls, ignore_ssl=False):
mc_api = cls(os.environ['MC_BASE'])
if ignore_ssl:
mc_api.s.verify = False
if os.environ.get('MC_JWT'):
mc_api.login(jwt=os.environ['MC_JWT'])
else:
mc_api.login(username=os.environ['MC_USERNAME'], password=os.environ['MC_PASSWORD'])
return mc_api

def get(self, path, *args, **kwargs):
r = self.s.get(urljoin(self.mc_base, path), *args, **kwargs)
r.raise_for_status()
Expand All @@ -22,6 +53,16 @@ def getj(self, path, *args, **kwargs):
r = self.get(path, *args, **kwargs)
return r.json()

def post(self, path, *args, **kwargs):
r = self.s.post(urljoin(self.mc_base, path), *args, **kwargs)
r.raise_for_status()
return r

def postj(self, path, *args, **kwargs):
ret = self.s.post(urljoin(self.mc_base, path), *args, **kwargs)
ret.raise_for_status()
return ret.json()

def put(self, path, *args, **kwargs):
r = self.s.put(urljoin(self.mc_base, path), *args, **kwargs)
r.raise_for_status()
Expand Down Expand Up @@ -145,6 +186,85 @@ def get_pass_task_stack(self, uuid, **kwargs):
json=kwargs
)

def get_files(self, what, **kwargs):
kwargs.update({"what": what})
return self.getj(
f'/api/v0/files/',
params=kwargs
)

def get_file(self, uuid):
return self.getj(
f'/api/v0/files/{uuid}/'
)

def download_file(self, uuid):
return self.get(
f'/api/v0/files/{uuid}/data/'
)

def download_cid(self, cid):
return self.get(
f'/api/v0/raw-file/{cid}/data/'
)

def upload_file(self, path, what, uuid=None, where=None, start=None, end=None,
work_id=None, content_type=None):

if uuid is None:
uuid = str(uuid4())

if start is None:
start = UTC("now").iso

if where is None:
where = socket.getfqdn()

f = GzippingFile.from_filename(
path,
what=what,
where=where,
start=start,
work_id=work_id
)

cid = f.metadata["hash"]

fleetmeta = {
"uuid": uuid,
"cid": cid,
"path": f.metadata["path"],
"start": UTC("now").iso,
"what": f.metadata["what"],
"where": f.metadata["where"],
"work_id": f.metadata["work_id"]
}

# get signed upload
signed = self.postj(
f'/api/v0/files/presign/',
json=fleetmeta
)

file_tuple = ("file", f)
if content_type is not None:
file_tuple += (content_type,)

# upload file
if "url" in signed:
signed["fields"]["Content-Encoding"] = "gzip"
resp = requests.post(
signed["url"],
data=signed["fields"],
files=[file_tuple]
)

# upload metadata
return self.putj(
f'/api/v0/files/{uuid}/',
json=fleetmeta
)

def login(self, username=None, password=None, jwt=None):
if username is not None and jwt is not None:
raise ValueError("Can't give both a username and a jwt")
Expand All @@ -163,8 +283,8 @@ def add_parser_defaults(parser):
"--mc-base",
dest="mc_api",
required="MC_BASE" not in os.environ,
type=MCAPI,
default=MCAPI(os.environ.get("MC_BASE")))
type=MCAPIv0,
default=MCAPIv0(os.environ.get("MC_BASE")))

add_login_to_parser(parser)
add_ssl_to_parser(parser)
Expand Down Expand Up @@ -213,12 +333,15 @@ def handle_default_args(args):
args.mc_api.login(username=args.username, password=args.password)

def from_environ(ignore_ssl=False):
mc_api = MCAPI(os.environ['MC_BASE'])
# deprecated, use MCAPIv0.from_environ()
mc_api = MCAPIv0(os.environ['MC_BASE'])
if ignore_ssl:
mc_api.s.verify = False
if os.environ.get('MC_JWT'):
mc_api.login(jwt=os.environ['MC_JWT'])
else:
mc_api.login(username=os.environ['MC_USERNAME'], password=os.environ['MC_PASSWORD'])

return mc_api
return mc_api

MCAPI = MCAPIv0 # for backwards compatability

0 comments on commit 36689b5

Please sign in to comment.