Skip to main content

eox-tagging

Project description

Maintainance Status GitHub Actions Workflow Test Status PyPI - Version

Eox-tagging is an openedx plugin, part of the Edunext Open edX Extensions (aka EOX), that adds the capability to tag edx-platform objects. These tags can be used to categorize, include extra information, and so on.

Installation

  1. Add this plugin in your Tutor config.yml with the OPENEDX_EXTRA_PIP_REQUIREMENTS setting.

    OPENEDX_EXTRA_PIP_REQUIREMENTS:
       - eox-tagging=={{version}}
  2. Save the configuration with tutor config save.

  3. Build the image and launch your platform with tutor local launch.

Compatibility Notes

Open edX Release

Version

Ironwood

< 0.9 < 3.0

Juniper

>= 0.9 < 3.0

Koa

>= 2.2 < 5.0

Lilac

>= 2.2 < 5.0

Maple

>= 4.0 < 6.0

Nutmeg

>= 5.0 < 6.0

Olive

>= 5.0 < 6.0

Palm

>= 6.0 < 8.0

Quince

>= 7.0 < 9.0

Redwood

>= 7.2.0

Sumac

>= 9.0.0

Teak

>= 9.1.0

Ulmo

>= 9.3.0

Verawood

>= 9.4.0

The plugin is configured for the latest release (Teak). The following changes in the plugin settings should be applied to be used for previous releases. Those settings can be changed in eox_tagging/settings/common.py` or, for example, in the instance configurations.

🚨 If the release you are looking for is not listed, please note:

  • If the Open edX release is compatible with the current eox-tagging version (see Compatibility Notes), the default configuration is sufficient.

  • If incompatible, you can refer to the README from the relevant version tag for configuration details (e.g., v5.1.0 README).

Usage

See the How to section for detailed guidance on model, configurations and API usage.

Important notes:

  • All the comparisons with string objects are case insensitive.

  • If a tag owner is not defined, then it is assumed to be the site.

Examples

Example 1:

{
    "validate_tag_value": {
        "in": [
            "example_tag_value",
            "example_tag_value_1"
        ]
    },
    "validate_access": {
        "equals": "PRIVATE"
    },
    "validate_target_object": "OpaqueKeyProxyModel",
    "owner_object": "User",
    "tag_type": "tag_by_example"
}

This means that:

  • Tag value must be in the array

  • The field access must be equal to private

  • The target type must be equal to CourseOverview

  • The owner type must be equal to User

  • Tag_type must be equal to tag_by_example

Example 2:

{
    "validate_tag_value": {
        "exist": true
    },
    "validate_access": "Public",
    "validate_target_object": "User",
    "tag_type": "tag_by_edunext"
}

This means that:

  • The tag value must exist, it can take any value.

  • The field access must be equal to public.

  • The target type must be equal to User.

  • Tag type must be equal to tag_by_edunext.

Example 3:

{
    "validate_tag_value": "tag_value",
    "validate_access": {
        "in": [
            "Private",
            "Public"
        ]
    },
    "validate_target_object": "CourseEnrollment",
    "tag_type": "tag_by_edunext",
    "validate_activation_date": {
        "exist": true,
        "in": [
            "Dec 04 2020 10:30:40",
            "Oct 19 2020 10:30:40"
        ]
    }
}

This means that:

  • The tag value must be equal to tag_value.

  • The field access can be private or public.

  • The target type must be equal to CourseEnrollment

  • Tag type must be equal to tag_by_edunext.

  • The tag activation date must exist between the values defined in the array. This means, value_1 <= activation_date <= value_2. The array must be sorted or a validation error will be raised.

Tagging REST API

Get a list of tags

Request

curl -H 'Accept: application/json' -H "Authorization: Bearer AUTHENTICATION_TOKEN" http://BASE_URL_SITE/eox-tagging/api/v1/tags/

Response

{
    "count": 2,
    "next": null,
    "previous": null,
    "results": [
        {
            "meta": {
                "created_at": "2020-07-10T13:25:54.057846Z",
                "target_id": 2,
                "target_type": "User",
                "inactivated_at": null,
                "owner_type": "User",
                "owner_id": 7
            },
            "key": "55a20579-ce8e-4f0b-830e-78fe79adac46",
            "tag_value": "tag_value",
            "tag_type": "tag_by_edunext",
            "access": "PUBLIC",
            "activation_date": "2020-12-04T15:20:30Z",
            "expiration_date": null,
            "status": "ACTIVE"
        },
        {
            "meta": {
                "created_at": "2020-07-10T13:33:44.277374Z",
                "target_id": 2,
                "target_type": "User",
                "inactivated_at": null,
                "owner_type": "Site",
                "owner_id": 1
            },
            "key": "2bec10f5-a9e0-4e42-9c24-f9643bb13537",
            "tag_value": "tag_value",
            "tag_type": "tag_by_edunext",
            "access": "PUBLIC",
            "activation_date": "2020-12-04T15:20:30Z",
            "expiration_date": null,
            "status": "ACTIVE"
        },
    ]
}

Create tag

Request

curl -H 'Accept: application/json' -H "Authorization: Bearer AUTHENTICATION_TOKEN" --data TAG_DATA http://BASE_URL_SITE/eox-tagging/api/v1/tags/

Where TAG_DATA:

{
    "tag_type": "tag_by_edunext",
    "tag_value": "tag_value",
    "target_type": "user",
    "target_id": "edx",
    "access": "public",
    "owner_type": "user",
    "activation_date": "2020-12-04 10:20:30"
}

Response:

Status 201 Created

{
    "meta": {
        "created_at": "2020-07-10T13:25:54.057846Z",
        "target_id": 2,
        "target_type": "User",
        "inactivated_at": null,
        "owner_type": "User",
        "owner_id": 7
    },
    "key": "55a20579-ce8e-4f0b-830e-78fe79adac46",
    "tag_value": "tag_value",
    "tag_type": "tag_by_edunext",
    "access": "PUBLIC",
    "activation_date": "2020-12-04T10:20:30-05:00",
    "expiration_date": null,
    "status": "ACTIVE"
}

Delete tag

Request

curl -X DELETE http://BASE_URL_SITE/eox-tagging/api/v1/tags/EXISTING_KEY_TAG/

Response

Status 204 No Content

Filters example usage:

/eox_tagging/api/v1/tags/?target_type=MODEL_TYPE

/eox_tagging/api/v1/tags/?course_id=COURSE_ID

/eox_tagging/api/v1/tags/?username=USERNAME

/eox_tagging/api/v1/tags/?access=ACCESS_TYPE

/eox_tagging/api/v1/tags/?enrollments=COURSE_ID

Auditing Django views

The majority of views in eox-tagging use an auditing decorator, defined in our custom library called eox-audit-model, that helps save relevant information about non-idempotent operations. By default, this functionality is turned off, to enable it, install eox-audit-model.

Check your auditing records in Django sysadmin > DJANGO EDUNEXT AUDIT MODEL.

For more information, check the eox-audit-model documentation.

How to Contribute

Contributions are welcome! See our CONTRIBUTING file for more information – it also contains guidelines for how to maintain high code quality, which will make your contribution more likely to be accepted.

License

This project is licensed under the AGPL-3.0 License. See the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

eox_tagging-9.4.0.tar.gz (53.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

eox_tagging-9.4.0-py3-none-any.whl (63.7 kB view details)

Uploaded Python 3

File details

Details for the file eox_tagging-9.4.0.tar.gz.

File metadata

  • Download URL: eox_tagging-9.4.0.tar.gz
  • Upload date:
  • Size: 53.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for eox_tagging-9.4.0.tar.gz
Algorithm Hash digest
SHA256 3959839953c50036dbff869ccacab9a0b46aecd2c564e2c9235d06faf2bd3a14
MD5 087c7e8728bdb530a926d238d2937f04
BLAKE2b-256 e886b4c27e54c8c633f04034b63d6ede1a6aac2fc3bc5772a269c9c00ca95be4

See more details on using hashes here.

File details

Details for the file eox_tagging-9.4.0-py3-none-any.whl.

File metadata

  • Download URL: eox_tagging-9.4.0-py3-none-any.whl
  • Upload date:
  • Size: 63.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for eox_tagging-9.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e0831e91350a4ca41ac561dcf94f91186a396635f33f54104e45fc296d005eeb
MD5 4e896b4763f6dd77b6701819056f2541
BLAKE2b-256 9838bd8d3ae2faf31dfbcef5366a11dbc5640d4a1fbad3d4c86c694a361065db

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page