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.

121 lines
5.0 KiB

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