gitea源码

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442
  1. {{template "admin/layout_head" (dict "ctxData" . "pageClass" "admin edit authentication")}}
  2. <div class="admin-setting-content">
  3. <h4 class="ui top attached header">
  4. {{ctx.Locale.Tr "admin.auths.edit"}}
  5. </h4>
  6. <div class="ui attached segment">
  7. <form class="ui form" action="{{.Link}}" method="post">
  8. {{template "base/disable_form_autofill"}}
  9. {{.CsrfTokenHtml}}
  10. <input type="hidden" name="id" value="{{.Source.ID}}">
  11. <div class="inline field">
  12. <label>{{ctx.Locale.Tr "admin.auths.auth_type"}}</label>
  13. <input type="hidden" id="auth_type" name="type" value="{{.Source.Type.Int}}">
  14. <span>{{.Source.TypeName}}</span>
  15. </div>
  16. <div class="required inline field {{if .Err_Name}}error{{end}}">
  17. <label for="auth_name">{{ctx.Locale.Tr "admin.auths.auth_name"}}</label>
  18. <input id="auth_name" name="name" value="{{.Source.Name}}" required>
  19. </div>
  20. <div class="inline field">
  21. <div class="ui checkbox">
  22. <label ><strong>{{ctx.Locale.Tr "admin.auths.skip_local_two_fa"}}</strong></label>
  23. <input name="two_factor_policy" type="checkbox" value="skip" {{if eq .Source.TwoFactorPolicy "skip"}}checked{{end}}>
  24. <p class="help">{{ctx.Locale.Tr "admin.auths.skip_local_two_fa_helper"}}</p>
  25. </div>
  26. </div>
  27. <!-- LDAP and DLDAP -->
  28. {{if or .Source.IsLDAP .Source.IsDLDAP}}
  29. {{$cfg:=.Source.Cfg}}
  30. <div class="inline required field {{if .Err_SecurityProtocol}}error{{end}}">
  31. <label>{{ctx.Locale.Tr "admin.auths.security_protocol"}}</label>
  32. <div class="ui selection security-protocol dropdown">
  33. <input type="hidden" id="security_protocol" name="security_protocol" value="{{$cfg.SecurityProtocol.Int}}">
  34. <div class="text">{{$cfg.SecurityProtocolName}}</div>
  35. {{svg "octicon-triangle-down" 14 "dropdown icon"}}
  36. <div class="menu">
  37. {{range .SecurityProtocols}}
  38. <div class="item" data-value="{{.Type.Int}}">{{.Name}}</div>
  39. {{end}}
  40. </div>
  41. </div>
  42. </div>
  43. <div class="required field">
  44. <label for="host">{{ctx.Locale.Tr "admin.auths.host"}}</label>
  45. <input id="host" name="host" value="{{$cfg.Host}}" placeholder="mydomain.com" required>
  46. </div>
  47. <div class="required field">
  48. <label for="port">{{ctx.Locale.Tr "admin.auths.port"}}</label>
  49. <input id="port" name="port" value="{{$cfg.Port}}" placeholder="636" required>
  50. </div>
  51. <div class="has-tls inline field {{if not .HasTLS}}tw-hidden{{end}}">
  52. <div class="ui checkbox">
  53. <label><strong>{{ctx.Locale.Tr "admin.auths.skip_tls_verify"}}</strong></label>
  54. <input name="skip_verify" type="checkbox" {{if .Source.SkipVerify}}checked{{end}}>
  55. </div>
  56. </div>
  57. {{if .Source.IsLDAP}}
  58. <div class="field">
  59. <label for="bind_dn">{{ctx.Locale.Tr "admin.auths.bind_dn"}}</label>
  60. <input id="bind_dn" name="bind_dn" value="{{$cfg.BindDN}}" placeholder="cn=Search,dc=mydomain,dc=com">
  61. </div>
  62. <div class="field">
  63. <label for="bind_password">{{ctx.Locale.Tr "admin.auths.bind_password"}}</label>
  64. <input id="bind_password" name="bind_password" type="password" value="{{$cfg.BindPassword}}">
  65. </div>
  66. {{end}}
  67. <div class="{{if .Source.IsLDAP}}required{{end}} field">
  68. <label for="user_base">{{ctx.Locale.Tr "admin.auths.user_base"}}</label>
  69. <input id="user_base" name="user_base" value="{{$cfg.UserBase}}" placeholder="ou=Users,dc=mydomain,dc=com" {{if .Source.IsLDAP}}required{{end}}>
  70. </div>
  71. {{if .Source.IsDLDAP}}
  72. <div class="required field">
  73. <label for="user_dn">{{ctx.Locale.Tr "admin.auths.user_dn"}}</label>
  74. <input id="user_dn" name="user_dn" value="{{$cfg.UserDN}}" placeholder="uid=%s,ou=Users,dc=mydomain,dc=com" required>
  75. </div>
  76. {{end}}
  77. <div class="required field">
  78. <label for="filter">{{ctx.Locale.Tr "admin.auths.filter"}}</label>
  79. <input id="filter" name="filter" value="{{$cfg.Filter}}" placeholder="(&(objectClass=posixAccount)(|(uid=%[1]s)(mail=%[1]s)))" required>
  80. </div>
  81. <div class="field">
  82. <label for="admin_filter">{{ctx.Locale.Tr "admin.auths.admin_filter"}}</label>
  83. <input id="admin_filter" name="admin_filter" value="{{$cfg.AdminFilter}}">
  84. </div>
  85. <div class="field">
  86. <label for="restricted_filter">{{ctx.Locale.Tr "admin.auths.restricted_filter"}}</label>
  87. <input id="restricted_filter" name="restricted_filter" value="{{$cfg.RestrictedFilter}}">
  88. <p class="help">{{ctx.Locale.Tr "admin.auths.restricted_filter_helper"}}</p>
  89. </div>
  90. <div class="field">
  91. <label for="attribute_username">{{ctx.Locale.Tr "admin.auths.attribute_username"}}</label>
  92. <input id="attribute_username" name="attribute_username" value="{{$cfg.AttributeUsername}}" placeholder="{{ctx.Locale.Tr "admin.auths.attribute_username_placeholder"}}">
  93. </div>
  94. <div class="field">
  95. <label for="attribute_name">{{ctx.Locale.Tr "admin.auths.attribute_name"}}</label>
  96. <input id="attribute_name" name="attribute_name" value="{{$cfg.AttributeName}}">
  97. </div>
  98. <div class="field">
  99. <label for="attribute_surname">{{ctx.Locale.Tr "admin.auths.attribute_surname"}}</label>
  100. <input id="attribute_surname" name="attribute_surname" value="{{$cfg.AttributeSurname}}">
  101. </div>
  102. <div class="required field">
  103. <label for="attribute_mail">{{ctx.Locale.Tr "admin.auths.attribute_mail"}}</label>
  104. <input id="attribute_mail" name="attribute_mail" value="{{$cfg.AttributeMail}}" placeholder="mail" required>
  105. </div>
  106. <div class="field">
  107. <label for="attribute_ssh_public_key">{{ctx.Locale.Tr "admin.auths.attribute_ssh_public_key"}}</label>
  108. <input id="attribute_ssh_public_key" name="attribute_ssh_public_key" value="{{$cfg.AttributeSSHPublicKey}}" placeholder="SshPublicKey">
  109. </div>
  110. <div class="field">
  111. <label for="attribute_avatar">{{ctx.Locale.Tr "admin.auths.attribute_avatar"}}</label>
  112. <input id="attribute_avatar" name="attribute_avatar" value="{{$cfg.AttributeAvatar}}" placeholder="jpegPhoto">
  113. </div>
  114. <!-- ldap group begin -->
  115. <div class="inline field">
  116. <div class="ui checkbox">
  117. <label><strong>{{ctx.Locale.Tr "admin.auths.enable_ldap_groups"}}</strong></label>
  118. <input type="checkbox" name="groups_enabled" class="js-ldap-group-toggle" {{if $cfg.GroupsEnabled}}checked{{end}}>
  119. </div>
  120. </div>
  121. <div id="ldap-group-options" class="ui segment secondary {{if not $cfg.GroupsEnabled}}tw-hidden{{end}}">
  122. <div class="field">
  123. <label>{{ctx.Locale.Tr "admin.auths.group_search_base"}}</label>
  124. <input name="group_dn" value="{{$cfg.GroupDN}}" placeholder="ou=group,dc=mydomain,dc=com">
  125. </div>
  126. <div class="field">
  127. <label>{{ctx.Locale.Tr "admin.auths.group_attribute_list_users"}}</label>
  128. <input name="group_member_uid" value="{{$cfg.GroupMemberUID}}" placeholder="memberUid">
  129. </div>
  130. <div class="field">
  131. <label>{{ctx.Locale.Tr "admin.auths.user_attribute_in_group"}}</label>
  132. <input name="user_uid" value="{{$cfg.UserUID}}" placeholder="uid">
  133. </div>
  134. <div class="field">
  135. <label>{{ctx.Locale.Tr "admin.auths.verify_group_membership"}}</label>
  136. <input name="group_filter" value="{{$cfg.GroupFilter}}" placeholder="(|(cn=gitea_users)(cn=admins))">
  137. </div>
  138. <div class="field">
  139. <label>{{ctx.Locale.Tr "admin.auths.map_group_to_team"}}</label>
  140. <textarea name="group_team_map" rows="5" placeholder='{"cn=my-group,cn=groups,dc=example,dc=org": {"MyGiteaOrganization": ["MyGiteaTeam1", "MyGiteaTeam2"]}}'>{{$cfg.GroupTeamMap}}</textarea>
  141. </div>
  142. <div class="ui checkbox">
  143. <label>{{ctx.Locale.Tr "admin.auths.map_group_to_team_removal"}}</label>
  144. <input name="group_team_map_removal" type="checkbox" {{if $cfg.GroupTeamMapRemoval}}checked{{end}}>
  145. </div>
  146. </div>
  147. <!-- ldap group end -->
  148. {{if .Source.IsLDAP}}
  149. <div class="inline field">
  150. <div class="ui checkbox">
  151. <label for="use_paged_search"><strong>{{ctx.Locale.Tr "admin.auths.use_paged_search"}}</strong></label>
  152. <input id="use_paged_search" name="use_paged_search" type="checkbox" {{if $cfg.UsePagedSearch}}checked{{end}}>
  153. </div>
  154. </div>
  155. <div class="field required search-page-size{{if not $cfg.UsePagedSearch}} tw-hidden{{end}}">
  156. <label for="search_page_size">{{ctx.Locale.Tr "admin.auths.search_page_size"}}</label>
  157. <input id="search_page_size" name="search_page_size" value="{{if $cfg.UsePagedSearch}}{{$cfg.SearchPageSize}}{{end}}">
  158. </div>
  159. <div class="inline field">
  160. <div class="ui checkbox">
  161. <label><strong>{{ctx.Locale.Tr "admin.auths.attributes_in_bind"}}</strong></label>
  162. <input name="attributes_in_bind" type="checkbox" {{if $cfg.AttributesInBind}}checked{{end}}>
  163. </div>
  164. </div>
  165. {{end}}
  166. <div class="inline field">
  167. <div class="ui checkbox">
  168. <label for="allow_deactivate_all"><strong>{{ctx.Locale.Tr "admin.auths.allow_deactivate_all"}}</strong></label>
  169. <input id="allow_deactivate_all" name="allow_deactivate_all" type="checkbox" {{if $cfg.AllowDeactivateAll}}checked{{end}}>
  170. </div>
  171. </div>
  172. {{end}}
  173. <!-- SMTP -->
  174. {{if .Source.IsSMTP}}
  175. {{$cfg:=.Source.Cfg}}
  176. <div class="inline required field">
  177. <label>{{ctx.Locale.Tr "admin.auths.smtp_auth"}}</label>
  178. <div class="ui selection type dropdown">
  179. <input type="hidden" id="smtp_auth" name="smtp_auth" value="{{$cfg.Auth}}" required>
  180. <div class="text">{{$cfg.Auth}}</div>
  181. {{svg "octicon-triangle-down" 14 "dropdown icon"}}
  182. <div class="menu">
  183. {{range .SMTPAuths}}
  184. <div class="item" data-value="{{.}}">{{.}}</div>
  185. {{end}}
  186. </div>
  187. </div>
  188. </div>
  189. <div class="required field">
  190. <label for="smtp_host">{{ctx.Locale.Tr "admin.auths.smtphost"}}</label>
  191. <input id="smtp_host" name="smtp_host" value="{{$cfg.Host}}" required>
  192. </div>
  193. <div class="required field">
  194. <label for="smtp_port">{{ctx.Locale.Tr "admin.auths.smtpport"}}</label>
  195. <input id="smtp_port" name="smtp_port" value="{{$cfg.Port}}" required>
  196. </div>
  197. <div class="field">
  198. <div class="ui checkbox">
  199. <label for="force_smtps"><strong>{{ctx.Locale.Tr "admin.auths.force_smtps"}}</strong></label>
  200. <input id="force_smtps" name="force_smtps" type="checkbox" {{if $cfg.ForceSMTPS}}checked{{end}}>
  201. </div>
  202. <p class="help">{{ctx.Locale.Tr "admin.auths.force_smtps_helper"}}</p>
  203. </div>
  204. <div class="has-tls inline field {{if not .HasTLS}}tw-hidden{{end}}">
  205. <div class="ui checkbox">
  206. <label><strong>{{ctx.Locale.Tr "admin.auths.skip_tls_verify"}}</strong></label>
  207. <input name="skip_verify" type="checkbox" {{if $cfg.SkipVerify}}checked{{end}}>
  208. </div>
  209. </div>
  210. <div class="field">
  211. <label for="helo_hostname">{{ctx.Locale.Tr "admin.auths.helo_hostname"}}</label>
  212. <input id="helo_hostname" name="helo_hostname" value="{{$cfg.HeloHostname}}">
  213. <p class="help">{{ctx.Locale.Tr "admin.auths.helo_hostname_helper"}}</p>
  214. </div>
  215. <div class="inline field">
  216. <div class="ui checkbox">
  217. <label for="disable_helo"><strong>{{ctx.Locale.Tr "admin.auths.disable_helo"}}</strong></label>
  218. <input id="disable_helo" name="disable_helo" type="checkbox" {{if $cfg.DisableHelo}}checked{{end}}>
  219. </div>
  220. </div>
  221. <div class="field">
  222. <label for="allowed_domains">{{ctx.Locale.Tr "admin.auths.allowed_domains"}}</label>
  223. <input id="allowed_domains" name="allowed_domains" value="{{$cfg.AllowedDomains}}">
  224. <p class="help">{{ctx.Locale.Tr "admin.auths.allowed_domains_helper"}}</p>
  225. </div>
  226. {{end}}
  227. <!-- PAM -->
  228. {{if .Source.IsPAM}}
  229. {{$cfg:=.Source.Cfg}}
  230. <div class="required field">
  231. <label for="pam_service_name">{{ctx.Locale.Tr "admin.auths.pam_service_name"}}</label>
  232. <input id="pam_service_name" name="pam_service_name" value="{{$cfg.ServiceName}}" required>
  233. </div>
  234. <div class="field">
  235. <label for="pam_email_domain">{{ctx.Locale.Tr "admin.auths.pam_email_domain"}}</label>
  236. <input id="pam_email_domain" name="pam_email_domain" value="{{$cfg.EmailDomain}}">
  237. </div>
  238. {{end}}
  239. <!-- OAuth2 -->
  240. {{if .Source.IsOAuth2}}
  241. {{$cfg:=.Source.Cfg}}
  242. <div class="inline required field">
  243. <label>{{ctx.Locale.Tr "admin.auths.oauth2_provider"}}</label>
  244. <div class="ui selection type dropdown">
  245. <input type="hidden" id="oauth2_provider" name="oauth2_provider" value="{{$cfg.Provider}}" required>
  246. <div class="text">{{.CurrentOAuth2Provider.DisplayName}}</div>
  247. {{svg "octicon-triangle-down" 14 "dropdown icon"}}
  248. <div class="menu">
  249. {{range .OAuth2Providers}}
  250. <div class="item" data-value="{{.Name}}">{{.DisplayName}}</div>
  251. {{end}}
  252. </div>
  253. </div>
  254. </div>
  255. <div class="required field">
  256. <label for="oauth2_key">{{ctx.Locale.Tr "admin.auths.oauth2_clientID"}}</label>
  257. <input id="oauth2_key" name="oauth2_key" value="{{$cfg.ClientID}}" required>
  258. </div>
  259. <div class="required field">
  260. <label for="oauth2_secret">{{ctx.Locale.Tr "admin.auths.oauth2_clientSecret"}}</label>
  261. <input id="oauth2_secret" name="oauth2_secret" value="{{$cfg.ClientSecret}}" required>
  262. </div>
  263. <div class="optional field">
  264. <label for="oauth2_icon_url">{{ctx.Locale.Tr "admin.auths.oauth2_icon_url"}}</label>
  265. <input id="oauth2_icon_url" name="oauth2_icon_url" value="{{$cfg.IconURL}}">
  266. </div>
  267. <div class="open_id_connect_auto_discovery_url required field">
  268. <label for="open_id_connect_auto_discovery_url">{{ctx.Locale.Tr "admin.auths.openIdConnectAutoDiscoveryURL"}}</label>
  269. <input id="open_id_connect_auto_discovery_url" name="open_id_connect_auto_discovery_url" value="{{$cfg.OpenIDConnectAutoDiscoveryURL}}">
  270. </div>
  271. <div class="oauth2_use_custom_url inline field">
  272. <div class="ui checkbox">
  273. <label><strong>{{ctx.Locale.Tr "admin.auths.oauth2_use_custom_url"}}</strong></label>
  274. <input id="oauth2_use_custom_url" name="oauth2_use_custom_url" type="checkbox" {{if $cfg.CustomURLMapping}}checked{{end}}>
  275. </div>
  276. </div>
  277. <div class="oauth2_use_custom_url_field oauth2_auth_url required field">
  278. <label for="oauth2_auth_url">{{ctx.Locale.Tr "admin.auths.oauth2_authURL"}}</label>
  279. <input id="oauth2_auth_url" name="oauth2_auth_url" value="{{if $cfg.CustomURLMapping}}{{$cfg.CustomURLMapping.AuthURL}}{{end}}">
  280. </div>
  281. <div class="oauth2_use_custom_url_field oauth2_token_url required field">
  282. <label for="oauth2_token_url">{{ctx.Locale.Tr "admin.auths.oauth2_tokenURL"}}</label>
  283. <input id="oauth2_token_url" name="oauth2_token_url" value="{{if $cfg.CustomURLMapping}}{{$cfg.CustomURLMapping.TokenURL}}{{end}}">
  284. </div>
  285. <div class="oauth2_use_custom_url_field oauth2_profile_url required field">
  286. <label for="oauth2_profile_url">{{ctx.Locale.Tr "admin.auths.oauth2_profileURL"}}</label>
  287. <input id="oauth2_profile_url" name="oauth2_profile_url" value="{{if $cfg.CustomURLMapping}}{{$cfg.CustomURLMapping.ProfileURL}}{{end}}">
  288. </div>
  289. <div class="oauth2_use_custom_url_field oauth2_email_url required field">
  290. <label for="oauth2_email_url">{{ctx.Locale.Tr "admin.auths.oauth2_emailURL"}}</label>
  291. <input id="oauth2_email_url" name="oauth2_email_url" value="{{if $cfg.CustomURLMapping}}{{$cfg.CustomURLMapping.EmailURL}}{{end}}">
  292. </div>
  293. <div class="oauth2_use_custom_url_field oauth2_tenant required field">
  294. <label for="oauth2_tenant">{{ctx.Locale.Tr "admin.auths.oauth2_tenant"}}</label>
  295. <input id="oauth2_tenant" name="oauth2_tenant" value="{{if $cfg.CustomURLMapping}}{{$cfg.CustomURLMapping.Tenant}}{{end}}">
  296. </div>
  297. {{range .OAuth2Providers}}
  298. <input id="{{.Name}}_SupportSSHPublicKey" value="{{.SupportSSHPublicKey}}" type="hidden">
  299. {{if .CustomURLSettings}}
  300. <input id="{{.Name}}_customURLSettings" type="hidden" data-required="{{.CustomURLSettings.Required}}" data-available="true">
  301. <input id="{{.Name}}_token_url" value="{{.CustomURLSettings.TokenURL.Value}}" data-available="{{.CustomURLSettings.TokenURL.Available}}" data-required="{{.CustomURLSettings.TokenURL.Required}}" type="hidden">
  302. <input id="{{.Name}}_auth_url" value="{{.CustomURLSettings.AuthURL.Value}}" data-available="{{.CustomURLSettings.AuthURL.Available}}" data-required="{{.CustomURLSettings.AuthURL.Required}}" type="hidden">
  303. <input id="{{.Name}}_profile_url" value="{{.CustomURLSettings.ProfileURL.Value}}" data-available="{{.CustomURLSettings.ProfileURL.Available}}" data-required="{{.CustomURLSettings.ProfileURL.Required}}" type="hidden">
  304. <input id="{{.Name}}_email_url" value="{{.CustomURLSettings.EmailURL.Value}}" data-available="{{.CustomURLSettings.EmailURL.Available}}" data-required="{{.CustomURLSettings.EmailURL.Required}}" type="hidden">
  305. <input id="{{.Name}}_tenant" value="{{.CustomURLSettings.Tenant.Value}}" data-available="{{.CustomURLSettings.Tenant.Available}}" data-required="{{.CustomURLSettings.Tenant.Required}}" type="hidden">
  306. {{end}}
  307. {{end}}
  308. <div class="field">
  309. <label for="oauth2_scopes">{{ctx.Locale.Tr "admin.auths.oauth2_scopes"}}</label>
  310. <input id="oauth2_scopes" name="oauth2_scopes" value="{{if $cfg.Scopes}}{{StringUtils.Join $cfg.Scopes ","}}{{end}}">
  311. </div>
  312. <div class="field">
  313. <label>{{ctx.Locale.Tr "admin.auths.oauth2_full_name_claim_name"}}</label>
  314. <input name="oauth2_full_name_claim_name" value="{{$cfg.FullNameClaimName}}" placeholder="name">
  315. </div>
  316. <div class="field oauth2_ssh_public_key_claim_name">
  317. <label>{{ctx.Locale.Tr "admin.auths.oauth2_ssh_public_key_claim_name"}}</label>
  318. <input name="oauth2_ssh_public_key_claim_name" value="{{$cfg.SSHPublicKeyClaimName}}" placeholder="sshpubkey">
  319. </div>
  320. <div class="field">
  321. <label for="oauth2_required_claim_name">{{ctx.Locale.Tr "admin.auths.oauth2_required_claim_name"}}</label>
  322. <input id="oauth2_required_claim_name" name="oauth2_required_claim_name" value="{{$cfg.RequiredClaimName}}">
  323. <p class="help">{{ctx.Locale.Tr "admin.auths.oauth2_required_claim_name_helper"}}</p>
  324. </div>
  325. <div class="field">
  326. <label for="oauth2_required_claim_value">{{ctx.Locale.Tr "admin.auths.oauth2_required_claim_value"}}</label>
  327. <input id="oauth2_required_claim_value" name="oauth2_required_claim_value" value="{{$cfg.RequiredClaimValue}}">
  328. <p class="help">{{ctx.Locale.Tr "admin.auths.oauth2_required_claim_value_helper"}}</p>
  329. </div>
  330. <div class="field">
  331. <label for="oauth2_group_claim_name">{{ctx.Locale.Tr "admin.auths.oauth2_group_claim_name"}}</label>
  332. <input id="oauth2_group_claim_name" name="oauth2_group_claim_name" value="{{$cfg.GroupClaimName}}">
  333. </div>
  334. <div class="field">
  335. <label for="oauth2_admin_group">{{ctx.Locale.Tr "admin.auths.oauth2_admin_group"}}</label>
  336. <input id="oauth2_admin_group" name="oauth2_admin_group" value="{{$cfg.AdminGroup}}">
  337. </div>
  338. <div class="field">
  339. <label for="oauth2_restricted_group">{{ctx.Locale.Tr "admin.auths.oauth2_restricted_group"}}</label>
  340. <input id="oauth2_restricted_group" name="oauth2_restricted_group" value="{{$cfg.RestrictedGroup}}">
  341. </div>
  342. <div class="field">
  343. <label>{{ctx.Locale.Tr "admin.auths.oauth2_map_group_to_team"}}</label>
  344. <textarea name="oauth2_group_team_map" rows="5" placeholder='{"Developer": {"MyGiteaOrganization": ["MyGiteaTeam1", "MyGiteaTeam2"]}}'>{{$cfg.GroupTeamMap}}</textarea>
  345. </div>
  346. <div class="ui checkbox">
  347. <label>{{ctx.Locale.Tr "admin.auths.oauth2_map_group_to_team_removal"}}</label>
  348. <input name="oauth2_group_team_map_removal" type="checkbox" {{if $cfg.GroupTeamMapRemoval}}checked{{end}}>
  349. </div>
  350. {{end}}
  351. <!-- SSPI -->
  352. {{if .Source.IsSSPI}}
  353. {{$cfg:=.Source.Cfg}}
  354. <div class="field">
  355. <div class="ui checkbox">
  356. <label for="sspi_auto_create_users"><strong>{{ctx.Locale.Tr "admin.auths.sspi_auto_create_users"}}</strong></label>
  357. <input id="sspi_auto_create_users" name="sspi_auto_create_users" class="sspi-auto-create-users" type="checkbox" {{if $cfg.AutoCreateUsers}}checked{{end}}>
  358. <p class="help">{{ctx.Locale.Tr "admin.auths.sspi_auto_create_users_helper"}}</p>
  359. </div>
  360. </div>
  361. <div class="field">
  362. <div class="ui checkbox">
  363. <label for="sspi_auto_activate_users"><strong>{{ctx.Locale.Tr "admin.auths.sspi_auto_activate_users"}}</strong></label>
  364. <input id="sspi_auto_activate_users" name="sspi_auto_activate_users" class="sspi-auto-activate-users" type="checkbox" {{if $cfg.AutoActivateUsers}}checked{{end}}>
  365. <p class="help">{{ctx.Locale.Tr "admin.auths.sspi_auto_activate_users_helper"}}</p>
  366. </div>
  367. </div>
  368. <div class="field">
  369. <div class="ui checkbox">
  370. <label for="sspi_strip_domain_names"><strong>{{ctx.Locale.Tr "admin.auths.sspi_strip_domain_names"}}</strong></label>
  371. <input id="sspi_strip_domain_names" name="sspi_strip_domain_names" class="sspi-strip-domain-names" type="checkbox" {{if $cfg.StripDomainNames}}checked{{end}}>
  372. <p class="help">{{ctx.Locale.Tr "admin.auths.sspi_strip_domain_names_helper"}}</p>
  373. </div>
  374. </div>
  375. <div class="required field">
  376. <label for="sspi_separator_replacement">{{ctx.Locale.Tr "admin.auths.sspi_separator_replacement"}}</label>
  377. <input id="sspi_separator_replacement" name="sspi_separator_replacement" value="{{$cfg.SeparatorReplacement}}" required>
  378. <p class="help">{{ctx.Locale.Tr "admin.auths.sspi_separator_replacement_helper"}}</p>
  379. </div>
  380. <div class="field">
  381. <label for="sspi_default_language">{{ctx.Locale.Tr "admin.auths.sspi_default_language"}}</label>
  382. <div class="ui language selection dropdown" id="sspi_default_language">
  383. <input name="sspi_default_language" type="hidden" value="{{$cfg.DefaultLanguage}}">
  384. {{svg "octicon-triangle-down" 14 "dropdown icon"}}
  385. <div class="text">{{range .AllLangs}}{{if eq $cfg.DefaultLanguage .Lang}}{{.Name}}{{end}}{{end}}</div>
  386. <div class="menu">
  387. <div class="item{{if not $.SSPIDefaultLanguage}} active selected{{end}}" data-value="">-</div>
  388. {{range .AllLangs}}
  389. <div class="item{{if eq $cfg.DefaultLanguage .Lang}} active selected{{end}}" data-value="{{.Lang}}">{{.Name}}</div>
  390. {{end}}
  391. </div>
  392. </div>
  393. <p class="help">{{ctx.Locale.Tr "admin.auths.sspi_default_language_helper"}}</p>
  394. </div>
  395. {{end}}
  396. {{if (or .Source.IsLDAP .Source.IsOAuth2)}}
  397. <div class="inline field">
  398. <div class="ui checkbox">
  399. <label><strong>{{ctx.Locale.Tr "admin.auths.syncenabled"}}</strong></label>
  400. <input name="is_sync_enabled" type="checkbox" {{if .Source.IsSyncEnabled}}checked{{end}}>
  401. </div>
  402. </div>
  403. {{end}}
  404. <div class="inline field">
  405. <div class="ui checkbox">
  406. <label><strong>{{ctx.Locale.Tr "admin.auths.activated"}}</strong></label>
  407. <input name="is_active" type="checkbox" {{if .Source.IsActive}}checked{{end}}>
  408. </div>
  409. </div>
  410. <div class="field">
  411. <button class="ui primary button">{{ctx.Locale.Tr "admin.auths.update"}}</button>
  412. <button class="ui red button link-action" data-url="{{$.Link}}/delete?id={{.Source.ID}}"
  413. data-modal-confirm-header="{{ctx.Locale.Tr "admin.auths.delete_auth_title"}}"
  414. data-modal-confirm-content="{{ctx.Locale.Tr "admin.auths.delete_auth_desc"}}"
  415. >{{ctx.Locale.Tr "admin.auths.delete"}}</button>
  416. </div>
  417. </form>
  418. </div>
  419. <h4 class="ui top attached header">
  420. {{ctx.Locale.Tr "admin.auths.tips"}}
  421. </h4>
  422. <div class="ui attached segment">
  423. <h5>GMail Settings:</h5>
  424. <p>Host: smtp.gmail.com, Port: 587, Enable TLS Encryption: true</p>
  425. <h5 class="oauth2">{{ctx.Locale.Tr "admin.auths.tips.oauth2.general"}}:</h5>
  426. <p class="oauth2">{{ctx.Locale.Tr "admin.auths.tips.oauth2.general.tip"}} <b id="oauth2-callback-url"></b></p>
  427. </div>
  428. </div>
  429. {{template "admin/layout_footer" .}}