-
Notifications
You must be signed in to change notification settings - Fork 125
/
content-filtering-policy.xml
95 lines (92 loc) · 4.67 KB
/
content-filtering-policy.xml
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<policies>
<inbound>
<set-variable name="SubscriptionKey" value="@(context.Request.Headers.GetValueOrDefault("api-key"))" />
<send-request mode="new" response-variable-name="safetyResponse">
<set-url>@("https://" + context.Request.Headers.GetValueOrDefault("Host") + "/contentsafety/text:analyze?api-version=2023-10-01")</set-url>
<set-method>POST</set-method>
<set-header name="Ocp-Apim-Subscription-Key" exists-action="override">
<value>@(context.Variables.GetValueOrDefault<string>("SubscriptionKey"))</value>
</set-header>
<set-header name="Content-Type" exists-action="override">
<value>application/json</value>
</set-header>
<set-body>@{
string[] categories = new string[] {"Hate","Sexual","SelfHarm","Violence"};
JObject obj = new JObject();
JProperty textProperty = new JProperty("text", string.Concat(context.Request.Body.As<JObject>(preserveContent: true)["messages"].Select(m => m.Value<string>("content")).ToArray()));
JProperty categoriesProperty = new JProperty("categories", new JArray(categories));
JProperty outputTypeProperty = new JProperty("outputType", "EightSeverityLevels");
obj.Add(textProperty);
obj.Add(categoriesProperty);
obj.Add(outputTypeProperty);
return obj.ToString();
}</set-body>
</send-request>
<choose>
<when condition="@(((IResponse)context.Variables["safetyResponse"]).StatusCode == 200)">
<set-variable name="thresholdExceededCategory" value="@{
var thresholdExceededCategory = "";
// Define the allowed threshold for each category
Dictionary<string, int> categoryThresholds = new Dictionary<string, int>()
{
{ "Hate", 0 },
{ "Sexual", 0 },
{ "SelfHarm", 0 },
{ "Violence", 0 }
};
foreach (var category in categoryThresholds)
{
var categoryAnalysis = ((JArray)((IResponse)context.Variables["safetyResponse"]).Body.As<JObject>(preserveContent: true)["categoriesAnalysis"]).FirstOrDefault(c => (string)c["category"] == category.Key);
if (categoryAnalysis != null && (int)categoryAnalysis["severity"] > category.Value)
{
// Threshold exceeded for the category
thresholdExceededCategory = category.Key;
break;
}
}
return thresholdExceededCategory;
}" />
<choose>
<when condition="@(context.Variables["thresholdExceededCategory"] != "")">
<return-response>
<set-status code="400" reason="Bad Request" />
<set-body>@{
var errorResponse = new
{
error = new
{
message = "The content was filtered by the Azure AI Content Safety service for the category: " + (string)context.Variables["thresholdExceededCategory"]
}
};
return JsonConvert.SerializeObject(errorResponse);
}</set-body>
</return-response>
</when>
</choose>
</when>
<otherwise>
<return-response>
<set-status code="500" reason="Internal Server Error" />
</return-response>
</otherwise>
</choose>
<base />
<authentication-managed-identity resource="https://cognitiveservices.azure.com" output-token-variable-name="managed-id-access-token" ignore-error="false" />
<set-header name="Authorization" exists-action="override">
<value>@("Bearer " + (string)context.Variables["managed-id-access-token"])</value>
</set-header>
<set-backend-service backend-id="{backend-id}" />
</inbound>
<backend>
<base />
</backend>
<outbound>
<base />
<set-header name="debug-content-safety-output" exists-action="override">
<value>@(((IResponse)context.Variables["safetyResponse"]).Body.As<string>(preserveContent: true))</value>
</set-header>
</outbound>
<on-error>
<base />
</on-error>
</policies>