url_utils.py 2.89 KB
Newer Older
Deshui Yu's avatar
Deshui Yu committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# Copyright (c) Microsoft Corporation
# All rights reserved.
#
# MIT License
#
# Permission is hereby granted, free of charge,
# to any person obtaining a copy of this software and associated
# documentation files (the "Software"), to deal in the Software without restriction,
# including without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Software, and
# to permit persons to whom the Software is furnished to do so, subject to the following conditions:
# The above copyright notice and this permission notice shall be included
# in all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
# BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

chicm-ms's avatar
chicm-ms committed
21
import socket
SparkSnail's avatar
SparkSnail committed
22
import psutil
Deshui Yu's avatar
Deshui Yu committed
23
24
25
26
27
28
29
30
31

BASE_URL = 'http://localhost'

API_ROOT_URL = '/api/v1/nni'

EXPERIMENT_API = '/experiment'

CLUSTER_METADATA_API = '/experiment/cluster-metadata'

32
33
IMPORT_DATA_API = '/experiment/import-data'

Deshui Yu's avatar
Deshui Yu committed
34
35
36
37
CHECK_STATUS_API = '/check-status'

TRIAL_JOBS_API = '/trial-jobs'

38
39
EXPORT_DATA_API = '/export-data'

Deshui Yu's avatar
Deshui Yu committed
40
41
42
43
44
45
46
47
48
49
50
51
52
TENSORBOARD_API = '/tensorboard'


def check_status_url(port):
    '''get check_status url'''
    return '{0}:{1}{2}{3}'.format(BASE_URL, port, API_ROOT_URL, CHECK_STATUS_API)


def cluster_metadata_url(port):
    '''get cluster_metadata_url'''
    return '{0}:{1}{2}{3}'.format(BASE_URL, port, API_ROOT_URL, CLUSTER_METADATA_API)


53
54
55
56
57
def import_data_url(port):
    '''get import_data_url'''
    return '{0}:{1}{2}{3}'.format(BASE_URL, port, API_ROOT_URL, IMPORT_DATA_API)


Deshui Yu's avatar
Deshui Yu committed
58
59
60
61
62
63
64
65
66
def experiment_url(port):
    '''get experiment_url'''
    return '{0}:{1}{2}{3}'.format(BASE_URL, port, API_ROOT_URL, EXPERIMENT_API)


def trial_jobs_url(port):
    '''get trial_jobs url'''
    return '{0}:{1}{2}{3}'.format(BASE_URL, port, API_ROOT_URL, TRIAL_JOBS_API)

SparkSnail's avatar
SparkSnail committed
67

Deshui Yu's avatar
Deshui Yu committed
68
69
def trial_job_id_url(port, job_id):
    '''get trial_jobs with id url'''
demianzhang's avatar
demianzhang committed
70
    return '{0}:{1}{2}{3}/{4}'.format(BASE_URL, port, API_ROOT_URL, TRIAL_JOBS_API, job_id)
Deshui Yu's avatar
Deshui Yu committed
71
72


73
74
75
76
77
def export_data_url(port):
    '''get export_data url'''
    return '{0}:{1}{2}{3}'.format(BASE_URL, port, API_ROOT_URL, EXPORT_DATA_API)


Deshui Yu's avatar
Deshui Yu committed
78
79
80
def tensorboard_url(port):
    '''get tensorboard url'''
    return '{0}:{1}{2}{3}'.format(BASE_URL, port, API_ROOT_URL, TENSORBOARD_API)
SparkSnail's avatar
SparkSnail committed
81
82
83
84
85


def get_local_urls(port):
    '''get urls of local machine'''
    url_list = []
chicm-ms's avatar
chicm-ms committed
86
    for _, info in psutil.net_if_addrs().items():
SparkSnail's avatar
SparkSnail committed
87
        for addr in info:
chicm-ms's avatar
chicm-ms committed
88
            if socket.AddressFamily.AF_INET == addr.family:
SparkSnail's avatar
SparkSnail committed
89
                url_list.append('http://{}:{}'.format(addr.address, port))
demianzhang's avatar
demianzhang committed
90
    return url_list