-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathweb.config
108 lines (95 loc) · 3.83 KB
/
web.config
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
96
97
98
99
100
101
102
103
104
105
106
107
108
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appSettings>
<clear />
</appSettings>
<system.web>
<httpRuntime maxRequestLength="102400" maxUrlLength="102400" maxQueryStringLength="10000" requestValidationType="System.Web.Util.RequestValidator" />
<httpModules>
<clear />
</httpModules>
<httpHandlers>
<clear />
</httpHandlers>
</system.web>
<system.webServer>
<validation validateIntegratedModeConfiguration="false" />
<rewrite>
<rules>
<clear />
<rule name="Redirect to https" stopProcessing="true">
<match url=".*" />
<conditions>
<add input="{HTTPS}" pattern="off" ignoreCase="true" />
</conditions>
<action type="Redirect" url="https://{HTTP_HOST}{REQUEST_URI}" redirectType="Permanent" appendQueryString="false" />
</rule>
<rule name="new-api-reference-redirect" enabled="true">
<match url="api/html/(.*)" ignoreCase="true" />
<action type="Redirect" url="api" redirectType="Permanent" />
</rule>
<rule name="index" enabled="true" stopProcessing="true">
<match url="^/?$" />
<action type="Redirect" url="introduction" redirectType="Found" />
</rule>
{% for directory in site.redirect_directories %}
<rule name="redirect-{{ directory.path | replace: '/', '-' }}" enabled="true">
<match url="^{{ directory.path }}/?$" />
<conditions logicalGrouping="MatchAll">
<add input="{REQUEST_FILENAME}.html" matchType="IsFile" negate="true" />
</conditions>
<action type="Redirect" url="{{ directory.url }}" redirectType="Permanent" />
</rule>
{% endfor %}
{% for page in site.redirect_pages %} {% for redirect in page.previous_url %}
<rule name="redirect-{{ redirect | remove_first: '/' | replace: '/', '-' }}" enabled="true" stopProcessing="true">
<match url="^{{ redirect | remove_first: '/' }}$" />
<action type="Redirect" url="{{ page.url | remove_first: '/' | replace: '.html', '' }}" />
</rule>
{% endfor %}{% endfor %}
<rule name="Convert to lower case" enabled="true">
<match url="^([^?]*[A-Z][^?]*)(\?.*)?" ignoreCase="false" />
<conditions>
<add input="{REQUEST_FILENAME}" pattern="\.png|\.css|\.jpg|\.gif" negate="true" />
</conditions>
<action type="Redirect" url="{ToLower:{R:1}}{ToLower:{R:2}}" redirectType="Permanent" />
</rule>
<rule name="Hide .html ext" enabled="true">
<match ignoreCase="true" url="^(.*)"/>
<conditions>
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true"/>
<add input="{REQUEST_FILENAME}" pattern="\.png|\.css|\.jpg|\.gif" negate="true" />
<add input="{REQUEST_FILENAME}.html" matchType="IsFile"/>
</conditions>
<action type="Rewrite" url="{ToLower:{R:0}.html}"/>
</rule>
<rule name="Redirecting .html ext" enabled="true">
<match url="^(.*)[.]html$"/>
<conditions logicalGrouping="MatchAny">
<add input="{URL}" pattern="(.*)[.]html$"/>
</conditions>
<action type="Redirect" url="{ToLower:{R:1}}"/>
</rule>
<rule name="copyright" enabled="true" stopProcessing="true">
<match url="^licensing/copyright"/>
<action type="Redirect" url="copyright"/>
</rule>
</rules>
</rewrite>
<httpProtocol>
<customHeaders>
<add name="Cache-Control" value="no-cache" />
</customHeaders>
</httpProtocol>
<staticContent>
<remove fileExtension=".json" />
<mimeMap fileExtension=".json" mimeType="application/json" />
<remove fileExtension=".woff" />
<mimeMap fileExtension=".woff" mimeType="application/x-font-woff" />
</staticContent>
<httpErrors errorMode="Custom" defaultResponseMode="File" >
<remove statusCode="404" />
<error statusCode="404" path="40x.html" />
</httpErrors>
</system.webServer>
</configuration>