| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202 | {{template "base/head" .}}<div class="admin new authentication">	<div class="ui container">		<div class="ui grid">			{{template "admin/navbar" .}}			<div class="twelve wide column content">				{{template "base/alert" .}}				<h4 class="ui top attached header">					{{.i18n.Tr "admin.auths.new"}}				</h4>				<div class="ui attached segment">					<form class="ui form" action="{{.Link}}" method="post">						{{.CSRFTokenHTML}}						<!-- Types and name -->						<div class="inline required field {{if .Err_Type}}error{{end}}">							<label>{{.i18n.Tr "admin.auths.auth_type"}}</label>							<div class="ui selection type dropdown">								<input type="hidden" id="auth_type" name="type" value="{{.type}}">								<div class="text">{{.CurrentTypeName}}</div>								<i class="dropdown icon"></i>								<div class="menu">									{{range .AuthSources}}										<div class="item" data-value="{{.Type}}">{{.Name}}</div>									{{end}}								</div>							</div>						</div>						<div class="required inline field {{if .Err_Name}}error{{end}}">							<label for="name">{{.i18n.Tr "admin.auths.auth_name"}}</label>							<input id="name" name="name" value="{{.name}}" autofocus required>						</div>						<!-- LDAP and DLDAP -->						<div class="ldap dldap field {{if not (or (eq .type 2) (eq .type 5))}}hide{{end}}">							<div class="inline required field {{if .Err_SecurityProtocol}}error{{end}}">								<label>{{.i18n.Tr "admin.auths.security_protocol"}}</label>								<div class="ui selection security-protocol dropdown">									<input type="hidden" id="security_protocol" name="security_protocol" value="{{.security_protocol}}">									<div class="text">{{.CurrentSecurityProtocol}}</div>									<i class="dropdown icon"></i>									<div class="menu">										{{range .SecurityProtocols}}											<div class="item" data-value="{{.Type}}">{{.Name}}</div>										{{end}}									</div>								</div>							</div>							<div class="required field">								<label for="host">{{.i18n.Tr "admin.auths.host"}}</label>								<input id="host" name="host" value="{{.host}}" placeholder="e.g. mydomain.com">							</div>							<div class="required field">								<label for="port">{{.i18n.Tr "admin.auths.port"}}</label>								<input id="port" name="port" value="{{.port}}"  placeholder="e.g. 636">							</div>							<div class="ldap field {{if not (eq .type 2)}}hide{{end}}">								<label for="bind_dn">{{.i18n.Tr "admin.auths.bind_dn"}}</label>								<input id="bind_dn" name="bind_dn" value="{{.bind_dn}}" placeholder="e.g. cn=Search,dc=mydomain,dc=com">							</div>							<div class="ldap field {{if not (eq .type 2)}}hide{{end}}">								<label for="bind_password">{{.i18n.Tr "admin.auths.bind_password"}}</label>								<input id="bind_password" name="bind_password" type="password" value="{{.bind_password}}">								<p class="help text red">{{.i18n.Tr "admin.auths.bind_password_helper"}}</p>							</div>							<div class="ldap required field {{if not (eq .type 2)}}hide{{end}}">								<label for="user_base">{{.i18n.Tr "admin.auths.user_base"}}</label>								<input id="user_base" name="user_base" value="{{.user_base}}" placeholder="e.g. ou=Users,dc=mydomain,dc=com">							</div>							<div class="dldap required field {{if not (eq .type 5)}}hide{{end}}">								<label for="user_dn">{{.i18n.Tr "admin.auths.user_dn"}}</label>								<input id="user_dn" name="user_dn" value="{{.user_dn}}" placeholder="e.g. uid=%s,ou=Users,dc=mydomain,dc=com">							</div>							<div class="required field">								<label for="filter">{{.i18n.Tr "admin.auths.filter"}}</label>								<input id="filter" name="filter" value="{{.filter}}" placeholder="e.g. (&(objectClass=posixAccount)(uid=%s))">							</div>							<div class="field">								<label for="admin_filter">{{.i18n.Tr "admin.auths.admin_filter"}}</label>								<input id="admin_filter" name="admin_filter" value="{{.admin_filter}}">							</div>							<div class="field">								<label for="attribute_username">{{.i18n.Tr "admin.auths.attribute_username"}}</label>								<input id="attribute_username" name="attribute_username" value="{{.attribute_username}}" placeholder="{{.i18n.Tr "admin.auths.attribute_username_placeholder"}}">							</div>							<div class="field">								<label for="attribute_name">{{.i18n.Tr "admin.auths.attribute_name"}}</label>								<input id="attribute_name" name="attribute_name" value="{{.attribute_name}}">							</div>							<div class="field">								<label for="attribute_surname">{{.i18n.Tr "admin.auths.attribute_surname"}}</label>								<input id="attribute_surname" name="attribute_surname" value="{{.attribute_surname}}">							</div>							<div class="required field">								<label for="attribute_mail">{{.i18n.Tr "admin.auths.attribute_mail"}}</label>								<input id="attribute_mail" name="attribute_mail" value="{{.attribute_mail}}" placeholder="e.g. mail">							</div>														<div class="inline field">								<div class="ui checkbox">									<label><strong>{{.i18n.Tr "admin.auths.verify_group_membership"}}</strong></label>									<input class="enable-system" type="checkbox" name="group_enabled" data-target="#group_box" {{if .group_enabled}}checked{{end}}>								</div>							</div>							<div class="ui segment field {{if not .group_enabled}}disabled{{end}}" id="group_box">								<div class="field">									<label for="group_dn">{{.i18n.Tr "admin.auths.group_search_base_dn"}}</label>									<input id="group_dn" name="group_dn" value="{{.group_dn}}" placeholder="e.g. ou=group,dc=mydomain,dc=com">								</div>								<div class="field">									<label for="group_filter">{{.i18n.Tr "admin.auths.group_filter"}}</label>									<input id="group_filter" name="group_filter" value="{{.group_filter}}" placeholder="e.g. (|(cn=gogs_users)(cn=admins))">								</div>								<div class="field">									<label for="group_member_uid">{{.i18n.Tr "admin.auths.group_attribute_contain_user_list"}}</label>									<input id="group_member_uid" name="group_member_uid" value="{{.group_member_uid}}" placeholder="e.g. memberUid">								</div>								<div class="field">									<label for="user_uid">{{.i18n.Tr "admin.auths.user_attribute_listed_in_group"}}</label>									<input id="user_uid" name="user_uid" value="{{.user_uid}}" placeholder="e.g. uid">								</div>							</div>						</div>						<!-- SMTP -->						<div class="smtp field {{if not (eq .type 3)}}hide{{end}}">							<div class="inline required field">								<label>{{.i18n.Tr "admin.auths.smtp_auth"}}</label>								<div class="ui selection type dropdown">									<input type="hidden" id="smtp_auth" name="smtp_auth" value="{{.smtp_auth}}">									<div class="text">{{.smtp_auth}}</div>									<i class="dropdown icon"></i>									<div class="menu">										{{range .SMTPAuths}}											<div class="item" data-value="{{.}}">{{.}}</div>										{{end}}									</div>								</div>							</div>							<div class="required field">								<label for="smtp_host">{{.i18n.Tr "admin.auths.smtphost"}}</label>								<input id="smtp_host" name="smtp_host" value="{{.smtp_host}}">							</div>							<div class="required field">								<label for="smtp_port">{{.i18n.Tr "admin.auths.smtpport"}}</label>								<input id="smtp_port" name="smtp_port" value="{{.smtp_port}}">							</div>							<div class="field">								<label for="allowed_domains">{{.i18n.Tr "admin.auths.allowed_domains"}}</label>								<input id="allowed_domains" name="allowed_domains" value="{{.allowed_domains}}">								<p class="help">{{.i18n.Tr "admin.auths.allowed_domains_helper"}}</p>							</div>						</div>						<!-- PAM -->						<div class="pam required field {{if not (eq .type 4)}}hide{{end}}">							<label for="pam_service_name">{{.i18n.Tr "admin.auths.pam_service_name"}}</label>							<input id="pam_service_name" name="pam_service_name" value="{{.pam_service_name}}" />						</div>						<div class="ldap field">							<div class="ui checkbox">								<label><strong>{{.i18n.Tr "admin.auths.attributes_in_bind"}}</strong></label>								<input name="attributes_in_bind" type="checkbox" {{if .attributes_in_bind}}checked{{end}}>							</div>						</div>						<div class="smtp inline field {{if not (eq .type 3)}}hide{{end}}">							<div class="ui checkbox">								<label><strong>{{.i18n.Tr "admin.auths.enable_tls"}}</strong></label>								<input name="tls" type="checkbox" {{if .tls}}checked{{end}}>							</div>						</div>						<div class="has-tls inline field {{if not .HasTLS}}hide{{end}}">							<div class="ui checkbox">								<label><strong>{{.i18n.Tr "admin.auths.skip_tls_verify"}}</strong></label>								<input name="skip_verify" type="checkbox" {{if .skip_verify}}checked{{end}}>							</div>						</div>						<div class="inline field">							<div class="ui checkbox">								<label><strong>{{.i18n.Tr "admin.auths.activated"}}</strong></label>								<input name="is_active" type="checkbox" {{if .is_active}}checked{{end}}>							</div>						</div>						<div class="field">							<button class="ui green button">{{.i18n.Tr "admin.auths.new"}}</button>						</div>					</form>				</div>				<h4 class="ui top attached header">					{{.i18n.Tr "admin.auths.tips"}}				</h4>				<div class="ui attached segment">					<h5>GMail Settings:</h5>					<p>Host: smtp.gmail.com, Port: 587, Enable TLS Encryption: true</p>				</div>			</div>		</div>	</div></div>{{template "base/footer" .}}
 |