Bin
2025-12-17 262fecaa75b2909ad244f12c3b079ed3ff4ae329
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
# Common S3 storage schema properties following OpenAPI 3.0 specification
_common_s3_storage_schema_properties = {
    'title': {'type': 'string', 'description': 'Storage title', 'maxLength': 2048},
    'description': {'type': 'string', 'description': 'Storage description'},
    'project': {'type': 'integer', 'description': 'Project ID'},
    'bucket': {'type': 'string', 'description': 'S3 bucket name'},
    'prefix': {'type': 'string', 'description': 'S3 bucket prefix'},
    'aws_access_key_id': {'type': 'string', 'description': 'AWS_ACCESS_KEY_ID'},
    'aws_secret_access_key': {'type': 'string', 'description': 'AWS_SECRET_ACCESS_KEY'},
    'aws_session_token': {'type': 'string', 'description': 'AWS_SESSION_TOKEN'},
    'aws_sse_kms_key_id': {'type': 'string', 'description': 'AWS SSE KMS Key ID'},
    'region_name': {'type': 'string', 'description': 'AWS Region'},
    's3_endpoint': {'type': 'string', 'description': 'S3 Endpoint'},
}
 
# S3 import storage schema
_s3_import_storage_schema = {
    'type': 'object',
    'properties': {
        'regex_filter': {
            'type': 'string',
            'description': 'Cloud storage regex for filtering objects. You must specify it otherwise no objects will be imported.',
        },
        'use_blob_urls': {
            'type': 'boolean',
            'description': 'Interpret objects as BLOBs and generate URLs. For example, if your bucket contains images, you can use this option to generate URLs for these images. If set to False, it will read the content of the file and load it into Label Studio.',
            'default': False,
        },
        'presign': {'type': 'boolean', 'description': 'Presign URLs for download', 'default': True},
        'presign_ttl': {'type': 'integer', 'description': 'Presign TTL in minutes', 'default': 1},
        'recursive_scan': {'type': 'boolean', 'description': 'Scan recursively'},
        **_common_s3_storage_schema_properties,
    },
    'required': [],
}
 
# S3 import storage schema with ID
_s3_import_storage_schema_with_id = {
    'type': 'object',
    'properties': {
        'id': {'type': 'integer', 'description': 'Storage ID. If set, storage with specified ID will be updated'},
        **_s3_import_storage_schema['properties'],
    },
    'required': [],
}
 
# S3 export storage schema
_s3_export_storage_schema = {
    'type': 'object',
    'properties': {
        'can_delete_objects': {'type': 'boolean', 'description': 'Deletion from storage enabled.', 'default': False},
        **_common_s3_storage_schema_properties,
    },
    'required': [],
}
 
# S3 export storage schema with ID
_s3_export_storage_schema_with_id = {
    'type': 'object',
    'properties': {
        'id': {'type': 'integer', 'description': 'Storage ID. If set, storage with specified ID will be updated'},
        **_s3_export_storage_schema['properties'],
    },
    'required': [],
}