You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

151 lines
6.2 KiB

4 years ago
2 years ago
3 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
8 months ago
4 years ago
4 years ago
2 years ago
8 months ago
6 months ago
8 months ago
4 years ago
8 months ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.Web;
  5. namespace Apewer.Web
  6. {
  7. /// <summary>选项。</summary>
  8. public sealed class ApiOptions
  9. {
  10. /// <summary>允许压缩。</summary>
  11. /// <remarks>默认值:不允许。</remarks>
  12. public bool AllowCompression { get; set; } = false;
  13. /// <summary>设置 Access-Control-Max-Age 的值。</summary>
  14. /// <remarks>默认值:60。</remarks>
  15. public int AccessControlMaxAge { get; set; } = 60;
  16. /// <summary>允许枚举输出 Applications 或 Functions。</summary>
  17. /// <remarks>默认值:不允许,不输出列表。</remarks>
  18. public bool AllowEnumerate { get; set; } = false;
  19. /// <summary>允许解析 favicon.ico 请求。</summary>
  20. /// <remarks>默认值:不允许,响应空。</remarks>
  21. public bool AllowFavIcon { get; set; } = false;
  22. /// <summary>允许解析 robots.txt 请求。</summary>
  23. /// <remarks>默认值:不允许,拒绝搜索引擎收录根目录。</remarks>
  24. public bool AllowRobots { get; set; } = false;
  25. // /// <summary>允许同步 IO。</summary>
  26. // /// <remarks>
  27. // /// <para>默认值:允许。</para>
  28. // /// <para>允许:使用同步方法写入 Response.Body,可能会导致线程不足而崩溃。</para>
  29. // /// <para>不允许:必须用异步方法写入 Response.Body。</para>
  30. // /// </remarks>
  31. // public bool AllowSynchronousIO { get; set; } = true;
  32. /// <summary>默认的结果渲染器。</summary>
  33. /// <remarks>默认值:NULL</remarks>
  34. public Action<ApiContext, object> DefaultRenderer { get; set; }
  35. /// <summary>对输出的 Json 对象缩进。</summary>
  36. /// <remarks>默认值:不缩进。</remarks>
  37. public bool JsonIndent { get; set; } = false;
  38. /// <summary>默认的结果渲染器。</summary>
  39. /// <remarks>默认值:NULL</remarks>
  40. public Action<ApiContext, Json> JsonRenderer { get; set; }
  41. /// <summary>限制最大请求的字节数。</summary>
  42. /// <remarks>默认值:-1,不使用 ApiOptions 限制。</remarks>
  43. public long MaxRequestBody { get; set; } = -1;
  44. /// <summary>输出前的检查。</summary>
  45. public ApiPreOutput PreOutput { get; set; }
  46. /// <summary>默认的结果渲染器。</summary>
  47. /// <remarks>默认值:NULL(返回值不为空时视为错误信息)</remarks>
  48. public Action<ApiContext, string> TextRenderer { get; set; }
  49. /// <summary>在响应头中设置 Content-Security-Policy,要求浏览器升级资源链接,使用 HTTPS。</summary>
  50. /// <remarks>默认值:不要求。在 HTTPS 页面中,不自动升级 HTTP 资源。</remarks>
  51. public bool UpgradeHttps { get; set; } = false;
  52. /// <summary>使用反射。</summary>
  53. /// <remarks>默认值:使用</remarks>
  54. public bool UseReflection { get; set; } = true;
  55. /// <summary>使用路由。</summary>
  56. /// <remarks>默认值:使用</remarks>
  57. public bool UseRoute { get; set; } = true;
  58. /// <summary>在响应中包含 Access-Control 属性。</summary>
  59. /// <remarks>默认值:不包含。</remarks>
  60. public bool WithAccessControl { get; set; } = false;
  61. /// <summary>在响应中包含时间属性。</summary>
  62. /// <remarks>默认值:不包含。</remarks>
  63. public bool WithClock { get; set; } = false;
  64. /// <summary>允许响应标头中包含 X-Content-Type-Options: nosiff。</summary>
  65. /// <remarks>默认值:不包含。当设置默认控制器时自动启用此属性。</remarks>
  66. public bool WithContentTypeOptions { get; set; } = false;
  67. /// <summary>在响应中包含执行 API 的持续时间。</summary>
  68. /// <remarks>默认值:不包含。</remarks>
  69. public bool WithDuration { get; set; } = false;
  70. /// <summary>允许响应中包含 Exception 对象的属性。</summary>
  71. /// <remarks>默认值:不允许。</remarks>
  72. public bool WithException { get; set; } = false;
  73. /// <summary>允许输出 Application 列表时包含模块名称。</summary>
  74. /// <remarks>默认值:不包含。</remarks>
  75. public bool WithModuleName { get; set; } = false;
  76. /// <summary>允许在枚举 Function 时包含参数信息。</summary>
  77. /// <remarks>默认值:不包含。</remarks>
  78. public bool WithParameters { get; set; } = false;
  79. /// <summary>在响应中包含 Application 和 Function 属性。</summary>
  80. /// <remarks>默认值:不包含。</remarks>
  81. public bool WithTarget { get; set; } = false;
  82. /// <summary>允许输出 Application 列表时包含类型名称。</summary>
  83. /// <remarks>默认值:不包含。</remarks>
  84. public bool WithTypeName { get; set; } = false;
  85. #region 默认控制器,可用于静态控制器。
  86. private Type _default = null;
  87. /// <summary>获取已设置的控制器类型,当未匹配到 Application 或 Function 时候,使用此类型创建控制器。</summary>
  88. public Type Default { get => _default; }
  89. /// <summary>设置控制器类型,当未匹配到 Application 或 Function 时候,使用此类型创建控制器。</summary>
  90. public void SetDefault<T>() where T : ApiController, new() => _default = typeof(T);
  91. /// <summary>取消默认控制器类型。</summary>
  92. public void SetDefault() => _default = null;
  93. #endregion
  94. /// <summary>创建默认选项。</summary>
  95. /// <remarks>
  96. /// 在 Debug 模式中默认设置以下选项
  97. /// <br />JsonIndent = TRUE
  98. /// <br />WithException = TRUE
  99. /// <br />WithDuration = TRUE
  100. /// <br />WithParameters = TRUE
  101. /// </remarks>
  102. public ApiOptions()
  103. {
  104. Debug();
  105. }
  106. [Conditional("DEBUG")]
  107. void Debug()
  108. {
  109. JsonIndent = true;
  110. WithException = true;
  111. WithDuration = true;
  112. WithParameters = true;
  113. }
  114. }
  115. }