mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-25 03:57:13 +08:00 
			
		
		
		
	EnableUnit() -> UnitEnabled() (#2242)
This commit is contained in:
		| @ -192,8 +192,8 @@ func (t *Team) RemoveRepository(repoID int64) error { | |||||||
| 	return sess.Commit() | 	return sess.Commit() | ||||||
| } | } | ||||||
|  |  | ||||||
| // EnableUnit returns if the team enables unit type t | // UnitEnabled returns if the team has the given unit type enabled | ||||||
| func (t *Team) EnableUnit(tp UnitType) bool { | func (t *Team) UnitEnabled(tp UnitType) bool { | ||||||
| 	if len(t.UnitTypes) == 0 { | 	if len(t.UnitTypes) == 0 { | ||||||
| 		return true | 		return true | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -398,8 +398,8 @@ func (repo *Repository) getUnitsByUserID(e Engine, userID int64, isAdmin bool) ( | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
| // EnableUnit if this repository enabled some unit | // UnitEnabled if this repository has the given unit enabled | ||||||
| func (repo *Repository) EnableUnit(tp UnitType) bool { | func (repo *Repository) UnitEnabled(tp UnitType) bool { | ||||||
| 	repo.getUnits(x) | 	repo.getUnits(x) | ||||||
| 	for _, unit := range repo.Units { | 	for _, unit := range repo.Units { | ||||||
| 		if unit.Type == tp { | 		if unit.Type == tp { | ||||||
| @ -658,7 +658,7 @@ func (repo *Repository) CanEnablePulls() bool { | |||||||
|  |  | ||||||
| // AllowsPulls returns true if repository meets the requirements of accepting pulls and has them enabled. | // AllowsPulls returns true if repository meets the requirements of accepting pulls and has them enabled. | ||||||
| func (repo *Repository) AllowsPulls() bool { | func (repo *Repository) AllowsPulls() bool { | ||||||
| 	return repo.CanEnablePulls() && repo.EnableUnit(UnitTypePullRequests) | 	return repo.CanEnablePulls() && repo.UnitEnabled(UnitTypePullRequests) | ||||||
| } | } | ||||||
|  |  | ||||||
| // CanEnableEditor returns true if repository meets the requirements of web editor. | // CanEnableEditor returns true if repository meets the requirements of web editor. | ||||||
|  | |||||||
| @ -523,14 +523,7 @@ func LoadRepoUnits() macaron.Handler { | |||||||
| // CheckUnit will check whether | // CheckUnit will check whether | ||||||
| func CheckUnit(unitType models.UnitType) macaron.Handler { | func CheckUnit(unitType models.UnitType) macaron.Handler { | ||||||
| 	return func(ctx *Context) { | 	return func(ctx *Context) { | ||||||
| 		var find bool | 		if !ctx.Repo.Repository.UnitEnabled(unitType) { | ||||||
| 		for _, unit := range ctx.Repo.Repository.Units { |  | ||||||
| 			if unit.Type == unitType { |  | ||||||
| 				find = true |  | ||||||
| 				break |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		if !find { |  | ||||||
| 			ctx.Handle(404, "CheckUnit", fmt.Errorf("%s: %v", ctx.Tr("units.error.unit_not_allowed"), unitType)) | 			ctx.Handle(404, "CheckUnit", fmt.Errorf("%s: %v", ctx.Tr("units.error.unit_not_allowed"), unitType)) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -235,7 +235,7 @@ func orgAssignment(args ...bool) macaron.Handler { | |||||||
| } | } | ||||||
|  |  | ||||||
| func mustEnableIssues(ctx *context.APIContext) { | func mustEnableIssues(ctx *context.APIContext) { | ||||||
| 	if !ctx.Repo.Repository.EnableUnit(models.UnitTypeIssues) { | 	if !ctx.Repo.Repository.UnitEnabled(models.UnitTypeIssues) { | ||||||
| 		ctx.Status(404) | 		ctx.Status(404) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -59,8 +59,8 @@ var ( | |||||||
|  |  | ||||||
| // MustEnableIssues check if repository enable internal issues | // MustEnableIssues check if repository enable internal issues | ||||||
| func MustEnableIssues(ctx *context.Context) { | func MustEnableIssues(ctx *context.Context) { | ||||||
| 	if !ctx.Repo.Repository.EnableUnit(models.UnitTypeIssues) && | 	if !ctx.Repo.Repository.UnitEnabled(models.UnitTypeIssues) && | ||||||
| 		!ctx.Repo.Repository.EnableUnit(models.UnitTypeExternalTracker) { | 		!ctx.Repo.Repository.UnitEnabled(models.UnitTypeExternalTracker) { | ||||||
| 		ctx.Handle(404, "MustEnableIssues", nil) | 		ctx.Handle(404, "MustEnableIssues", nil) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -31,8 +31,8 @@ const ( | |||||||
|  |  | ||||||
| // MustEnableWiki check if wiki is enabled, if external then redirect | // MustEnableWiki check if wiki is enabled, if external then redirect | ||||||
| func MustEnableWiki(ctx *context.Context) { | func MustEnableWiki(ctx *context.Context) { | ||||||
| 	if !ctx.Repo.Repository.EnableUnit(models.UnitTypeWiki) && | 	if !ctx.Repo.Repository.UnitEnabled(models.UnitTypeWiki) && | ||||||
| 		!ctx.Repo.Repository.EnableUnit(models.UnitTypeExternalWiki) { | 		!ctx.Repo.Repository.UnitEnabled(models.UnitTypeExternalWiki) { | ||||||
| 		ctx.Handle(404, "MustEnableWiki", nil) | 		ctx.Handle(404, "MustEnableWiki", nil) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -57,7 +57,7 @@ | |||||||
| 							{{range $t, $unit := $.Units}} | 							{{range $t, $unit := $.Units}} | ||||||
| 							<div class="field"> | 							<div class="field"> | ||||||
| 								<div class="ui toggle checkbox"> | 								<div class="ui toggle checkbox"> | ||||||
| 									<input type="checkbox" class="hidden" name="units" value="{{$unit.Type}}"{{if $.Team.EnableUnit $unit.Type}} checked{{end}}> | 									<input type="checkbox" class="hidden" name="units" value="{{$unit.Type}}"{{if $.Team.UnitEnabled $unit.Type}} checked{{end}}> | ||||||
| 									<label>{{$.i18n.Tr $unit.NameKey}}</label> | 									<label>{{$.i18n.Tr $unit.NameKey}}</label> | ||||||
| 									<span class="help">{{$.i18n.Tr $unit.DescKey}}</span> | 									<span class="help">{{$.i18n.Tr $unit.DescKey}}</span> | ||||||
| 								</div> | 								</div> | ||||||
|  | |||||||
| @ -49,19 +49,19 @@ | |||||||
| {{if not .IsDiffCompare}} | {{if not .IsDiffCompare}} | ||||||
| 	<div class="ui tabs container"> | 	<div class="ui tabs container"> | ||||||
| 		<div class="ui tabular stackable menu navbar"> | 		<div class="ui tabular stackable menu navbar"> | ||||||
| 			{{if .Repository.EnableUnit $.UnitTypeCode}} | 			{{if .Repository.UnitEnabled $.UnitTypeCode}} | ||||||
| 			<a class="{{if .PageIsViewCode}}active{{end}} item" href="{{.RepoLink}}"> | 			<a class="{{if .PageIsViewCode}}active{{end}} item" href="{{.RepoLink}}"> | ||||||
| 				<i class="octicon octicon-code"></i> {{.i18n.Tr "repo.code"}} | 				<i class="octicon octicon-code"></i> {{.i18n.Tr "repo.code"}} | ||||||
| 			</a> | 			</a> | ||||||
| 			{{end}} | 			{{end}} | ||||||
|  |  | ||||||
| 			{{if .Repository.EnableUnit $.UnitTypeIssues}} | 			{{if .Repository.UnitEnabled $.UnitTypeIssues}} | ||||||
| 				<a class="{{if .PageIsIssueList}}active{{end}} item" href="{{.RepoLink}}/issues"> | 				<a class="{{if .PageIsIssueList}}active{{end}} item" href="{{.RepoLink}}/issues"> | ||||||
| 					<i class="octicon octicon-issue-opened"></i> {{.i18n.Tr "repo.issues"}} <span class="ui {{if not .Repository.NumOpenIssues}}gray{{else}}blue{{end}} small label">{{.Repository.NumOpenIssues}}</span> | 					<i class="octicon octicon-issue-opened"></i> {{.i18n.Tr "repo.issues"}} <span class="ui {{if not .Repository.NumOpenIssues}}gray{{else}}blue{{end}} small label">{{.Repository.NumOpenIssues}}</span> | ||||||
| 				</a> | 				</a> | ||||||
| 			{{end}} | 			{{end}} | ||||||
|  |  | ||||||
| 			{{if .Repository.EnableUnit $.UnitTypeExternalTracker}} | 			{{if .Repository.UnitEnabled $.UnitTypeExternalTracker}} | ||||||
| 				<a class="{{if .PageIsIssueList}}active{{end}} item" href="{{.RepoLink}}/issues"> | 				<a class="{{if .PageIsIssueList}}active{{end}} item" href="{{.RepoLink}}/issues"> | ||||||
| 					<i class="octicon octicon-issue-opened"></i> {{.i18n.Tr "repo.issues"}} </span> | 					<i class="octicon octicon-issue-opened"></i> {{.i18n.Tr "repo.issues"}} </span> | ||||||
| 				</a> | 				</a> | ||||||
| @ -73,19 +73,19 @@ | |||||||
| 				</a> | 				</a> | ||||||
| 			{{end}} | 			{{end}} | ||||||
|  |  | ||||||
| 			{{if and (.Repository.EnableUnit $.UnitTypeCode) (not .IsBareRepo)}} | 			{{if and (.Repository.UnitEnabled $.UnitTypeCode) (not .IsBareRepo)}} | ||||||
| 			<a class="{{if (or (.PageIsCommits) (.PageIsDiff))}}active{{end}} item" href="{{.RepoLink}}/commits/{{EscapePound .BranchName}}"> | 			<a class="{{if (or (.PageIsCommits) (.PageIsDiff))}}active{{end}} item" href="{{.RepoLink}}/commits/{{EscapePound .BranchName}}"> | ||||||
| 				<i class="octicon octicon-history"></i> {{.i18n.Tr "repo.commits"}} <span class="ui {{if not .CommitsCount}}gray{{else}}blue{{end}} small label">{{.CommitsCount}}</span> | 				<i class="octicon octicon-history"></i> {{.i18n.Tr "repo.commits"}} <span class="ui {{if not .CommitsCount}}gray{{else}}blue{{end}} small label">{{.CommitsCount}}</span> | ||||||
| 			</a> | 			</a> | ||||||
| 			{{end}} | 			{{end}} | ||||||
|  |  | ||||||
| 			{{if and (.Repository.EnableUnit $.UnitTypeReleases) (not .IsBareRepo) }} | 			{{if and (.Repository.UnitEnabled $.UnitTypeReleases) (not .IsBareRepo) }} | ||||||
| 			<a class="{{if .PageIsReleaseList}}active{{end}} item" href="{{.RepoLink}}/releases"> | 			<a class="{{if .PageIsReleaseList}}active{{end}} item" href="{{.RepoLink}}/releases"> | ||||||
| 				<i class="octicon octicon-tag"></i> {{.i18n.Tr "repo.releases"}} <span class="ui {{if not .Repository.NumTags}}gray{{else}}blue{{end}} small label">{{.Repository.NumTags}}</span> | 				<i class="octicon octicon-tag"></i> {{.i18n.Tr "repo.releases"}} <span class="ui {{if not .Repository.NumTags}}gray{{else}}blue{{end}} small label">{{.Repository.NumTags}}</span> | ||||||
| 			</a> | 			</a> | ||||||
| 			{{end}} | 			{{end}} | ||||||
|  |  | ||||||
| 			{{if or (.Repository.EnableUnit $.UnitTypeWiki) (.Repository.EnableUnit $.UnitTypeExternalWiki)}} | 			{{if or (.Repository.UnitEnabled $.UnitTypeWiki) (.Repository.UnitEnabled $.UnitTypeExternalWiki)}} | ||||||
| 				<a class="{{if .PageIsWiki}}active{{end}} item" href="{{.RepoLink}}/wiki"> | 				<a class="{{if .PageIsWiki}}active{{end}} item" href="{{.RepoLink}}/wiki"> | ||||||
| 					<i class="octicon octicon-book"></i> {{.i18n.Tr "repo.wiki"}} | 					<i class="octicon octicon-book"></i> {{.i18n.Tr "repo.wiki"}} | ||||||
| 				</a> | 				</a> | ||||||
|  | |||||||
| @ -93,7 +93,7 @@ | |||||||
| 				{{.CsrfTokenHtml}} | 				{{.CsrfTokenHtml}} | ||||||
| 				<input type="hidden" name="action" value="advanced"> | 				<input type="hidden" name="action" value="advanced"> | ||||||
|  |  | ||||||
| 				{{$isWikiEnabled := or (.Repository.EnableUnit $.UnitTypeWiki) (.Repository.EnableUnit $.UnitTypeExternalWiki)}} | 				{{$isWikiEnabled := or (.Repository.UnitEnabled $.UnitTypeWiki) (.Repository.UnitEnabled $.UnitTypeExternalWiki)}} | ||||||
| 				<div class="inline field"> | 				<div class="inline field"> | ||||||
| 					<label>{{.i18n.Tr "repo.wiki"}}</label> | 					<label>{{.i18n.Tr "repo.wiki"}}</label> | ||||||
| 					<div class="ui checkbox"> | 					<div class="ui checkbox"> | ||||||
| @ -104,17 +104,17 @@ | |||||||
| 				<div class="field {{if not $isWikiEnabled}}disabled{{end}}" id="wiki_box"> | 				<div class="field {{if not $isWikiEnabled}}disabled{{end}}" id="wiki_box"> | ||||||
| 					<div class="field"> | 					<div class="field"> | ||||||
| 						<div class="ui radio checkbox"> | 						<div class="ui radio checkbox"> | ||||||
| 							<input class="hidden enable-system-radio" tabindex="0" name="enable_external_wiki" type="radio" value="false" data-target="#external_wiki_box" {{if not (.Repository.EnableUnit $.UnitTypeExternalWiki)}}checked{{end}}/> | 							<input class="hidden enable-system-radio" tabindex="0" name="enable_external_wiki" type="radio" value="false" data-target="#external_wiki_box" {{if not (.Repository.UnitEnabled $.UnitTypeExternalWiki)}}checked{{end}}/> | ||||||
| 							<label>{{.i18n.Tr "repo.settings.use_internal_wiki"}}</label> | 							<label>{{.i18n.Tr "repo.settings.use_internal_wiki"}}</label> | ||||||
| 						</div> | 						</div> | ||||||
| 					</div> | 					</div> | ||||||
| 					<div class="field"> | 					<div class="field"> | ||||||
| 						<div class="ui radio checkbox"> | 						<div class="ui radio checkbox"> | ||||||
| 							<input class="hidden enable-system-radio" tabindex="0" name="enable_external_wiki" type="radio" value="true" data-target="#external_wiki_box" {{if .Repository.EnableUnit $.UnitTypeExternalWiki}}checked{{end}}/> | 							<input class="hidden enable-system-radio" tabindex="0" name="enable_external_wiki" type="radio" value="true" data-target="#external_wiki_box" {{if .Repository.UnitEnabled $.UnitTypeExternalWiki}}checked{{end}}/> | ||||||
| 							<label>{{.i18n.Tr "repo.settings.use_external_wiki"}}</label> | 							<label>{{.i18n.Tr "repo.settings.use_external_wiki"}}</label> | ||||||
| 						</div> | 						</div> | ||||||
| 					</div> | 					</div> | ||||||
| 					<div class="field {{if not (.Repository.EnableUnit $.UnitTypeExternalWiki)}}disabled{{end}}" id="external_wiki_box"> | 					<div class="field {{if not (.Repository.UnitEnabled $.UnitTypeExternalWiki)}}disabled{{end}}" id="external_wiki_box"> | ||||||
| 						<label for="external_wiki_url">{{.i18n.Tr "repo.settings.external_wiki_url"}}</label> | 						<label for="external_wiki_url">{{.i18n.Tr "repo.settings.external_wiki_url"}}</label> | ||||||
| 						<input id="external_wiki_url" name="external_wiki_url" type="url" value="{{(.Repository.MustGetUnit $.UnitTypeExternalWiki).ExternalWikiConfig.ExternalWikiURL}}"> | 						<input id="external_wiki_url" name="external_wiki_url" type="url" value="{{(.Repository.MustGetUnit $.UnitTypeExternalWiki).ExternalWikiConfig.ExternalWikiURL}}"> | ||||||
| 						<p class="help">{{.i18n.Tr "repo.settings.external_wiki_url_desc"}}</p> | 						<p class="help">{{.i18n.Tr "repo.settings.external_wiki_url_desc"}}</p> | ||||||
| @ -123,7 +123,7 @@ | |||||||
|  |  | ||||||
| 				<div class="ui divider"></div> | 				<div class="ui divider"></div> | ||||||
|  |  | ||||||
| 				{{$isIssuesEnabled := or (.Repository.EnableUnit $.UnitTypeIssues) (.Repository.EnableUnit $.UnitTypeExternalTracker)}} | 				{{$isIssuesEnabled := or (.Repository.UnitEnabled $.UnitTypeIssues) (.Repository.UnitEnabled $.UnitTypeExternalTracker)}} | ||||||
| 				<div class="inline field"> | 				<div class="inline field"> | ||||||
| 					<label>{{.i18n.Tr "repo.issues"}}</label> | 					<label>{{.i18n.Tr "repo.issues"}}</label> | ||||||
| 					<div class="ui checkbox"> | 					<div class="ui checkbox"> | ||||||
| @ -134,17 +134,17 @@ | |||||||
| 				<div class="field {{if not $isIssuesEnabled}}disabled{{end}}" id="issue_box"> | 				<div class="field {{if not $isIssuesEnabled}}disabled{{end}}" id="issue_box"> | ||||||
| 					<div class="field"> | 					<div class="field"> | ||||||
| 						<div class="ui radio checkbox"> | 						<div class="ui radio checkbox"> | ||||||
| 							<input class="hidden enable-system-radio" tabindex="0" name="enable_external_tracker" type="radio" value="false" data-target="#external_issue_box" {{if not (.Repository.EnableUnit $.UnitTypeExternalTracker)}}checked{{end}}/> | 							<input class="hidden enable-system-radio" tabindex="0" name="enable_external_tracker" type="radio" value="false" data-target="#external_issue_box" {{if not (.Repository.UnitEnabled $.UnitTypeExternalTracker)}}checked{{end}}/> | ||||||
| 							<label>{{.i18n.Tr "repo.settings.use_internal_issue_tracker"}}</label> | 							<label>{{.i18n.Tr "repo.settings.use_internal_issue_tracker"}}</label> | ||||||
| 						</div> | 						</div> | ||||||
| 					</div> | 					</div> | ||||||
| 					<div class="field"> | 					<div class="field"> | ||||||
| 						<div class="ui radio checkbox"> | 						<div class="ui radio checkbox"> | ||||||
| 							<input class="hidden enable-system-radio" tabindex="0" name="enable_external_tracker" type="radio" value="true" data-target="#external_issue_box" {{if .Repository.EnableUnit $.UnitTypeExternalTracker}}checked{{end}}/> | 							<input class="hidden enable-system-radio" tabindex="0" name="enable_external_tracker" type="radio" value="true" data-target="#external_issue_box" {{if .Repository.UnitEnabled $.UnitTypeExternalTracker}}checked{{end}}/> | ||||||
| 							<label>{{.i18n.Tr "repo.settings.use_external_issue_tracker"}}</label> | 							<label>{{.i18n.Tr "repo.settings.use_external_issue_tracker"}}</label> | ||||||
| 						</div> | 						</div> | ||||||
| 					</div> | 					</div> | ||||||
| 					<div class="field {{if not (.Repository.EnableUnit $.UnitTypeExternalTracker)}}disabled{{end}}" id="external_issue_box"> | 					<div class="field {{if not (.Repository.UnitEnabled $.UnitTypeExternalTracker)}}disabled{{end}}" id="external_issue_box"> | ||||||
| 						<div class="field"> | 						<div class="field"> | ||||||
| 							<label for="external_tracker_url">{{.i18n.Tr "repo.settings.external_tracker_url"}}</label> | 							<label for="external_tracker_url">{{.i18n.Tr "repo.settings.external_tracker_url"}}</label> | ||||||
| 							<input id="external_tracker_url" name="external_tracker_url" type="url" value="{{(.Repository.MustGetUnit $.UnitTypeExternalTracker).ExternalTrackerConfig.ExternalTrackerURL}}"> | 							<input id="external_tracker_url" name="external_tracker_url" type="url" value="{{(.Repository.MustGetUnit $.UnitTypeExternalTracker).ExternalTrackerConfig.ExternalTrackerURL}}"> | ||||||
| @ -181,7 +181,7 @@ | |||||||
| 					<div class="inline field"> | 					<div class="inline field"> | ||||||
| 						<label>{{.i18n.Tr "repo.pulls"}}</label> | 						<label>{{.i18n.Tr "repo.pulls"}}</label> | ||||||
| 						<div class="ui checkbox"> | 						<div class="ui checkbox"> | ||||||
| 							<input name="enable_pulls" type="checkbox" {{if .Repository.EnableUnit $.UnitTypePullRequests}}checked{{end}}> | 							<input name="enable_pulls" type="checkbox" {{if .Repository.UnitEnabled $.UnitTypePullRequests}}checked{{end}}> | ||||||
| 							<label>{{.i18n.Tr "repo.settings.pulls_desc"}}</label> | 							<label>{{.i18n.Tr "repo.settings.pulls_desc"}}</label> | ||||||
| 						</div> | 						</div> | ||||||
| 					</div> | 					</div> | ||||||
| @ -222,7 +222,7 @@ | |||||||
| 				</div> | 				</div> | ||||||
| 			</div> | 			</div> | ||||||
|  |  | ||||||
| 			{{if .Repository.EnableUnit $.UnitTypeWiki}} | 			{{if .Repository.UnitEnabled $.UnitTypeWiki}} | ||||||
| 				<div class="ui divider"></div> | 				<div class="ui divider"></div> | ||||||
|  |  | ||||||
| 				<div class="item"> | 				<div class="item"> | ||||||
| @ -354,7 +354,7 @@ | |||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
|  |  | ||||||
| 	{{if .Repository.EnableUnit $.UnitTypeWiki}} | 	{{if .Repository.UnitEnabled $.UnitTypeWiki}} | ||||||
| 	<div class="ui small modal" id="delete-wiki-modal"> | 	<div class="ui small modal" id="delete-wiki-modal"> | ||||||
| 		<div class="header"> | 		<div class="header"> | ||||||
| 			{{.i18n.Tr "repo.settings.wiki-delete"}} | 			{{.i18n.Tr "repo.settings.wiki-delete"}} | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 Ethan Koenig
					Ethan Koenig