Moderation

In addition to the system's built-in content moderation types, Dify also supports user-defined content moderation rules. This method is suitable for developers customizing their own private deployments. For instance, in an enterprise internal customer service setup, it may be required that users, while querying or customer service agents while responding, not only avoid entering words related to violence, sex, and illegal activities but also avoid specific terms forbidden by the enterprise or violating internally established moderation logic. Developers can extend custom content moderation rules at the code level in a private deployment of Dify.

Quick Start

Here is an example of extending a Cloud Service content moderation type, with the steps as follows:

  1. Initialize the directory

  2. Add the frontend component definition file

  3. Add the implementation class

  4. Preview the frontend interface

  5. Debug the extension

1. Initialize the Directory

To add a custom type Cloud Service, create the relevant directories and files under the api/core/moderation directory.

.
└── api
    └── core
        └── moderation
            └── cloud_service
                ├── __init__.py
                ├── cloud_service.py
                └── schema.json

2. Add Frontend Component Specifications

  • schema.json: This file defines the frontend component specifications. For details, see Code-Based Extension.

3. Add Implementation Class

cloud_service.py code template where you can implement specific business logic.

4. Debug the Extension

At this point, you can select the custom Cloud Service content moderation extension type for debugging in the Dify application orchestration interface.

Implementation Class Template

Detailed Introduction to Implementation Class Development

def validate_config

The schema.json form validation method is called when the user clicks "Publish" to save the configuration.

  • config form parameters

    • {{variable}} custom variable of the form

    • inputs_config input moderation preset response

      • enabled whether it is enabled

      • preset_response input preset response

    • outputs_config output moderation preset response

      • enabled whether it is enabled

      • preset_response output preset response

def moderation_for_inputs

Input validation function

  • inputs: values passed by the end user

  • query: the current input content of the end user in a conversation, a fixed parameter for conversational applications.

  • ModerationInputsResult

    • flagged: whether it violates the moderation rules

    • action: action to be taken

      • direct_output: directly output the preset response

      • overridden: override the passed variable values

    • preset_response: preset response (returned only when action=direct_output)

    • inputs: values passed by the end user, with key as the variable name and value as the variable value (returned only when action=overridden)

    • query: overridden current input content of the end user in a conversation, a fixed parameter for conversational applications (returned only when action=overridden)

def moderation_for_outputs

Output validation function

  • text: content output by the model

  • moderation_for_outputs: output validation function

    • text: content of the LLM response. When the LLM output is streamed, this is the content in segments of 100 characters.

    • ModerationOutputsResult

      • flagged: whether it violates the moderation rules

      • action: action to be taken

        • direct_output: directly output the preset response

        • overridden: override the passed variable values

      • preset_response: preset response (returned only when action=direct_output)

      • text: overridden content of the LLM response (returned only when action=overridden).

Last updated