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
|
import logging
import os, sys
import subprocess
# Explicitly enable local imports
# Don't forget to add imported scripts to inputs of the calling command!
sys.path.append(os.path.dirname(os.path.abspath(__file__)))
import fetch_from
class UnsupportedProtocolException(Exception):
pass
def executable_path():
return "/usr/local/bin/sky"
def is_avaliable():
if not os.path.exists(executable_path()):
return False
try:
subprocess.check_output([executable_path(), "--version"])
return True
except subprocess.CalledProcessError:
return False
except OSError:
return False
def fetch(skynet_id, file_name, timeout=None):
if not is_avaliable():
raise UnsupportedProtocolException("Skynet is not available")
target_dir = os.path.abspath(fetch_from.uniq_string_generator())
os.mkdir(target_dir)
cmd_args = [executable_path(), "get", "-N", "Backbone", "--user", "--wait", "--dir", target_dir, skynet_id]
if timeout is not None:
cmd_args += ["--timeout", str(timeout)]
logging.info("Call skynet with args: %s", cmd_args)
stdout = subprocess.check_output(cmd_args).strip()
logging.debug("Skynet call with args %s is finished, result is %s", cmd_args, stdout)
return os.path.join(target_dir, file_name)
|