From 646421399c96897abc55a6addf54903cbe295e16 Mon Sep 17 00:00:00 2001 From: robot-ci-heartex Date: Thu, 12 Dec 2024 06:05:34 +0000 Subject: [PATCH 1/6] ci: Update Feature Flags Workflow run: https://github.com/HumanSignal/label-studio/actions/runs/12290796936 --- label_studio/feature_flags.json | 81 +++++++++++++++++++++++++++++++++ 1 file changed, 81 insertions(+) diff --git a/label_studio/feature_flags.json b/label_studio/feature_flags.json index 184c844cbc7c..f96148991184 100644 --- a/label_studio/feature_flags.json +++ b/label_studio/feature_flags.json @@ -2499,6 +2499,33 @@ "version": 5, "deleted": false }, + "fflag_feat_front_leap_1424_grid_preview_short": { + "key": "fflag_feat_front_leap_1424_grid_preview_short", + "on": false, + "prerequisites": [], + "targets": [], + "contextTargets": [], + "rules": [], + "fallthrough": { + "variation": 0 + }, + "offVariation": 1, + "variations": [ + true, + false + ], + "clientSideAvailability": { + "usingMobileKey": false, + "usingEnvironmentId": false + }, + "clientSide": false, + "salt": "dfdd8f564ddc4111b73f59594a17502d", + "trackEvents": false, + "trackEventsFallthrough": false, + "debugEventsUntilDate": null, + "version": 2, + "deleted": false + }, "fflag_feat_front_leap_187_video_seek_on_select_short": { "key": "fflag_feat_front_leap_187_video_seek_on_select_short", "on": true, @@ -2985,6 +3012,33 @@ "version": 2, "deleted": false }, + "fflag_feat_front_optic_1351_use_new_projects_counts_api_short": { + "key": "fflag_feat_front_optic_1351_use_new_projects_counts_api_short", + "on": false, + "prerequisites": [], + "targets": [], + "contextTargets": [], + "rules": [], + "fallthrough": { + "variation": 0 + }, + "offVariation": 1, + "variations": [ + true, + false + ], + "clientSideAvailability": { + "usingMobileKey": false, + "usingEnvironmentId": false + }, + "clientSide": false, + "salt": "8fb14818f38c44e39f11993e13ab535a", + "trackEvents": false, + "trackEventsFallthrough": false, + "debugEventsUntilDate": null, + "version": 2, + "deleted": false + }, "fflag_feat_front_optic_1419_backend_csv_comments_export_short": { "key": "fflag_feat_front_optic_1419_backend_csv_comments_export_short", "on": false, @@ -4700,6 +4754,33 @@ "version": 5, "deleted": false }, + "fflag_fix_front_optic_1418_cache_members_manager_apis_short": { + "key": "fflag_fix_front_optic_1418_cache_members_manager_apis_short", + "on": false, + "prerequisites": [], + "targets": [], + "contextTargets": [], + "rules": [], + "fallthrough": { + "variation": 0 + }, + "offVariation": 1, + "variations": [ + true, + false + ], + "clientSideAvailability": { + "usingMobileKey": false, + "usingEnvironmentId": false + }, + "clientSide": false, + "salt": "15587c19c881430081d2fa63699543b9", + "trackEvents": false, + "trackEventsFallthrough": false, + "debugEventsUntilDate": null, + "version": 2, + "deleted": false + }, "fflag_fix_leap_246_multi_object_hotkeys_160124_short": { "key": "fflag_fix_leap_246_multi_object_hotkeys_160124_short", "on": true, From a900be23f5e006be8620c29ccabea3c1553f32b5 Mon Sep 17 00:00:00 2001 From: Alex Strick van Linschoten Date: Thu, 12 Dec 2024 14:40:47 +0100 Subject: [PATCH 2/6] docs: Change link to label-studio-sdk/converter in README.md (#6563) --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 95cab4fdf486..1fb21a6843ff 100644 --- a/README.md +++ b/README.md @@ -231,7 +231,7 @@ You can use Label Studio as an independent part of your machine learning workflo | label-studio | Server, distributed as a pip package | | [Frontend library](web/libs/editor/) | The Label Studio frontend library. This uses React to build the UI and mobx-state-tree for state management. | | [Data Manager library](web/libs/datamanager/) | A library for the Data Manager, our data exploration tool. | -| [label-studio-converter](https://github.com/HumanSignal/label-studio-converter) | Encode labels in the format of your favorite machine learning library | +| [label-studio-converter](https://github.com/HumanSignal/label-studio-sdk/tree/master/src/label_studio_sdk/converter) | Encode labels in the format of your favorite machine learning library | | [label-studio-transformers](https://github.com/HumanSignal/label-studio-transformers) | Transformers library connected and configured for use with Label Studio | ## Citation From 769ced2e0e3eb0bab198ef87f930811d285970a4 Mon Sep 17 00:00:00 2001 From: Sergei Ivashchenko Date: Fri, 13 Dec 2024 14:56:52 +0000 Subject: [PATCH 3/6] fix: LEAP-1352: API for Bulk Annotation Configuration Validation (#6757) Co-authored-by: hlomzik Co-authored-by: MihajloHoma Co-authored-by: triklozoid --- label_studio/projects/serializers.py | 83 +++++++++++++++++++ .../tests/config_validation.tavern.yml | 71 +++++++++++++++- 2 files changed, 153 insertions(+), 1 deletion(-) diff --git a/label_studio/projects/serializers.py b/label_studio/projects/serializers.py index c54be0470f5b..1df08fdd524a 100644 --- a/label_studio/projects/serializers.py +++ b/label_studio/projects/serializers.py @@ -3,6 +3,30 @@ import bleach from constants import SAFE_HTML_ATTRIBUTES, SAFE_HTML_TAGS from django.db.models import Q +from label_studio_sdk.label_interface import LabelInterface +from label_studio_sdk.label_interface.control_tags import ( + BrushLabelsTag, + BrushTag, + ChoicesTag, + DateTimeTag, + EllipseLabelsTag, + EllipseTag, + HyperTextLabelsTag, + KeyPointLabelsTag, + KeyPointTag, + LabelsTag, + NumberTag, + ParagraphLabelsTag, + PolygonLabelsTag, + PolygonTag, + RatingTag, + RectangleLabelsTag, + RectangleTag, + TaxonomyTag, + TextAreaTag, + TimeSeriesLabelsTag, + VideoRectangleTag, +) from projects.models import Project, ProjectImport, ProjectOnboarding, ProjectReimport, ProjectSummary from rest_flex_fields import FlexFieldsModelSerializer from rest_framework import serializers @@ -66,6 +90,9 @@ class ProjectSerializer(FlexFieldsModelSerializer): config_has_control_tags = SerializerMethodField( default=None, read_only=True, help_text='Flag to detect is project ready for labeling' ) + config_suitable_for_bulk_annotation = serializers.SerializerMethodField( + default=None, read_only=True, help_text='Flag to detect is project ready for bulk annotation' + ) finished_task_number = serializers.IntegerField(default=None, read_only=True, help_text='Finished tasks') queue_total = serializers.SerializerMethodField() @@ -82,6 +109,61 @@ def user_id(self): def get_config_has_control_tags(project): return len(project.get_parsed_config()) > 0 + @staticmethod + def get_config_suitable_for_bulk_annotation(project): + li = LabelInterface(project.label_config) + + # List of tags that should not be present + disallowed_tags = [ + LabelsTag, + BrushTag, + BrushLabelsTag, + EllipseTag, + EllipseLabelsTag, + KeyPointTag, + KeyPointLabelsTag, + PolygonTag, + PolygonLabelsTag, + RectangleTag, + RectangleLabelsTag, + HyperTextLabelsTag, + ParagraphLabelsTag, + TimeSeriesLabelsTag, + VideoRectangleTag, + ] + + # Return False if any disallowed tag is present + for tag_class in disallowed_tags: + if li.find_tags_by_class(tag_class): + return False + + # Check perRegion/perItem for expanded list of tags, plus value="no" for Choices/Taxonomy + allowed_tags_for_checks = [ChoicesTag, TaxonomyTag, DateTimeTag, NumberTag, RatingTag, TextAreaTag] + for tag_class in allowed_tags_for_checks: + tags = li.find_tags_by_class(tag_class) + for tag in tags: + per_region = tag.attr.get('perRegion', 'false').lower() == 'true' + per_item = tag.attr.get('perItem', 'false').lower() == 'true' + if per_region or per_item: + return False + # For ChoicesTag and TaxonomyTag, the value attribute must not be set at all + if tag_class in [ChoicesTag, TaxonomyTag]: + if 'value' in tag.attr: + return False + + # For TaxonomyTag, check labeling and apiUrl + taxonomy_tags = li.find_tags_by_class(TaxonomyTag) + for tag in taxonomy_tags: + labeling = tag.attr.get('labeling', 'false').lower() == 'true' + if labeling: + return False + api_url = tag.attr.get('apiUrl', None) + if api_url is not None: + return False + + # If all checks pass, return True + return True + @staticmethod def get_parsed_label_config(project): return project.get_parsed_config() @@ -156,6 +238,7 @@ class Meta: 'finished_task_number', 'queue_total', 'queue_done', + 'config_suitable_for_bulk_annotation', ] def validate_label_config(self, value): diff --git a/label_studio/tests/config_validation.tavern.yml b/label_studio/tests/config_validation.tavern.yml index 3dca2afeff3b..0320c072b97d 100644 --- a/label_studio/tests/config_validation.tavern.yml +++ b/label_studio/tests/config_validation.tavern.yml @@ -1435,4 +1435,73 @@ stages: method: POST url: '{django_live_url}/api/projects/{pk}/validate' response: - status_code: 200 \ No newline at end of file + status_code: 200 + +--- +test_name: check_config_suitable_for_bulk_annotation +strict: false +marks: +- usefixtures: + - django_live_url +stages: + +- id: signup + type: ref + +- name: create classification project + request: + data: + label_config: | + + + + + + + + + method: POST + url: '{django_live_url}/api/projects' + response: + status_code: 201 + save: + json: + classification_project_id: id + +- name: check classification project property + request: + method: GET + url: '{django_live_url}/api/projects/{classification_project_id}' + response: + status_code: 200 + json: + config_suitable_for_bulk_annotation: true + +- name: create object detection project + request: + data: + label_config: | + + + + + + method: POST + url: '{django_live_url}/api/projects' + response: + status_code: 201 + save: + json: + detection_project_id: id + +- name: check object detection project property + request: + method: GET + url: '{django_live_url}/api/projects/{detection_project_id}' + response: + status_code: 200 + json: + config_suitable_for_bulk_annotation: false From 510fe943faf2474c03666bcbe5f4578783c24da4 Mon Sep 17 00:00:00 2001 From: Jo Booth Date: Fri, 13 Dec 2024 12:12:13 -0500 Subject: [PATCH 4/6] chore: BEG-7: Django 5 upgrade (#6614) Co-authored-by: Wesley Lima Co-authored-by: niklub Co-authored-by: nik --- .github/workflows/tests.yml | 2 +- label_studio/core/settings/base.py | 18 +++++++++----- label_studio/data_manager/managers.py | 10 ++++---- poetry.lock | 34 +++++++++++++-------------- pyproject.toml | 6 ++--- 5 files changed, 37 insertions(+), 33 deletions(-) diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 17b3f99aac96..b192657d0313 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -179,7 +179,7 @@ jobs: fail-fast: false matrix: python-version: - - '3.9' + - '3.10' # required for poetry action # see https://github.com/marketplace/actions/install-poetry-action#running-on-windows diff --git a/label_studio/core/settings/base.py b/label_studio/core/settings/base.py index 1c641009e816..6258a78710b3 100644 --- a/label_studio/core/settings/base.py +++ b/label_studio/core/settings/base.py @@ -411,7 +411,14 @@ 'django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder', ) -STATICFILES_STORAGE = 'core.storage.SkipMissedManifestStaticFilesStorage' +STORAGES = { + 'default': { + 'BACKEND': 'django.core.files.storage.FileSystemStorage', + }, + 'staticfiles': { + 'BACKEND': 'core.storage.SkipMissedManifestStaticFilesStorage', + }, +} # Sessions and CSRF SESSION_COOKIE_SECURE = bool(int(get_env('SESSION_COOKIE_SECURE', False))) @@ -648,7 +655,7 @@ def collect_versions_dummy(**kwargs): if get_env('MINIO_STORAGE_ENDPOINT') and not get_bool_env('MINIO_SKIP', False): CLOUD_FILE_STORAGE_ENABLED = True - DEFAULT_FILE_STORAGE = 'storages.backends.s3boto3.S3Boto3Storage' + STORAGES['default']['BACKEND'] = 'storages.backends.s3boto3.S3Boto3Storage' AWS_STORAGE_BUCKET_NAME = get_env('MINIO_STORAGE_BUCKET_NAME') AWS_ACCESS_KEY_ID = get_env('MINIO_STORAGE_ACCESS_KEY') AWS_SECRET_ACCESS_KEY = get_env('MINIO_STORAGE_SECRET_KEY') @@ -661,7 +668,7 @@ def collect_versions_dummy(**kwargs): if get_env('STORAGE_TYPE') == 's3': CLOUD_FILE_STORAGE_ENABLED = True - DEFAULT_FILE_STORAGE = 'core.storage.CustomS3Boto3Storage' + STORAGES['default']['BACKEND'] = 'core.storage.CustomS3Boto3Storage' if get_env('STORAGE_AWS_ACCESS_KEY_ID'): AWS_ACCESS_KEY_ID = get_env('STORAGE_AWS_ACCESS_KEY_ID') if get_env('STORAGE_AWS_SECRET_ACCESS_KEY'): @@ -681,7 +688,7 @@ def collect_versions_dummy(**kwargs): if get_env('STORAGE_TYPE') == 'azure': CLOUD_FILE_STORAGE_ENABLED = True - DEFAULT_FILE_STORAGE = 'core.storage.CustomAzureStorage' + STORAGES['default']['BACKEND'] = 'core.storage.CustomAzureStorage' AZURE_ACCOUNT_NAME = get_env('STORAGE_AZURE_ACCOUNT_NAME') AZURE_ACCOUNT_KEY = get_env('STORAGE_AZURE_ACCOUNT_KEY') AZURE_CONTAINER = get_env('STORAGE_AZURE_CONTAINER_NAME') @@ -690,8 +697,7 @@ def collect_versions_dummy(**kwargs): if get_env('STORAGE_TYPE') == 'gcs': CLOUD_FILE_STORAGE_ENABLED = True - # DEFAULT_FILE_STORAGE = 'storages.backends.gcloud.GoogleCloudStorage' - DEFAULT_FILE_STORAGE = 'core.storage.AlternativeGoogleCloudStorage' + STORAGES['default']['BACKEND'] = 'core.storage.AlternativeGoogleCloudStorage' GS_PROJECT_ID = get_env('STORAGE_GCS_PROJECT_ID') GS_BUCKET_NAME = get_env('STORAGE_GCS_BUCKET_NAME') GS_EXPIRATION = timedelta(seconds=int(get_env('STORAGE_GCS_EXPIRATION_SECS', '86400'))) diff --git a/label_studio/data_manager/managers.py b/label_studio/data_manager/managers.py index b8d5365233ac..85c433a51250 100644 --- a/label_studio/data_manager/managers.py +++ b/label_studio/data_manager/managers.py @@ -599,7 +599,7 @@ def annotate_annotations_results(queryset): ) ) else: - return queryset.annotate(annotations_results=ArrayAgg('annotations__result', distinct=True)) + return queryset.annotate(annotations_results=ArrayAgg('annotations__result', distinct=True, default=Value([]))) def annotate_predictions_results(queryset): @@ -610,7 +610,7 @@ def annotate_predictions_results(queryset): ) ) else: - return queryset.annotate(predictions_results=ArrayAgg('predictions__result', distinct=True)) + return queryset.annotate(predictions_results=ArrayAgg('predictions__result', distinct=True, default=Value([]))) def annotate_annotators(queryset): @@ -619,7 +619,7 @@ def annotate_annotators(queryset): annotators=Coalesce(GroupConcat('annotations__completed_by'), Value(''), output_field=models.CharField()) ) else: - return queryset.annotate(annotators=ArrayAgg('annotations__completed_by', distinct=True)) + return queryset.annotate(annotators=ArrayAgg('annotations__completed_by', distinct=True, default=Value([]))) def annotate_predictions_score(queryset): @@ -653,7 +653,7 @@ def annotate_annotations_ids(queryset): if settings.DJANGO_DB == settings.DJANGO_DB_SQLITE: return queryset.annotate(annotations_ids=GroupConcat('annotations__id', output_field=models.CharField())) else: - return queryset.annotate(annotations_ids=ArrayAgg('annotations__id')) + return queryset.annotate(annotations_ids=ArrayAgg('annotations__id', default=Value([]))) def annotate_predictions_model_versions(queryset): @@ -662,7 +662,7 @@ def annotate_predictions_model_versions(queryset): predictions_model_versions=GroupConcat('predictions__model_version', output_field=models.CharField()) ) else: - return queryset.annotate(predictions_model_versions=ArrayAgg('predictions__model_version')) + return queryset.annotate(predictions_model_versions=ArrayAgg('predictions__model_version', default=Value([]))) def annotate_avg_lead_time(queryset): diff --git a/poetry.lock b/poetry.lock index 2a8e9a36228d..83ea851df632 100644 --- a/poetry.lock +++ b/poetry.lock @@ -60,13 +60,13 @@ test = ["coverage", "mypy", "pexpect", "ruff", "wheel"] [[package]] name = "asgiref" -version = "3.7.2" +version = "3.8.1" description = "ASGI specs, helper code, and adapters" optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "asgiref-3.7.2-py3-none-any.whl", hash = "sha256:89b2ef2247e3b562a16eef663bc0e2e703ec6468e2fa8a5cd61cd449786d4f6e"}, - {file = "asgiref-3.7.2.tar.gz", hash = "sha256:9e0ce3aa93a819ba5b45120216b23878cf6e8525eb3848653452b4192b92afed"}, + {file = "asgiref-3.8.1-py3-none-any.whl", hash = "sha256:3e1e3ecc849832fe52ccf2cb6686b7a55f82bb1d6aee72a58826471390335e47"}, + {file = "asgiref-3.8.1.tar.gz", hash = "sha256:c343bd80a0bec947a9860adb4c432ffa7db769836c64238fc34bdc3fec84d590"}, ] [package.dependencies] @@ -628,7 +628,6 @@ packaging = "*" pydantic = [ {version = ">=1.10.0,<2.0.0 || >2.0.0,<2.0.1 || >2.0.1,<2.4.0 || >2.4.0,<3.0", extras = ["email"], markers = "python_version >= \"3.12\" and python_version < \"4.0\""}, {version = ">=1.10.0,<2.4.0 || >2.4.0,<3.0", extras = ["email"], markers = "python_version >= \"3.11\" and python_version < \"3.12\""}, - {version = ">=1.5.1,<2.4.0 || >2.4.0,<3.0", extras = ["email"], markers = "python_version < \"3.10\""}, {version = ">=1.9.0,<2.4.0 || >2.4.0,<3.0", extras = ["email"], markers = "python_version >= \"3.10\" and python_version < \"3.11\""}, ] pyyaml = ">=6.0.1" @@ -675,17 +674,17 @@ files = [ [[package]] name = "django" -version = "4.2.17" +version = "5.1.4" description = "A high-level Python web framework that encourages rapid development and clean, pragmatic design." optional = false -python-versions = ">=3.8" +python-versions = ">=3.10" files = [ - {file = "Django-4.2.17-py3-none-any.whl", hash = "sha256:3a93350214ba25f178d4045c0786c61573e7dbfa3c509b3551374f1e11ba8de0"}, - {file = "Django-4.2.17.tar.gz", hash = "sha256:6b56d834cc94c8b21a8f4e775064896be3b4a4ca387f2612d4406a5927cd2fdc"}, + {file = "Django-5.1.4-py3-none-any.whl", hash = "sha256:236e023f021f5ce7dee5779de7b286565fdea5f4ab86bae5338e3f7b69896cf0"}, + {file = "Django-5.1.4.tar.gz", hash = "sha256:de450c09e91879fa5a307f696e57c851955c910a438a35e6b4c895e86bedc82a"}, ] [package.dependencies] -asgiref = ">=3.6.0,<4" +asgiref = ">=3.8.1,<4" sqlparse = ">=0.3.1" tzdata = {version = "*", markers = "sys_platform == \"win32\""} @@ -787,17 +786,17 @@ Django = ">=3.2" [[package]] name = "django-filter" -version = "2.4.0" +version = "24.3" description = "Django-filter is a reusable Django application for allowing users to filter querysets dynamically." optional = false -python-versions = ">=3.5" +python-versions = ">=3.8" files = [ - {file = "django-filter-2.4.0.tar.gz", hash = "sha256:84e9d5bb93f237e451db814ed422a3a625751cbc9968b484ecc74964a8696b06"}, - {file = "django_filter-2.4.0-py3-none-any.whl", hash = "sha256:e00d32cebdb3d54273c48f4f878f898dced8d5dfaad009438fe61ebdf535ace1"}, + {file = "django_filter-24.3-py3-none-any.whl", hash = "sha256:c4852822928ce17fb699bcfccd644b3574f1a2d80aeb2b4ff4f16b02dd49dc64"}, + {file = "django_filter-24.3.tar.gz", hash = "sha256:d8ccaf6732afd21ca0542f6733b11591030fa98669f8d15599b358e24a2cd9c3"}, ] [package.dependencies] -Django = ">=2.2" +Django = ">=4.2" [[package]] name = "django-migration-linter" @@ -3477,7 +3476,6 @@ files = [ {file = "PyYAML-6.0.1-cp311-cp311-win_amd64.whl", hash = "sha256:bf07ee2fef7014951eeb99f56f39c9bb4af143d8aa3c21b1677805985307da34"}, {file = "PyYAML-6.0.1-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:855fb52b0dc35af121542a76b9a84f8d1cd886ea97c84703eaa6d88e37a2ad28"}, {file = "PyYAML-6.0.1-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:40df9b996c2b73138957fe23a16a4f0ba614f4c0efce1e9406a184b6d07fa3a9"}, - {file = "PyYAML-6.0.1-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:a08c6f0fe150303c1c6b71ebcd7213c2858041a7e01975da3a99aed1e7a378ef"}, {file = "PyYAML-6.0.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6c22bec3fbe2524cde73d7ada88f6566758a8f7227bfbf93a408a9d86bcc12a0"}, {file = "PyYAML-6.0.1-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:8d4e9c88387b0f5c7d5f281e55304de64cf7f9c0021a3525bd3b1c542da3b0e4"}, {file = "PyYAML-6.0.1-cp312-cp312-win32.whl", hash = "sha256:d483d2cdf104e7c9fa60c544d92981f12ad66a457afae824d146093b8c294c54"}, @@ -4616,5 +4614,5 @@ uwsgi = ["pyuwsgi", "uwsgitop"] [metadata] lock-version = "2.0" -python-versions = ">=3.9,<4" -content-hash = "045667fad3d575ef8b624a03314d14107671c0a90211cba420859eedef23a84a" +python-versions = ">=3.10,<4" +content-hash = "5124c308584e6f9d7493d37f6d471947f30ab4eaedb1b13c3c6ac9a71c3eaccd" diff --git a/pyproject.toml b/pyproject.toml index bbd3e293c08d..b1e374e588cb 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -143,7 +143,7 @@ exclude = [ label-studio = "label_studio.server:main" [tool.poetry.dependencies] -python = ">=3.9,<4" +python = ">=3.10,<4" wheel = "<=0.40.0,>=0.38.1" appdirs = ">=1.4.3" attr = "0.3.1" @@ -154,12 +154,12 @@ boto = "^2.49.0" boto3 = "^1.28.58" botocore = "^1.31.58" bleach = "~=5.0.0" -Django = "~=4.2.13" +Django = "~=5.1.4" django-storages = "1.12.3" django-annoying = "0.10.6" django-debug-toolbar = "3.2.1" django-environ = "0.10.0" -django-filter = "2.4.0" +django-filter = "24.3" django-model-utils = "4.1.1" django-rq = "2.5.1" django-cors-headers = "3.6.0" From a47984fc32ee0b349ab09922b58e33ab49faf2e0 Mon Sep 17 00:00:00 2001 From: carly-bartel Date: Fri, 13 Dec 2024 13:32:54 -0500 Subject: [PATCH 5/6] docs: Update cta buttons for humansignal on enterprise and opensource (#6790) --- docs/source/guide/release_notes.md | 471 +++++++++++++++++++++++++++ docs/source/playground/index.ejs | 2 +- docs/themes/v2/layout/page.ejs | 9 +- docs/themes/v2/source/css/styles.css | 2 +- 4 files changed, 480 insertions(+), 4 deletions(-) diff --git a/docs/source/guide/release_notes.md b/docs/source/guide/release_notes.md index fc2319af9a5c..9bddffa00ee4 100644 --- a/docs/source/guide/release_notes.md +++ b/docs/source/guide/release_notes.md @@ -19,6 +19,477 @@ meta_description: Review new features, enhancements, and bug fixes for on-premis Before upgrading, review the steps outlined in [Upgrade Label Studio Enterprise](upgrade_enterprise) and ensure that you complete the recommended tests after each upgrade.
+ + +## Label Studio Enterprise 2.18.0 + +
Link comments to fields, export information from the Annotator Performance dashboard
+ +*Nov 19, 2024* + +Helm Chart version: 1.7.1 + +### New features + +#### Link comments to fields + +You can now link comments to specific regions or fields within an annotation. + +This change will help improve clarity between Annotators and Reviewers, enhancing the quality review process. + +For more information, see [Comments and notifications](https://docs.humansignal.com/guide/comments_notifications). + +![Screenshot of comment linking](/images/releases/2-18-comments1.png) + +![Screenshot of comment linking](/images/releases/2-18-comments2.png) + +#### Export information from the Annotator Performance dashboard + +There is a new **Export** action available from the [Annotator Performance dashboard.](https://docs.humansignal.com/guide/dashboard_annotator) + +- **Report** - Download the information in the dashboard as CSV or JSON. +- **Timeline** - Download a detailed timeline of all the user's annotation actions within the timeframe, including when the began and submitted each annotation. +- **Comments Received** - Download a CSV file with all of the comments that other users have left on the user's annotations. + +![Screenshot of export action](/images/releases/2-18-export.png) + +### Enhancements + +#### Performance score added to the Annotator Performance dashboard + +A **Performance Score** metric has been added to the Annotator Performance dashboard metrics. This reflects the overall performance of annotators in terms of review actions (**Accept**, **Reject**, **Fix+Accept**). For more information, see [Performance summaries](https://docs.humansignal.com/guide/dashboard_annotator#Performance-summaries). + +![Screenshot of Performance Score metric](/images/releases/2-18-score.png) + +#### Edit regions when classifying video frames + +We recently introduced the ability to perform [video frame classification](https://docs.humansignal.com/templates/video_frame_classification) with the `` tag. + +You now have the ability to edit the frame spans you select in the timeline editor, making it easier to control which frames you want to label. + +![Screenshot of edit action](/images/releases/2-18-edit.png) + +#### Improved usability on project settings pages + +There are a number of [project settings](https://docs.humansignal.com/guide/project_settings_lse) that are only applicable when auto distribution is enabled for users. + +To prevent confusion, settings that are not applicable will be hidden when manual distribution is enabled. + +This means the following settings will be hidden when **Annotation > Distribute Labeling Tasks** is set to **Manual**: + +- **Annotation > Task Sampling** +- **Quality > Overlap of Annotations** +- **Quality > Low Agreement Strategy** + +#### Hotkey to show/hide all regions + +A new hotkey (**Ctrl + h**) has been added. Use this shortcut to hide all regions. Or, if no regions are visible, show all regions. + +### Bug fixes + +- Fixed an issue where users were shown a 500 error when attempting to create a project without first selecting a workspace. + +- Fixed an issue where in certain scenarios users were unable to receive a password reset email. + +- Fixed an issue where non-unicode symbols would cause the Activity Log page to not load. + +- Fixed an issue where, despite the project settings, reviewers were not required to leave a comment on reject if they were using Quick View. + +- Fixed an issue where links were not resolving when using multiple S3 storages. + +- Fixed an issue where users were unable to use multiple source storages. + +- Fixed a small UI issue seen when displaying drop-down menus with multiple nested selection options. + +- Fixed an issue where deleting reviews did not clear cancelled values from the Data Manager. + +- Fixed an issue where the **Allow reviewer to choose: Requeue or Remove** setting could cause the Label All Tasks action to be enabled for annotators when there were no tasks to label. + +- Fixed an issue where instructions were not visible to reviewers in the Review Stream. + +- Fixed an issue in which SMTP configuration was not working correctly despite passing initial tests. + +- Fixed an issue where deleted annotator users were not available as option when building filters in the Data Manager. + +- Fixed an issue that could produce duplicate accounts when synced from SCIM. + +- Fixed an issue where the application would crash when annotators who have also had a project role of Reviewer would navigate to the Data Manager. + +- Fixed an issue where users were getting errors if using Redis passwords that included special characters. + + + + + + +
+ + +## Label Studio Enterprise 2.17.0 + +
New reviewer workflow options, streamlined layout for the Projects page, and other UI improvements
+ +*Oct 22, 2024* + +Helm Chart version: 1.6.3 + +### New features + +#### Allow Reviewers to either requeue or reject annotations + +There is a new option on the **Review** page of the project settings: **Allow reviewer to choose: Requeue or Remove**. + +When enabled, reviewers will see two reject options for an annotation: **Remove** (reject and remove the annotation from the queue) and **Requeue** (reject and then requeue the annotation). + +This is useful for situations in which some annotations are incorrect or incomplete, but are acceptable with some fixes. In those cases, it may be more useful to send the task back to the annotator. In other cases, where the annotation is far from correct, it is better to remove it entirely. + +For more information, see [Project settings - Review](#Review). + +![Screenshot of reject setting options](/images/releases/2_17_0_review_settings.png) + +![Screenshot of reject actions](/images/releases/2_17_0_review_actions.png) + +### Enhancements + +- The Projects page header has been updated with a more compact design: + - The search bar, projects drop-down menu, and create actions have all been consolidated onto one line. + - The **Use Template** action has been moved and is now available as a drop-down option within the **Create Project** button. + - The **Use Template** action has also been renamed **Create from saved template**. + + ![Screenshot of project page](/images/releases/2_17_0_project_page.png) +- For better clarity, the Sandbox workspace has been renamed **Personal Sandbox**. +- You will now see a progress bar when performing searches against the activity log to indicate that the search is still processing. +- When creating regions that have start and end times (such as when annotating sections of an audio track), you will now see the duration of your selection under the **Info** tab. + ![Screenshot of duration info](/images/releases/2_17_0_duration.png) + +### Bug fixes + +- Fixed an issue in which the agreement score was not updating after a reviewer completed the **Fix+Accept** action. +- Fixed an issue that caused the time portion of the DateTimePicker in the project Dashboard to not display correctly. +- Fixed an issue which caused the Label Config UI preview to display stale information. +- Fixed an issue in which users were not able to use Quick View to load tasks that included an external taxonomy. +- Fixed an issue where the instructions modal was not appearing for reviewers even though **Show before reviewing** was enabled in the project settings. +- Fixed an issue in which draft lead time could incorrectly inflate the lead time calculation for an annotation. +- Fixed an issue in which Data Manager drop-down menus were inaccessible in smaller viewports. +- Fixed a small UI issue seen when displaying drop-down menus with multiple nested selection options. +- Fixed an issue where images were improperly spaced in the Annotator Agreement Matrix. +- Fixed an issue in which **Label All Tasks** would not respect filters that had been applied in the Data Manager. + + + + + + +
+ + +## Label Studio Enterprise 2.16.0 + +
Video frame classification, user activation through SCIM, and bug fixes
+ +*Sep 24, 2024* + +Helm Chart version: 1.6.3 + + +### New features + +#### Video frame classification + +You can now apply labels to video frames. Previously, we only supported per-video classification. This new feature allows you to apply labels at a per-frame level. + +You can implement this feature using a new tag: [``](/tags/timelinelabels). + +For more information, see [New! Video Frame Classification](https://humansignal.com/blog/video-frame-classification/). + +![Video frame classification](/images/releases/2_16_video.png) + + +### Enhancements + +- You can now deactivate and activate user accounts via SCIM. Note that for this to work, `manual_role_management` must be set to `False`. + +- Changed the default behavior of the project Dashboard so that it no longer defaults to the “include time” option in the calendar. + +### Bug fixes + +- Fixed an issue where user limits were not being enforced when users were added via LDAP. + +- Fixed a regression issue with BigInteger support in the Data Manager. + +- Fixed a styling issue in which buttons were overlapping in the review workflow. + +- Fixed an issue with the Activity Logs page where some options would become unavailable. + +- Fixed an issue where setting a task agreement threshold incorrectly affected counts in the project Dashboard. + +- Fixed an issue in which notifications were fetched too frequently. + +- Fixed an issue with a missing `db` field for Redis storage, which caused issues for users adding Redis target storage. + +- Fixed an issue in which project-level roles could not be reverted once set. + + + + + + +
+ + +## Label Studio Enterprise 2.15.0 + +
Reviewer workflow updates, drag-and-drop tab reordering, usability enhancements for the Show region labels option, and upgrading to Django 4.2
+ +*Sep 03, 2024* + +Helm Chart version: 1.6.3 + +### Enhancements + +- The reviewer workflow has changed to be more user-friendly and intuitive. As part of this enhancement, you will see the following changes: + - If you are a Reviewer, Manager, Admin, or Owner and you click a task in the Data Manager, you will now see the reviewer actions (**Accept, Reject, Fix+Accept**) instead of the **Update** action. Going forward, only the user who created the annotation will see the **Update** action. + - The **Explore All Reviews** option is no longer available. This is because the same basic functionality is now available by simply selecting tasks in the Data Manager. + - When you click **Review All Tasks**, by default you will now be shown tasks in the same order in which the annotator completed their tasks. Previously, you were shown tasks in reverse order from completion. + + For more information, see [Improvements to HumanSignal Reviewer Workflow](https://humansignal.com/blog/improvements-to-humansignal-reviewer-workflow/). + +* You can now reorder tabs in the Data Manager by dragging and dropping them. + + ![Gif of reordering tabs](/images/releases/2-15-drag-and-drop.gif) + +* When viewing regions with the **Show region labels** option enabled, the region label will now include the same index identifier that you see in the regions list. + + Before: + + ![Screenshot of label regions before](/images/releases/2-15-label-after.png) + + After: + + ![Screenshot of label regions after](/images/releases/2-15-label-before.png) + +* When you make changes to the labeling configuration and attempt to navigate away before leaving, you will now see a warning message prompting you to save your changes. + + ![Screenshot of warning message](/images/releases/2-15-unsaved-changes.png) + +* When using the Annotator Performance Reports, you can now select whether you want to aggregate data by Creation Date or Updated Date. + + ![Screenshot of warning message](/images/releases/2-15-performance-report.png) + +* There is a new Performance Score column on the project Members page: + + The Performance Score column reflects the overall performance of annotators. This score takes into account all review actions, including annotations that were initially rejected and later accepted. The calculation is as follows: + - Each annotation review action (accept, reject, fix+accept) contributes to the score. + - The score is calculated by summing the scores of all review actions and dividing by the total number of review actions. + For example: + - If an annotation is rejected twice and then accepted once, the Performance Score would be (0 + 0 + 1) / 3 = 33%. + - If an annotation is rejected once and then fixed+accepted with a score of 42%, the Performance Score would be (0 + 0.42) / 2 = 21%. + + This is different from the Review Score, which only reflects the current accepted/rejected state of annotations. + + ![Screenshot of performance score](/images/releases/2-15-performance-score.png) + +* There is now a link to the HumanSignal support portal available from the menu. You can find FAQ and troubleshooting information here, as well as a link to open a support ticket. + + ![Screenshot of warning message](/images/releases/2-15-support-link.png) + +### Breaking changes + +- This release includes an upgrade to Django 4.2. As a result, PostgreSQL 11 is no longer support. Before upgrading, you must migrate to PostresSQL 12 or later. + +### Security + +Upgraded NLTK to 3.9.1 to address [CVE-2024-39705](https://nvd.nist.gov/vuln/detail/CVE-2024-39705). + +### Feature flag updates + +The following feature flags have been removed: + +- `fflag_feat_front_prod_e_111_annotator_workflow_control_short` +- `fflag_fix_front_lsdv_4673_rect3point_relative_310523_short` +- `ff_back_1614_rejected_queue_17022022_short` + +### Bug fixes + +- Fixed an issue where the View all annotations action was not working when the `` tag value was empty. + +- Fixed an issue where Annotators were not seeing comments when assigned to the Reviewer role on the project-level. + +- Fixed an issue with agreement scores for Annotators being inaccurately calculated on the Members page within projects. This issue would appear when a Reviewer would reject an annotation and then later accept it. + +- Fixed an issue with displaying large integer numbers in the Data Manager. + +- Fixed an issue with breaking Text/HyperText content that contains emoji when regions are added. + +- Fixed an issue with tooltips that was causing errors in the transition effects. + +- Fixed an issue where workspaces could be deleted through the API even if they still contained projects. + +- Fixed an issue where users were seeing an error when visiting the Annotator Performance Report page without first selecting a user. Instead, users should be redirected away from the page until a user is selected. + +- Fixed usability issues seen in the Members table once the member user list grows large enough. + +- Fixed an issue where users were seeing a runtime error when loading the dashboard in situations in which the project’s labeling configuration did not include labels. + +- Fixed an issue where tracing was breaking presigned URL requests. + +- Fixed an issue where the Project dashboard was returning an error. + +- Fixed an issue where, when attempting to select multiple bounding boxes by pressing Command (or Ctrl), a new bounding box would be created instead. + +- Fixed an issue where the project summary was not being included when duplicating a project. + +- Fixed an issue where images were improperly resizing after loading due to how the original dimensions were set. + + + + + +
+ + +## Label Studio Enterprise 2.14.0.post1 + +
Bug fix
+ +*Aug 27, 2024* + +Helm Chart version: 1.6.3 + +### Bug fixes +- Fixed an issue that occurred with Chrome v128 where the Data Manager would not display correctly. + + + + + + +
+ + +## Label Studio Enterprise 2.14.0 + +
Refreshed interface for the HumanSignal platform and bug fixes
+ +*Jul 30, 2024* + +Helm Chart version: 1.6.0 + +### New features + +#### Refreshed Label Studio interface + +This release includes a new UI with updated colors and fonts, giving it a sleek new look while maintaining the same intuitive navigation you're familiar with. All Label Studio tools, features, and settings are still in the same place, ensuring a smooth transition. + +![Screenshot of new UI](/images/releases/2-14-UI-login.png) + +![Screenshot of new UI](/images/releases/2-14-UI-new.png) + +![Screenshot of new UI](/images/releases/2-14-UI-projects.png) + +![Screenshot of new UI](/images/releases/2-14-UI-settings.png) + +![Screenshot of new UI](/images/releases/2-14-UI-settings2.png) + +### Bug fixes + +- Fixed an issue where users were unable to export in Pascal VOC XML format when applying bounding boxes to images. + +- Fixed an issue where after an annotation had been fixed and accepted, the update action was not recorded when exporting the annotation history to JSON. + +- Fixed a sizing issue affecting the icons for workspace actions. + +- Fixed an issue where the docs link icon was not properly formatted. + +- Fixed an issue affecting SAML users caused by changes to the HumanSignal app domain. + +- Fixed an issue in which sometimes the Submit button would be displayed when it should be the Update button. + +- Fixed an issue where Annotators where able to resolve comments made by Reviewers, when this action should not be available to them. + +- Fixed an issue where usernames in the Annotator Performance Report were not displayed correctly if the user had a long email address. + +- Fixed an issue where annotation history was not working correctly if `created_by` was null. + + + + + + +
+ + +## Label Studio Enterprise 2.13.0.post1 + +
Bug fix
+ +*Aug 27, 2024* + +Helm Chart version: 1.6.3 + +### Bug fixes +- Fixed an issue that occurred with Chrome v128 where the Data Manager would not display correctly. + + + + + +
+ + +## Label Studio Enterprise 2.13.0 + +
Annotator performance dashboards, potential breaking change for Google Cloud Storage users, feature flag changes
+ +*Jul 02, 2024* + +Helm Chart version: 1.4.9 + +### New features + +#### Annotator performance dashboards - Beta + +With this release, you will see a new **Performance report** action available from the Organization page. + +![Screenshot of Performance Report button](/images/project/user_report.png) + +Clicking this takes you to a dashboard focused on annotator performance. This new dashboard is designed to help you manage your team, figure out resource allocation, and save the expense of building custom internal tracking tools. + +![Screenshot of the annotator dashboard](/images/releases/2-13-annotator-report.png) + +The annotator performance dashboard provides insight into each user’s annotation activity over a period of time. You can see how much time they spent annotating, how many annotations they submitted, and their average time spent per annotation. You can further refine this dashboard by workspace and project. + +For more information, see [Annotator performance dashboard](dashboard_annotator) and [Annotator Dashboard Helps Optimize Team Performance](https://humansignal.com/blog/new-annotator-dashboard-helps-optimize-team-performance/). + +### Enhancements + +Improved performance on the Projects list page due to improvement on the API level. + + +### Breaking changes + +- Fixed an issue with Google Cloud Storage when the connection has the **Use pre-signed URLs** option disabled. In these situations, Google was sending pre-signed URLs with the format `https://storage.googleapis.com` rather than sending BLOBs. + + With this fix, Google Cloud Storage will begin returning BLOBs/base64 encoded data when **Use pre-signed URLs** is off. This means that Label Studio will start reading data from Google Cloud Storage buckets, which can result in large amounts of data being sent to your Label Studio instance - potentially affecting performance. + +### Feature flag changes + +- As part of an ongoing effort to streamline our codebase, we have identified a number of seldom-used feature flags. We have marked these feature flags as `stale`, meaning they can no longer be enabled by users. For a full list of all affected feature flags, see https://github.com/HumanSignal/label-studio/pull/5971 + +### Bug fixes + +- Fixed an issue with Redis being unable to connect to SSL. +- Fixed an issue where Redis storage connections were causing errors due to a missing field in the storage form (Storage Title). +- Fixed an issue where connected ML backends were unable to return more than one prediction per task. +- Fixed an issue where annotators were not being prompted to leave a comment when skipping a task, even though the project settings required them to do so. +- Fixed an issue where sometimes actual usernames were being replaced by a generic “Admin” username in the annotation history. + + + + + + +
## Label Studio Enterprise 2.12.0 diff --git a/docs/source/playground/index.ejs b/docs/source/playground/index.ejs index 1957051030a4..b6c481f71e1a 100644 --- a/docs/source/playground/index.ejs +++ b/docs/source/playground/index.ejs @@ -455,7 +455,7 @@ meta_description: Label Studio interactive demo and playground for data labeling

Want to put these templates into practice?

diff --git a/docs/themes/v2/layout/page.ejs b/docs/themes/v2/layout/page.ejs index 3b455616b79d..74b9052a4d7c 100644 --- a/docs/themes/v2/layout/page.ejs +++ b/docs/themes/v2/layout/page.ejs @@ -24,8 +24,13 @@
<% } %>
- Unlock more with Enterprise - <%- partial("component/button", { url: "https://humansignal.com/contact-sales", label: "Get a Demo", theme: "Tertiary" }) %> + <% if(isEnterpriseTheme) { %> + Designed for teams of all sizes + <%- partial("component/button", { url: "https://humansignal.com/contact-sales", label: "Contact Sales", theme: "Tertiary" }) %> + <% } else { %> + Designed for teams of all sizes + <%- partial("component/button", { url: "https://humansignal.com/pricing", label: "Compare Versions", theme: "Tertiary" }) %> + <% } %>
diff --git a/docs/themes/v2/source/css/styles.css b/docs/themes/v2/source/css/styles.css index c86554818d9b..f4235f5bb8fe 100644 --- a/docs/themes/v2/source/css/styles.css +++ b/docs/themes/v2/source/css/styles.css @@ -1260,7 +1260,7 @@ ul { .toc-enterprise-cta { margin-top: 2em; - padding: 1.5em 2em; + padding: 1.5em 1em; color: var(--color-gray-900); background: url("/images/design/gradient.svg"); background-size: cover; From 1ac41ae35febb58aa0633967ea4d3630f6893dbf Mon Sep 17 00:00:00 2001 From: robot-ci-heartex Date: Mon, 16 Dec 2024 06:05:34 +0000 Subject: [PATCH 6/6] ci: Update Feature Flags Workflow run: https://github.com/HumanSignal/label-studio/actions/runs/12346897752 --- label_studio/feature_flags.json | 31 +++++++++++++++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) diff --git a/label_studio/feature_flags.json b/label_studio/feature_flags.json index f96148991184..7b7407b4fda9 100644 --- a/label_studio/feature_flags.json +++ b/label_studio/feature_flags.json @@ -2418,6 +2418,33 @@ "version": 4, "deleted": false }, + "fflag_feat_front_dia_1747_projects_list_banner": { + "key": "fflag_feat_front_dia_1747_projects_list_banner", + "on": false, + "prerequisites": [], + "targets": [], + "contextTargets": [], + "rules": [], + "fallthrough": { + "variation": 0 + }, + "offVariation": 1, + "variations": [ + true, + false + ], + "clientSideAvailability": { + "usingMobileKey": false, + "usingEnvironmentId": false + }, + "clientSide": false, + "salt": "21bfa474c82b4ab0b89314fbecd164cc", + "trackEvents": false, + "trackEventsFallthrough": false, + "debugEventsUntilDate": null, + "version": 3, + "deleted": false + }, "fflag_feat_front_dia_916_model_creation_and_versioning_short": { "key": "fflag_feat_front_dia_916_model_creation_and_versioning_short", "on": true, @@ -3036,7 +3063,7 @@ "trackEvents": false, "trackEventsFallthrough": false, "debugEventsUntilDate": null, - "version": 2, + "version": 3, "deleted": false }, "fflag_feat_front_optic_1419_backend_csv_comments_export_short": { @@ -4778,7 +4805,7 @@ "trackEvents": false, "trackEventsFallthrough": false, "debugEventsUntilDate": null, - "version": 2, + "version": 3, "deleted": false }, "fflag_fix_leap_246_multi_object_hotkeys_160124_short": {