_config_endpoint.py 2.22 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import requests
import os
import logging

logging.basicConfig(level=logging.INFO)

# test connection to huggingface
TIMEOUT = 3

def config_endpoint():
    """
    Checks for connectivity to Hugging Face and sets the model source accordingly.
    If the Hugging Face endpoint is reachable, it sets MINERU_MODEL_SOURCE to 'huggingface'.
    Otherwise, it falls back to 'modelscope'.
    """

    os.environ.setdefault('MINERU_MODEL_SOURCE', 'huggingface')
Xiaomeng Zhao's avatar
Xiaomeng Zhao committed
18
19
    model_list_url = f"https://huggingface.co/models"
    modelscope_url = f"https://modelscope.cn/models"
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
    
    # Use a specific check for the Hugging Face source
    if os.environ['MINERU_MODEL_SOURCE'] == 'huggingface':
        try:
            response = requests.head(model_list_url, timeout=TIMEOUT)
            
            # Check for any successful status code (2xx)
            if response.ok:
                logging.info(f"Successfully connected to Hugging Face. Using 'huggingface' as model source.")
                return True
            else:
                logging.warning(f"Hugging Face endpoint returned a non-200 status code: {response.status_code}")

        except requests.exceptions.RequestException as e:
            logging.error(f"Failed to connect to Hugging Face at {model_list_url}: {e}")

        # If any of the above checks fail, switch to modelscope
        logging.info("Falling back to 'modelscope' as model source.")
        os.environ['MINERU_MODEL_SOURCE'] = 'modelscope'
    
    elif os.environ['MINERU_MODEL_SOURCE'] == 'modelscope':
        try:
42
            response = requests.head(modelscope_url, timeout=TIMEOUT)
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
            if response.ok:
                logging.info(f"Successfully connected to ModelScope. Using 'modelscope' as model source.")
                return True
        except requests.exceptions.RequestException as e:
            logging.error(f"Failed to connect to ModelScope at {model_list_url}: {e}")
        
    elif os.environ['MINERU_MODEL_SOURCE'] == 'local':
        logging.info("Using 'local' as model source.")
        return True
    
    else:
        logging.error(f"Using custom model source: {os.environ['MINERU_MODEL_SOURCE']}")
        return True
    
    return False

if __name__ == '__main__':
Xiaomeng Zhao's avatar
Xiaomeng Zhao committed
60
    print(config_endpoint())