HTTP API Client Interface

Example parameter for login request on route /login

params = {
    'user': 'user_name',
    'key': 'user_key',
    'endpoint_name': 'llama2_chat',
    'version': 'Client interface version'
}

Example response json on route /login

response_json = {
    'client_session_auth_key': '7511a186-b0c6-4901-b228-68faea2b07f4'
}

Example parameter for http request on route /endpoint

params = {
    'prompt': 'prompt',
    'client_session_auth_key': 'obtained auth key from /login',
    'wait_for_result': False
}

Example response json for http request on route /endpoint if param ‘wait_for_result’: True

final_result = {
    'success': True,
    'job_id': 'JID1',
    'images': ['...'],
    'text': 'Test output...',
    'seed': 26262303,
    'prompt': 'cat',
    'compute_duration': 8.2,
    'total_duration': 47.8,
    'auth': 'neo07_NVIDIA A100-SXM4-40GB_0',
    'worker_interface_version': 'API-Worker-Interface 0.3.5'
}

Example response json for http request on route /endpoint if param ‘wait_for_result’: False

response_json = {
    'success': True,
    'job_id': 'JID01'
}

Example parameter for http request on route /endpoint/progress

params = {
    'client_session_auth_key': 'obtained auth key from /login',
    'job_id': 'job id obtained from /endpoint'
}

Example response json for http request on route /endpoint/progress dictionary at start:

progress_result = {
    'job_id': 'JID1',
    'job_state': 'processing',
    'progress': {
        'progress': 0,
        'queue_position': 0
    },
    'success': True
}

Example response json for http request on route /endpoint/progress dictionary while processing:

progress_result = {
    'job_id': 'JID1',
    'job_state': 'processing',
    'progress': {
        'job_id': 'JID1',
        'progress': 50,
        'progress_data': {
            'images': ['base64-string', 'base64-string', ...]
            'text': 'Test output'
        },
        'queue_position': 0
    },
    'success': True
}

Example response json for http request on route /endpoint/progress dictionary when job finished:

progress_result = {
    'job_id': 'JID1',
    'job_result': {
        'auth': 'worker_name',
        'compute_duration': 2.4,
        'images': ['base64-string', 'base64-string', ...]
        'text': 'Test outpu...',
        'total_duration': 2.5,
        'worker_interface_version': 'API-Worker-Interface 0.3.5'
    },
    'job_state': 'done',
    'progress': {
        'job_id': 'JID1',
        'progress': 100,
        'progress_data': {
            'images': ['base64-string', 'base64-string', ...]
            'text': 'Test outpu...'
        },
        'queue_position': 0
    },
    'success': True
}