Merge remote-tracking branch 'upstream/dev'
Conflicts: models/repo.go
This commit is contained in:
		
						commit
						8d2a6fc484
					
				|  | @ -1,5 +1,8 @@ | |||
| [run] | ||||
| init_cmds = [["./gogs", "web"]] | ||||
| init_cmds = [ | ||||
| 	["grep", "-rn", "FIXME", "."], | ||||
| 	["./gogs", "web"] | ||||
| ] | ||||
| watch_all = true | ||||
| watch_dirs = [ | ||||
| 	"$WORKDIR/conf/locale", | ||||
|  | @ -11,7 +14,7 @@ watch_dirs = [ | |||
| watch_exts = [".go", ".ini"] | ||||
| build_delay = 1500 | ||||
| cmds = [ | ||||
| 	["go", "install"], | ||||
| 	["go", "build"], | ||||
| 	["go", "install", "-tags", "sqlite cert"], | ||||
| 	["go", "build", "-tags", "sqlite cert"], | ||||
| 	["./gogs", "web"] | ||||
| ] | ||||
|  | @ -16,6 +16,6 @@ settings: | |||
|             then | ||||
|                 go install -v | ||||
|             else | ||||
|                 go get -v -tags "sqlite redis memecache" github.com/gogits/gogs | ||||
|                 go install -v -tags "sqlite redis memecache" | ||||
|                 go get -v -tags "sqlite redis memcache cert" github.com/gogits/gogs | ||||
|                 go install -v -tags "sqlite redis memcache cert" | ||||
|             fi | ||||
|  |  | |||
							
								
								
									
										11
									
								
								.gopmfile
								
								
								
								
							
							
						
						
									
										11
									
								
								.gopmfile
								
								
								
								
							|  | @ -8,7 +8,7 @@ github.com/Unknwon/cae = commit:2e70a1351b | |||
| github.com/Unknwon/com = commit:2cbcbc6916 | ||||
| github.com/Unknwon/goconfig = commit:0f8d8dc1c0 | ||||
| github.com/Unknwon/i18n = commit:47baeff8d0 | ||||
| github.com/Unknwon/macaron =  | ||||
| github.com/Unknwon/macaron = commit:4927b78ad9 | ||||
| github.com/codegangsta/cli = commit:7381bc4e62 | ||||
| github.com/go-sql-driver/mysql = commit:8111ee3ec3 | ||||
| github.com/go-xorm/core = commit:750aae0fa5 | ||||
|  | @ -17,13 +17,14 @@ github.com/gogits/gfm = commit:40f747a9c0 | |||
| github.com/gogits/oauth2 = commit:99cbec870a | ||||
| github.com/lib/pq = commit:b021d0ef20 | ||||
| github.com/macaron-contrib/cache = commit:204d8e5137 | ||||
| github.com/macaron-contrib/captcha =  | ||||
| github.com/macaron-contrib/csrf =  | ||||
| github.com/macaron-contrib/i18n =  | ||||
| github.com/macaron-contrib/session =  | ||||
| github.com/macaron-contrib/captcha = commit:d37d37eeea | ||||
| github.com/macaron-contrib/csrf = commit:8e980822b0 | ||||
| github.com/macaron-contrib/i18n = commit:2246f45894 | ||||
| github.com/macaron-contrib/session = commit:42ad41e323 | ||||
| github.com/macaron-contrib/toolbox = commit:57127bcc89 | ||||
| github.com/mattn/go-sqlite3 = commit:a80c27ba33 | ||||
| github.com/nfnt/resize = commit:581d15cb53 | ||||
| github.com/russross/blackfriday = commit:05b8cefd6a | ||||
| github.com/saintfish/chardet = commit:3af4cd4741 | ||||
| 
 | ||||
| [res] | ||||
|  |  | |||
							
								
								
									
										10
									
								
								README.md
								
								
								
								
							
							
						
						
									
										10
									
								
								README.md
								
								
								
								
							|  | @ -1,11 +1,11 @@ | |||
| Gogs - Go Git Service [](https://app.wercker.com/project/bykey/ad0bdb0bc450ac6f09bc56b9640a50aa) [](https://drone.io/github.com/gogits/gogs/latest)  | ||||
| Gogs - Go Git Service [](https://app.wercker.com/project/bykey/ad0bdb0bc450ac6f09bc56b9640a50aa) [](https://travis-ci.org/gogits/gogs) | ||||
| ===================== | ||||
| 
 | ||||
| Gogs(Go Git Service) is a painless self-hosted Git Service written in Go. | ||||
| 
 | ||||
|  | ||||
| 
 | ||||
| ##### Current version: 0.5.4 Beta | ||||
| ##### Current version: 0.5.5 Beta | ||||
| 
 | ||||
| ### NOTICES | ||||
| 
 | ||||
|  | @ -32,11 +32,13 @@ The goal of this project is to make the easiest, fastest and most painless way t | |||
| - Activity timeline | ||||
| - SSH/HTTP(S) protocol support | ||||
| - SMTP/LDAP/reverse proxy authentication support | ||||
| - Reverse proxy suburl support | ||||
| - Register/delete/rename account | ||||
| - Create/manage/delete organization with team management | ||||
| - Create/migrate/mirror/delete/watch/rename/transfer public/private repository | ||||
| - Repository viewer/release/issue tracker | ||||
| - Repository and Organization level webhooks | ||||
| - Repository Git hooks | ||||
| - Add/remove repository collaborators | ||||
| - Gravatar and cache support | ||||
| - Mail service(register, issue) | ||||
|  | @ -44,7 +46,7 @@ The goal of this project is to make the easiest, fastest and most painless way t | |||
| - Slack webhook integration | ||||
| - Supports MySQL, PostgreSQL and SQLite3 | ||||
| - Social account login(GitHub, Google, QQ, Weibo) | ||||
| - Multi-language support(English, Chinese, Germany, French etc.) | ||||
| - Multi-language support(English, Simplified Chinese, Traditional Chinese, Germany, French, Dutch etc.) | ||||
| 
 | ||||
| ## System Requirements | ||||
| 
 | ||||
|  | @ -57,7 +59,7 @@ Make sure you install [Prerequirements](http://gogs.io/docs/installation/) first | |||
| 
 | ||||
| There are 5 ways to install Gogs: | ||||
| 
 | ||||
| - [Install from binary](http://gogs.io/docs/installation/install_from_binary.md): **STRONGLY RECOMMENDED** | ||||
| - [Install from binary](http://gogs.io/docs/installation/install_from_binary.md) | ||||
| - [Install from source](http://gogs.io/docs/installation/install_from_source.md) | ||||
| - [Install from packages](http://gogs.io/docs/installation/install_from_packages.md) | ||||
| - [Ship with Docker](https://github.com/gogits/gogs/tree/master/docker) | ||||
|  |  | |||
							
								
								
									
										26
									
								
								README_ZH.md
								
								
								
								
							
							
						
						
									
										26
									
								
								README_ZH.md
								
								
								
								
							|  | @ -1,11 +1,11 @@ | |||
| Gogs - Go Git Service [](https://app.wercker.com/project/bykey/ad0bdb0bc450ac6f09bc56b9640a50aa) [](https://drone.io/github.com/gogits/gogs/latest) | ||||
| Gogs - Go Git Service [](https://app.wercker.com/project/bykey/ad0bdb0bc450ac6f09bc56b9640a50aa) [](https://travis-ci.org/gogits/gogs) | ||||
| ===================== | ||||
| 
 | ||||
| Gogs(Go Git Service) 是一个基于 Go 语言的自助 Git 服务。 | ||||
| 
 | ||||
|  | ||||
| 
 | ||||
| ##### 当前版本:0.5.4 Beta | ||||
| ##### 当前版本:0.5.5 Beta | ||||
| 
 | ||||
| ## 开发目的 | ||||
| 
 | ||||
|  | @ -23,19 +23,21 @@ Gogs 的目标是打造一个最简单、最快速和最轻松的方式搭建自 | |||
| - 活动时间线 | ||||
| - 支持 SSH/HTTP(S) 协议 | ||||
| - 支持 SMTP/LDAP/反向代理 用户认证 | ||||
| - 注册/删除/重命名 用户 | ||||
| - 创建/管理/删除 组织以及团队管理功能 | ||||
| - 创建/迁移/镜像/删除/关注/重命名/转移 公开/私有 仓库 | ||||
| - 仓库 浏览/发布/工单管理 | ||||
| - 仓库和组织级别 Web 钩子 | ||||
| - 添加/删除 仓库协作者 | ||||
| - Gravatar 以及缓存支持 | ||||
| - 邮件服务(注册、Issue) | ||||
| - 支持反向代理子路径 | ||||
| - 支持 注册/删除/重命名 用户 | ||||
| - 支持 创建/管理/删除 组织以及团队管理功能 | ||||
| - 支持 创建/迁移/镜像/删除/关注/重命名/转移 公开/私有 仓库 | ||||
| - 支持仓库 浏览/发布/工单管理 | ||||
| - 支持仓库和组织级别 Web 钩子 | ||||
| - 支持仓库 Git 钩子 | ||||
| - 支持 添加/删除 仓库协作者 | ||||
| - 支持 Gravatar 以及本地缓存 | ||||
| - 支持邮件服务(注册、Issue) | ||||
| - 管理员面板 | ||||
| - Slack Web 钩子集成 | ||||
| - 支持 MySQL、PostgreSQL 以及 SQLite3 数据库 | ||||
| - 社交帐号登录(GitHub、Google、QQ、微博) | ||||
| - 多语言支持(英文、简体中文、德语、法语等等) | ||||
| - 多语言支持(英文、简体中文、繁体中文、德语、法语、荷兰语等等) | ||||
| 
 | ||||
| ## 系统要求 | ||||
| 
 | ||||
|  | @ -48,7 +50,7 @@ Gogs 的目标是打造一个最简单、最快速和最轻松的方式搭建自 | |||
| 
 | ||||
| 然后,您可以通过以下 5 种方式来安装 Gogs: | ||||
| 
 | ||||
| - [二进制安装](http://gogs.io/docs/installation/install_from_binary.md): **强烈推荐** | ||||
| - [二进制安装](http://gogs.io/docs/installation/install_from_binary.md) | ||||
| - [源码安装](http://gogs.io/docs/installation/install_from_source.md) | ||||
| - [包管理安装](http://gogs.io/docs/installation/install_from_packages.md) | ||||
| - [采用 Docker 部署](https://github.com/gogits/gogs/tree/master/docker) | ||||
|  |  | |||
|  | @ -1,3 +1,5 @@ | |||
| // +build cert
 | ||||
| 
 | ||||
| // Copyright 2009 The Go Authors. All rights reserved.
 | ||||
| // Copyright 2014 The Gogs Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a MIT-style
 | ||||
|  |  | |||
|  | @ -0,0 +1,34 @@ | |||
| // +build !cert
 | ||||
| 
 | ||||
| // Copyright 2009 The Go Authors. All rights reserved.
 | ||||
| // Copyright 2014 The Gogs Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a MIT-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| package cmd | ||||
| 
 | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/codegangsta/cli" | ||||
| ) | ||||
| 
 | ||||
| var CmdCert = cli.Command{ | ||||
| 	Name:  "cert", | ||||
| 	Usage: "Generate self-signed certificate", | ||||
| 	Description: `Generate a self-signed X.509 certificate for a TLS server.  | ||||
| Outputs to 'cert.pem' and 'key.pem' and will overwrite existing files.`, | ||||
| 	Action: runCert, | ||||
| 	Flags: []cli.Flag{ | ||||
| 		cli.StringFlag{"host", "", "Comma-separated hostnames and IPs to generate a certificate for", ""}, | ||||
| 		cli.StringFlag{"ecdsa-curve", "", "ECDSA curve to use to generate a key. Valid values are P224, P256, P384, P521", ""}, | ||||
| 		cli.IntFlag{"rsa-bits", 2048, "Size of RSA key to generate. Ignored if --ecdsa-curve is set", ""}, | ||||
| 		cli.StringFlag{"start-date", "", "Creation date formatted as Jan 1 15:04:05 2011", ""}, | ||||
| 		cli.DurationFlag{"duration", 365 * 24 * time.Hour, "Duration that certificate is valid for", ""}, | ||||
| 		cli.BoolFlag{"ca", "whether this cert should be its own Certificate Authority", ""}, | ||||
| 	}, | ||||
| } | ||||
| 
 | ||||
| func runCert(ctx *cli.Context) { | ||||
| 	fmt.Println("Command cert not available, please use build tags 'cert' to rebuild.") | ||||
| } | ||||
|  | @ -60,6 +60,7 @@ func runDump(ctx *cli.Context) { | |||
| 	z.AddFile("gogs-db.sql", path.Join(workDir, "gogs-db.sql")) | ||||
| 	z.AddFile("custom/conf/app.ini", path.Join(workDir, "custom/conf/app.ini")) | ||||
| 	z.AddDir("log", path.Join(workDir, "log")) | ||||
| 	// FIXME: SSH key file.
 | ||||
| 	if err = z.Close(); err != nil { | ||||
| 		os.Remove(fileName) | ||||
| 		log.Fatalf("Fail to save %s: %v", fileName, err) | ||||
|  |  | |||
							
								
								
									
										35
									
								
								cmd/web.go
								
								
								
								
							
							
						
						
									
										35
									
								
								cmd/web.go
								
								
								
								
							|  | @ -61,10 +61,18 @@ func checkVersion() { | |||
| 		log.Fatal(4, "Binary and template file version does not match, did you forget to recompile?") | ||||
| 	} | ||||
| 
 | ||||
| 	// Macaron.
 | ||||
| 	// Check dependency version.
 | ||||
| 	macaronVer := git.MustParseVersion(strings.Join(strings.Split(macaron.Version(), ".")[:3], ".")) | ||||
| 	if macaronVer.LessThan(git.MustParseVersion("0.1.8")) { | ||||
| 		log.Fatal(4, "Macaron version does not match, did you forget to update?(github.com/Unknwon/macaron)") | ||||
| 	if macaronVer.LessThan(git.MustParseVersion("0.2.0")) { | ||||
| 		log.Fatal(4, "Package macaron version is too old, did you forget to update?(github.com/Unknwon/macaron)") | ||||
| 	} | ||||
| 	i18nVer := git.MustParseVersion(i18n.Version()) | ||||
| 	if i18nVer.LessThan(git.MustParseVersion("0.0.2")) { | ||||
| 		log.Fatal(4, "Package i18n version is too old, did you forget to update?(github.com/macaron-contrib/i18n)") | ||||
| 	} | ||||
| 	sessionVer := git.MustParseVersion(session.Version()) | ||||
| 	if sessionVer.LessThan(git.MustParseVersion("0.0.1")) { | ||||
| 		log.Fatal(4, "Package session version is too old, did you forget to update?(github.com/macaron-contrib/session)") | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | @ -88,10 +96,12 @@ func newMacaron() *macaron.Macaron { | |||
| 		IndentJSON: macaron.Env != macaron.PROD, | ||||
| 	})) | ||||
| 	m.Use(i18n.I18n(i18n.Options{ | ||||
| 		SubURL:   setting.AppSubUrl, | ||||
| 		Langs:    setting.Langs, | ||||
| 		Names:    setting.Names, | ||||
| 		Redirect: true, | ||||
| 		SubURL:          setting.AppSubUrl, | ||||
| 		Directory:       path.Join(setting.ConfRootPath, "locale"), | ||||
| 		CustomDirectory: path.Join(setting.CustomPath, "conf/locale"), | ||||
| 		Langs:           setting.Langs, | ||||
| 		Names:           setting.Names, | ||||
| 		Redirect:        true, | ||||
| 	})) | ||||
| 	m.Use(cache.Cacher(cache.Options{ | ||||
| 		Adapter:  setting.CacheAdapter, | ||||
|  | @ -239,6 +249,11 @@ func runWeb(*cli.Context) { | |||
| 			r.Post("/:authid", bindIgnErr(auth.AuthenticationForm{}), admin.EditAuthSourcePost) | ||||
| 			r.Post("/:authid/delete", admin.DeleteAuthSource) | ||||
| 		}) | ||||
| 
 | ||||
| 		m.Group("/notices", func(r *macaron.Router) { | ||||
| 			r.Get("", admin.Notices) | ||||
| 			r.Get("/:id:int/delete", admin.DeleteNotice) | ||||
| 		}) | ||||
| 	}, adminReq) | ||||
| 
 | ||||
| 	m.Get("/:username", ignSignIn, user.Profile) | ||||
|  | @ -313,6 +328,12 @@ func runWeb(*cli.Context) { | |||
| 			r.Get("/hooks/:id", repo.WebHooksEdit) | ||||
| 			r.Post("/hooks/gogs/:id", bindIgnErr(auth.NewWebhookForm{}), repo.WebHooksEditPost) | ||||
| 			r.Post("/hooks/slack/:id", bindIgnErr(auth.NewSlackHookForm{}), repo.SlackHooksEditPost) | ||||
| 
 | ||||
| 			m.Group("/hooks/git", func(r *macaron.Router) { | ||||
| 				r.Get("", repo.GitHooks) | ||||
| 				r.Get("/:name", repo.GitHooksEdit) | ||||
| 				r.Post("/:name", repo.GitHooksEditPost) | ||||
| 			}, middleware.GitHookService()) | ||||
| 		}) | ||||
| 	}, reqSignIn, middleware.RepoAssignment(true), reqTrueOwner) | ||||
| 
 | ||||
|  |  | |||
|  | @ -70,6 +70,8 @@ ENABLE_CACHE_AVATAR = false | |||
| ENABLE_NOTIFY_MAIL = false | ||||
| ; More detail: https://github.com/gogits/gogs/issues/165 | ||||
| ENABLE_REVERSE_PROXY_AUTHENTICATION = false | ||||
| ; Repository Git hooks | ||||
| ENABLE_GIT_HOOKS = false | ||||
| 
 | ||||
| [webhook] | ||||
| ; Cron task interval in minutes | ||||
|  | @ -256,5 +258,5 @@ CONN = | |||
| MAX_GITDIFF_LINES = 10000 | ||||
| 
 | ||||
| [i18n] | ||||
| LANGS = en-US,zh-CN,de-DE,fr-CA | ||||
| NAMES = English,简体中文,Deutsch,Français | ||||
| LANGS = en-US,zh-CN,zh-HK,de-DE,fr-CA,nl-NL | ||||
| NAMES = English,简体中文,繁體中文,Deutsch,Français,Nederlands | ||||
|  |  | |||
|  | @ -5,9 +5,9 @@ dashboard = Dashboard | |||
| explore = Erkunden | ||||
| help = Hilfe | ||||
| sign_in = Anmelden | ||||
| social_sign_in = Social Sign In: 2nd Step <small>associate account</small> | ||||
| social_sign_in = Anmeldung über soziales Konto: zweiter Schritt <small>Konto verknüpfen</small> | ||||
| sign_out = Abmelden | ||||
| sign_up = Sign up | ||||
| sign_up = Registrieren | ||||
| register = Registrieren | ||||
| website = Webseite | ||||
| version = Version | ||||
|  | @ -18,7 +18,7 @@ language = Sprache | |||
| username = Benutzername | ||||
| email = E-Mail | ||||
| password = Passwort | ||||
| re_type = wiederholen | ||||
| re_type = Passwort bestätigen | ||||
| captcha = Captcha | ||||
| 
 | ||||
| repository = Repository | ||||
|  | @ -60,11 +60,11 @@ domain = Domain | |||
| domain_helper = Dies hat Auswirkung auf die SSH clone URLs. | ||||
| app_url = Anwendungs-URL | ||||
| app_url_helper = Dies hat Auswirkung auf die HTTP/HTTPS clone URLs und für die E-Mails. | ||||
| email_title = E-Mail-Service-Einstellungen(Optional) | ||||
| email_title = E-Mail-Service-Einstellungen (optional) | ||||
| smtp_host = SMTP Host | ||||
| mailer_user = Sender E-mail | ||||
| mailer_password = Sender Passwort | ||||
| notify_title = Benachrichtigungseinstellungen(Optional) | ||||
| notify_title = Benachrichtigungseinstellungen (optional) | ||||
| register_confirm = Registrierungsbestätigung aktvieren | ||||
| mail_notify = E-Mail-Benachrichtgung aktivieren | ||||
| admin_title = Konto-Einstellungen für den Administrator | ||||
|  | @ -85,14 +85,14 @@ install_success = Herzlich Willkommen! Wir sind froh, dass du dich für Gogs ent | |||
| [home] | ||||
| uname_holder = Benutzername oder E-Mail | ||||
| password_holder = Passwort | ||||
| switch_dashboard_context = Switch Dashboard Context | ||||
| switch_dashboard_context = Dashboard Kontext wechseln | ||||
| my_repos = Meine Repositorys | ||||
| collaborative_repos = Gemeinschaftliche Repositorys | ||||
| my_orgs = Meine Organisationen | ||||
| my_mirrors = Meine Spiegel | ||||
| 
 | ||||
| [explore] | ||||
| repos = Repositories | ||||
| repos = Repositorys | ||||
| 
 | ||||
| [auth] | ||||
| create_new_account = Neues Konto erstellen | ||||
|  | @ -104,9 +104,9 @@ remember_me = angemeldet bleiben | |||
| forgot_password= Passwort vergessen | ||||
| forget_password = Passwort vergessen? | ||||
| sign_up_now = Du willst ein Konto? Jetzt registrieren! | ||||
| confirmation_mail_sent_prompt = Eine neu Bestätigungs-E-Mail wurde an <b>%s</b> gesendet. Kontrolliere dein Postfach innerhalb der nächsten %d Stunden um die Registrierung abzuschließen. | ||||
| sign_in_email = Melden dich mit deiner E-Mail-Adresse an | ||||
| active_your_account = Aktivieren dein Konto | ||||
| confirmation_mail_sent_prompt = Eine neue Bestätigungs-E-Mail wurde an <b>%s</b> gesendet. Kontrolliere dein Postfach innerhalb der nächsten %d Stunden, um die Registrierung abzuschließen. | ||||
| sign_in_email = Melde dich mit deiner E-Mail-Adresse an | ||||
| active_your_account = Aktiviere dein Konto | ||||
| resent_limit_prompt = Es tut uns leid, du sendest zu häufig Aktivierungs-E-Mails. Bitte warte 3 Minuten. | ||||
| has_unconfirmed_mail = Hallo %s, du hast eine unbestätigte E-Mail-Adresse (<b>%s</b>). Falls du noch keine Bestätigungs-E-Mail erhalten hast oder eine neue senden musst, klicke auf den unteren Button. | ||||
| resend_mail = Hier klicken, um deine Aktivierungs-E-Mail erneut zu versenden | ||||
|  | @ -122,7 +122,7 @@ UserName = Benutzername | |||
| RepoName = Repository-Name | ||||
| Email = E-Mail-Adresse | ||||
| Password = Passwort | ||||
| Retype = Passwort erneut eingeben | ||||
| Retype = Passwort bestätigen | ||||
| SSHTitle = SSH-Schlüsselname | ||||
| HttpsUrl = HTTPS-URL | ||||
| PayloadUrl = Payload-URL | ||||
|  | @ -158,7 +158,7 @@ enterred_invalid_password = Bitte stelle sicher, dass das eingegebene Passwort r | |||
| user_not_exist = Angegebener Benutzer existiert nicht. | ||||
| last_org_owner = Der zu entfernende Benutzer ist der letzte Teambesitzer. Es muss einen anderen Besitzer geben. | ||||
| 
 | ||||
| invalid_ssh_key = Leider sind wir nicht in der Lage, Ihren SSH-Schlüssel zu überprüfen: %s | ||||
| invalid_ssh_key = Leider sind wir nicht in der Lage, deinen SSH-Schlüssel zu überprüfen: %s | ||||
| auth_failed = Authentifizierung fehlgeschlagen: %v | ||||
| 
 | ||||
| still_own_repo = Dein Konto besitzt noch Repositorys. Diese müssen zuerst gelöscht oder übertragen werden. | ||||
|  | @ -166,6 +166,15 @@ org_still_own_repo = Diese Organisation besitzt noch Repositorys. Diese müssen | |||
| 
 | ||||
| still_own_user = Diese Authentifizierung wird noch von einigen Benutzern genutzt. Entferne diese zuvor und lösche erneut. | ||||
| 
 | ||||
| [user] | ||||
| change_avatar = Ändere dein Profilbild auf gravatar.com | ||||
| join_on = Registriert | ||||
| repositories = Repositorys | ||||
| activity = Öffentliche Aktivität | ||||
| followers = Folgen | ||||
| starred = Markiert | ||||
| following = Folgt | ||||
| 
 | ||||
| [settings] | ||||
| profile = Profil | ||||
| password = Passwort | ||||
|  | @ -260,7 +269,7 @@ settings.transfer = Besitz übertragen | |||
| settings.transfer_desc = Übertrage dieses Repository einem anderen Benutzer oder einer Organisation. | ||||
| settings.new_owner_has_same_repo = Neuer Eigentümer hat bereits ein Repository mit dem gleichen Namen. | ||||
| settings.delete = Repository löschen | ||||
| settings.delete_desc = Wenn dieses Repository gelöschet ist, gibt es keinen Weg zurück. Sei dir sicher! | ||||
| settings.delete_desc = Wenn dieses Repository gelöscht ist, gibt es keinen Weg zurück. Sei dir sicher! | ||||
| settings.update_settings_success = Repository-Optionen aktualisiert | ||||
| settings.transfer_owner = Neuer Besitzer | ||||
| settings.make_transfer = übertragen | ||||
|  | @ -285,7 +294,7 @@ settings.update_webhook = Webhook aktualisieren | |||
| settings.update_hook_success = Webhook aktualisiert | ||||
| settings.delete_webhook = Webhook löschen | ||||
| settings.recent_deliveries = letzte Zustellungen | ||||
| settings.hook_type = Hook Type | ||||
| settings.hook_type = Hook Typ | ||||
| settings.add_slack_hook_desc = Add <a href="http://slack.com">Slack</a> integration to your repository. | ||||
| settings.slack_token = Token | ||||
| settings.slack_domain = Domain | ||||
|  | @ -321,7 +330,7 @@ settings.delete = Organisation löschen | |||
| settings.delete_account = Diese Organisation löschen | ||||
| settings.delete_prompt = Die Organisation wird dauerhaft gelöscht. Dies kann <strong>NICHT</strong> rückgängig gemacht werden! | ||||
| settings.confirm_delete_account = Löschen | ||||
| settings.hooks_desc = Add webhooks that will be triggered for <strong>all repositories</strong> under this organization. | ||||
| settings.hooks_desc = Füge Webhooks hinzu, die für <strong>alle</strong> Repositorys dieser Organisation ausgelöst werden. | ||||
| 
 | ||||
| members.public = Öffentlich | ||||
| members.public_helper = Privat machen | ||||
|  | @ -372,8 +381,8 @@ next = vor | |||
| dashboard.statistic = Statistik | ||||
| dashboard.operations = Operationen | ||||
| dashboard.system_status = System-Monitor-Status | ||||
| dashboard.statistic_info = GoGS Datenbank hat <b>%d</b> Benutzer, <b>%d</b> Organizationen, <b>%d</b> öffentliche Schlüssel, <b>%d</b> Repositorys, <b>%d</b> watches, <b>%d</b> stars, <b>%d</b> actions, <b>%d</b> Zugriffe, <b>%d</b> issues, <b>%d</b> Kommentare, <b>%d</b> soziale Konten, <b>%d</b> follows, <b>%d</b> Spiegel, <b>%d</b> Releases, <b>%d</b> Login-Quellen, <b>%d</b> Webhooks, <b>%d</b> Milestones, <b>%d</b> Labels, <b>%d</b> Hook-Tasks, <b>%d</b> Teams, <b>%d</b> Aktualisierungs-Tasks, <b>%d</b> Anhänge. | ||||
| dashboard.operation_name = Operation Name | ||||
| dashboard.statistic_info = GoGS Datenbank hat <b>%d</b> Benutzer, <b>%d</b> Organisationen, <b>%d</b> öffentliche Schlüssel, <b>%d</b> Repositorys, <b>%d</b> Beobachtungen, <b>%d</b> Markierungen, <b>%d</b> Aktionen, <b>%d</b> Zugriffe, <b>%d</b> Issues, <b>%d</b> Kommentare, <b>%d</b> soziale Konten, <b>%d</b> Folgende, <b>%d</b> Spiegel, <b>%d</b> Releases, <b>%d</b> Login-Quellen, <b>%d</b> Webhooks, <b>%d</b> Milestones, <b>%d</b> Labels, <b>%d</b> Hook-Tasks, <b>%d</b> Teams, <b>%d</b> Aktualisierungs-Tasks, <b>%d</b> Anhänge. | ||||
| dashboard.operation_name = Name der Operation | ||||
| dashboard.operation_switch = Switch | ||||
| dashboard.operation_run = Ausführen | ||||
| dashboard.clean_unbind_oauth = ungebundene OAuths bereinigen | ||||
|  | @ -436,8 +445,8 @@ repos.repo_manage_panel = Repositorys | |||
| repos.owner = Besitzer | ||||
| repos.name = Name | ||||
| repos.private = Privat | ||||
| repos.watches = Watches | ||||
| repos.stars = Stars | ||||
| repos.watches = Beobachtungen | ||||
| repos.stars = Markierungen | ||||
| repos.issues = Issues | ||||
| 
 | ||||
| auths.auth_manage_panel = Authentifizierung | ||||
|  | @ -493,11 +502,11 @@ config.db_path_helper = (nur für "sqlite3") | |||
| config.service_config = Service-Einstellungen | ||||
| config.register_email_confirm = E-Mail-Bestätigung bei Registrierung | ||||
| config.disable_register = Registrierung deaktivieren | ||||
| config.require_sign_in_view = Require Sign In View | ||||
| config.require_sign_in_view = Ansehen erfordert Registrierung | ||||
| config.mail_notify = E-Mail-Benachrichtigung | ||||
| config.enable_cache_avatar = Avatar-Cache aktivieren | ||||
| config.active_code_lives = Active Code Lives | ||||
| config.reset_password_code_lives = Reset Password Code Lives | ||||
| config.active_code_lives = Aktivierungscode Lebensdauer | ||||
| config.reset_password_code_lives = Passwortcode Lebensdauer | ||||
| config.webhook_config = Webhook-Einstellungen | ||||
| config.task_interval = Task-Intervall | ||||
| config.deliver_timeout = Zeitlimit für Zustellung | ||||
|  | @ -516,7 +525,7 @@ config.session_config = Session-Einstellungen | |||
| config.session_provider = Session-Provider | ||||
| config.provider_config = Provider-Einstellungen | ||||
| config.cookie_name = Cookie-Name | ||||
| config.enable_set_cookie = Enable Set Cookie | ||||
| config.enable_set_cookie = Cookies einschalten | ||||
| config.gc_interval_time = GC-Intervallzeit | ||||
| config.session_life_time = Session-Lebensdauer | ||||
| config.https_only = nur HTTPS | ||||
|  | @ -534,7 +543,7 @@ monitor.name = Name | |||
| monitor.schedule = Zeitplan | ||||
| monitor.next = nächste Ausführung | ||||
| monitor.previous = letzte Ausführung | ||||
| monitor.execute_times = Execute Times | ||||
| monitor.execute_times = Anzahl Ausführungen | ||||
| monitor.process = Laufende Prozesse | ||||
| monitor.desc = Beschreibung | ||||
| monitor.start = Startzeit | ||||
|  |  | |||
|  | @ -159,6 +159,7 @@ user_not_exist = Given user does not exist. | |||
| last_org_owner = The user to remove is the last member in owner team. There must be another owner. | ||||
| 
 | ||||
| invalid_ssh_key = Sorry, we're not able to verify your SSH key: %s | ||||
| unable_verify_ssh_key = Gogs cannot verify your SSH key, but we assume that is valid, please make sure yourself. | ||||
| auth_failed = Authentication failed: %v | ||||
| 
 | ||||
| still_own_repo = Your account still have ownership of repository, you have to delete or transfer them first. | ||||
|  | @ -273,6 +274,9 @@ tags = Tags | |||
| issues = Issues | ||||
| commits = Commits | ||||
| releases = Releases | ||||
| file_raw = Raw | ||||
| file_history = History | ||||
| file_view_raw = View Raw | ||||
| 
 | ||||
| commits.commits = Commits | ||||
| commits.search = Search commits | ||||
|  | @ -287,6 +291,7 @@ settings = Settings | |||
| settings.options = Options | ||||
| settings.collaboration = Collaboration | ||||
| settings.hooks = Webhooks | ||||
| settings.githooks = Git Hooks | ||||
| settings.deploy_keys = Deploy Keys | ||||
| settings.basic_settings = Basic Settings | ||||
| settings.danger_zone = Danger Zone | ||||
|  | @ -308,8 +313,14 @@ settings.confirm_delete = Confirm Deletion | |||
| settings.add_collaborator = Add New Collaborator | ||||
| settings.add_collaborator_success = New collaborator has been added. | ||||
| settings.remove_collaborator_success = Collaborator has been removed. | ||||
| settings.user_is_org_member = User is organization member who cannot be added as a collaborator. | ||||
| settings.add_webhook = Add Webhook | ||||
| settings.hooks_desc = Webhooks allow external services to be notified when certain events happen on Gogs. When the specified events happen, we'll send a POST request to each of the URLs you provide. Learn more in our <a target="_blank" href="http://gogs.io/docs/features/webhook.html">Webhooks Guide</a>. | ||||
| settings.githooks_desc = Git Hooks are powered by Git itself, you can edit files of supported hooks in the list below to apply custom operations. | ||||
| settings.githook_edit_desc = If hook is not active, sample content will be presented. Leave content to be blank will disable this hook. | ||||
| settings.githook_name = Hook Name | ||||
| settings.githook_content = Hook Content | ||||
| settings.update_githook = Update Hook | ||||
| settings.remove_hook_success = Webhook has been removed. | ||||
| settings.add_webhook_desc = We’ll send a <code>POST</code> request to the URL below with details of any subscribed events. You can also specify which data format you'd like to receive (JSON, <code>x-www-form-urlencoded</code>, <em>etc</em>). More information can be found in <a target="_blank" href="http://gogs.io/docs/features/webhook.html">Webhooks Guide</a>. | ||||
| settings.payload_url = Payload URL | ||||
|  | @ -330,6 +341,15 @@ settings.slack_token = Token | |||
| settings.slack_domain = Domain | ||||
| settings.slack_channel = Channel | ||||
| 
 | ||||
| diff.browse_source = Browse Source | ||||
| diff.parent = parent | ||||
| diff.commit = commit | ||||
| diff.data_not_available = Diff Data Not Available. | ||||
| diff.show_diff_stats = Show Diff Stats | ||||
| diff.stats_desc = <strong> %d changed files</strong> with <strong>%d additions</strong> and <strong>%d deletions</strong> | ||||
| diff.bin = BIN | ||||
| diff.view_file = View File | ||||
| 
 | ||||
| [org] | ||||
| org_name_holder = Organization Name | ||||
| org_name_helper = Great organization names are short and memorable. | ||||
|  | @ -402,6 +422,7 @@ teams.admin_permission_desc = This team grants <strong>Admin</strong> access: me | |||
| teams.repositories = Team Repositories | ||||
| teams.add_team_repository = Add Team Repository | ||||
| teams.remove_repo = Remove | ||||
| teams.add_nonexistent_repo = The repository you're trying to add does not exist, please create it first. | ||||
| 
 | ||||
| [admin] | ||||
| dashboard = Dashboard | ||||
|  | @ -410,6 +431,7 @@ organizations = Organizations | |||
| repositories = Repositories | ||||
| authentication = Authentications | ||||
| config = Configuration | ||||
| notices = System Notices | ||||
| monitor = Monitoring | ||||
| prev = Prev. | ||||
| next = Next | ||||
|  | @ -587,12 +609,21 @@ monitor.desc = Description | |||
| monitor.start = Start Time | ||||
| monitor.execute_time = Execution Time | ||||
| 
 | ||||
| notices.system_notice_list = System Notices | ||||
| notices.type = Type | ||||
| notices.type_1 = Repository | ||||
| notices.desc = Description | ||||
| notices.op = Op. | ||||
| notices.delete_success = System notice has been successfully deleted. | ||||
| 
 | ||||
| [action] | ||||
| create_repo = created repository <a href="%s/%s">%s</a> | ||||
| commit_repo = pushed to <a href="%s/%s/src/%s">%s</a> at <a href="%s/%s">%s</a> | ||||
| create_issue = opened issue <a href="%s/%s/issues/%s">%s#%s</a> | ||||
| comment_issue = commented on issue <a href="%s/%s/issues/%s">%s#%s</a> | ||||
| transfer_repo = transfered repository <code>%s</code> to <a href="/%s%s">%s</a> | ||||
| push_tag = pushed tag <a href="%s/%s/src/%s">%s</a> to <a href="%s/%s">%s</a> | ||||
| compare_2_commits = View comparison for these 2 commits | ||||
| 
 | ||||
| [tool] | ||||
| ago = ago | ||||
|  |  | |||
|  | @ -0,0 +1,585 @@ | |||
| app_desc = Een pijnloze self-hosted Git-dienst geschreven in Go | ||||
| home = Home | ||||
| dashboard = Dashboard | ||||
| explore = Verkennen | ||||
| help = Help | ||||
| sign_in = Inloggen | ||||
| social_sign_in = Social netwerk inlog: tweede stap <small>account koppelen</small> | ||||
| sign_out = Afmelden | ||||
| sign_up = Aanmelden | ||||
| register = Registreer | ||||
| website = Website | ||||
| version = Versie | ||||
| page = Pagina | ||||
| template = Template | ||||
| language = Taal | ||||
| username = Gebruikersnaam | ||||
| email = E-mail | ||||
| password = Wachttwoord | ||||
| re_type = Verificatie | ||||
| captcha = Captcha | ||||
| repository = Repositorie | ||||
| organization = Organisatie | ||||
| mirror = Mirror | ||||
| new_repo = Nieuwe repositorie | ||||
| new_migrate = Nieuwe migratie | ||||
| new_org = Nieuwe organisatie | ||||
| manage_org = Beheer organisaties | ||||
| admin_panel = Adminpaneel | ||||
| account_settings = Accountinstellingen | ||||
| settings = Instellingen | ||||
| news_feed = Nieuwsfeed | ||||
| pull_requests = Pull-aanvragen | ||||
| issues = Issues | ||||
| cancel = Annuleer | ||||
| 
 | ||||
| [home] | ||||
| uname_holder = Gebruikersnaam of e-mail | ||||
| password_holder = Wachtwoord | ||||
| switch_dashboard_context = Wissel voorpaginacontext | ||||
| my_repos = Mijn repositories | ||||
| collaborative_repos = Gedeelde repositories | ||||
| my_orgs = Mijn organisaties | ||||
| my_mirrors = Mijn mirrors | ||||
| 
 | ||||
| [auth] | ||||
| create_new_account = Maak nieuw account aan | ||||
| register_hepler_msg = Heeft u al een account? Meld u nu aan! | ||||
| social_register_hepler_msg = Heeft u al een account? Koppel nu! | ||||
| disable_register_prompt = Sorry, registratie is uitgeschakeld. Neem contact op met de beheerder van deze site. | ||||
| disable_register_mail = Sorry, bevestiging van registratie per e-mail is uitgeschakeld. | ||||
| remember_me = Onthoud mij | ||||
| forgot_password = Wachtwoord vergeten | ||||
| forget_password = Wachtwoord vergeten? | ||||
| sign_up_now = Een account nodig? Meld u nu aan. | ||||
| confirmation_mail_sent_prompt = Een bevestigingsemail is gestuurd naar <b>%s</b>, Bevestig u aanvraag binnen %d uren om uw registratie te voltooien. | ||||
| sign_in_email = Meld u aan met uw e-mailadres | ||||
| active_your_account = Activeer uw account | ||||
| resent_limit_prompt = Sorry, u heeft te snel na elkaar een aanvraag gedaan voor een activatie mail. Wacht drie minuten voor uw volgende aanvraag. | ||||
| has_unconfirmed_mail = Beste %s, u heeft een onbevestigde e-mailadres (<b>%s</b>). Als u nog geen bevestiging per e-mail heeft ontvangen, of u een nieuwe aanvraag wilt doen, klik dan op de onderstaande knop. | ||||
| resend_mail = Klik hier om uw activatie mail nog een keer te verzenden | ||||
| send_reset_mail = Klik hier om uw wachtwoord reset mail (nogmaals) te versturen | ||||
| reset_password = Reset uw wachtwoord | ||||
| invalid_code = Sorry, uw bevestigingscode is verlopen of niet meer geldig. | ||||
| reset_password_helper = Klik hier om uw wachtwoord opnieuw in te stellen. | ||||
| password_too_short = De lengte van uw wachtwoord moet minimaal zes karakters zijn. | ||||
| email_not_associate = Dit e-mailadres is niet gekoppeld aan een account. | ||||
| 
 | ||||
| [form] | ||||
| UserName = Gebruikersnaam | ||||
| RepoName = Repositorie naam | ||||
| Email = e-mailadres | ||||
| Password = Wachtwoord | ||||
| Retype = Verifieer wachtwoord | ||||
| SSHTitle = SSH sleutel naam | ||||
| HttpsUrl = HTTPS URL | ||||
| PayloadUrl = Payload URL | ||||
| TeamName = Team naam | ||||
| AuthName = Autorisatienaam | ||||
| require_error =  kan niet leeg zijn. | ||||
| alpha_dash_error =  moet een valide alfanumeriek of dash(-_) karakter zijn. | ||||
| alpha_dash_dot_error =  moet een valide alfanumeriek, dash(-_) of (.) punt karakter zijn. | ||||
| min_size_error =  moet minimaal %s karakters bevatten. | ||||
| max_size_error =  mag maximaal %s karakters bevatten. | ||||
| email_error =  is niet een valide e-mail adres. | ||||
| url_error =  is niet een valide URL. | ||||
| unknown_error = Onbekende fout: | ||||
| captcha_incorrect = Captcha komt niet overeen. | ||||
| password_not_match = Wachtwoord en verificatie wachtwoord komen niet overeen. | ||||
| username_been_taken = Gebruikersnaam is al in gebruik. | ||||
| repo_name_been_taken = Repositorie naam is al in gebruik. | ||||
| org_name_been_taken = Organisatie naam is al in gebruik. | ||||
| team_name_been_taken = Team naam is al in gebruik. | ||||
| email_been_used = e-mailadres is al in gebruik. | ||||
| ssh_key_been_used = Openbare sleutel naam is al in gebruik. | ||||
| illegal_username = Gebruikersnaam bevat illegale karakters. | ||||
| illegal_repo_name = Repositorie naam bevat illegale karakters. | ||||
| illegal_org_name = Organisatie naam bevat illegale karakters. | ||||
| illegal_team_name = Team naam bevat illegale karakters. | ||||
| username_password_incorrect = Gebruikersnaam of wachtwoord is niet correct. | ||||
| enterred_invalid_repo_name = U heeft een onjuiste repositorie naam ingevoerd. | ||||
| enterred_invalid_owner_name = U heeft een onjuiste eigenaar ingevoerd. | ||||
| enterred_invalid_password = U heeft een onjuiste wachtwoord ingevoerd. | ||||
| user_not_exist = Gegeven gebruiker bestaat niet. | ||||
| last_org_owner = De gebruiker die u probeert te verwijderen is het enige lid (eigenaar) van dit team. U moet eerst nieuwe lid (eigenaar) aanstellen. | ||||
| invalid_ssh_key = Sorry, we zijn niet in staat om uw SSH-sleutel te verifiëren: %s | ||||
| auth_failed = Verificatie mislukt: %v | ||||
| still_own_repo = Uw account heeft nog een eigendom op een repositorie. U moet deze eerst verwijderen of overdragen. | ||||
| org_still_own_repo = De organisatie heeft nog eigendomen op repositories. U moet deze eerst verwijderen of overdragen. | ||||
| still_own_user = Deze authenticatie methode wordt nog gebruikt door sommige gebruikers. U moet hen eerst verplaatsen of verwijderen. | ||||
| AdminEmail = E-mail beheerder | ||||
| 
 | ||||
| [settings] | ||||
| profile = Profiel | ||||
| password = Wachtwoord | ||||
| ssh_keys = SSH-sleutels | ||||
| social = Sociale netwerk-accounts | ||||
| orgs = Organisaties | ||||
| delete = Verwijder account | ||||
| public_profile = Openbaar profiel | ||||
| profile_desc = Uw e-mailadres is openbaar zichtbaar en zal gebruikt worden gebruikt voor alle account gerlateerde berichtgevingen en web bewerking gemaakt via de website. | ||||
| full_name = Volledige naam | ||||
| website = Website | ||||
| location = Locatie | ||||
| update_profile = Profile bijwerken | ||||
| update_profile_success = Uw profiel is succesvol bijgewerkt. | ||||
| change_password = Verander wachtwoord | ||||
| old_password = Huidige wachtwoord | ||||
| new_password = Nieuw wachtwoord | ||||
| password_incorrect = Huidig wachtwoord is niet correct. | ||||
| change_password_success = Wachtwoord is succesvol gewijzigd. U kunt nu met uw nieuwe wachtwoord inloggen. | ||||
| manage_ssh_keys = Beheer SSH sleutels | ||||
| add_key = Sleutel toevoegen | ||||
| ssh_desc = Dit is een lijst van alle SSH sleutels die gekoppeld zijn aan uw account. Verwijder alle sleutels die u niet herkent. | ||||
| ssh_helper = <strong>Hulp nodig?</strong> Bekijk onze help pagina's over <a href="https://help.github.com/articles/generating-ssh-keys">SSH sleutels genereeren</a> of over <a href="https://help.github.com/ssh-issues/">meest voorkomende SSH problemen</a>. | ||||
| add_new_key = SSH sleutel toevoegen | ||||
| key_name = Sleutel naam | ||||
| key_content = Inhoud | ||||
| add_key_success = Nieuwe SSH sleutel is toegevoegd! | ||||
| delete_key = Verwijder | ||||
| add_on = Toegevoegd op | ||||
| last_used = Laatst gebruikt op | ||||
| no_activity = Geen recente activiteiten | ||||
| manage_social = Beheer gekoppelde sociale accounts | ||||
| social_desc = Dit is een lijst van de bijbehorende sociale accounts koppelingen, Verwijder eventueel koppelingen die u niet herkent. | ||||
| unbind = Loskoppelen | ||||
| unbind_success = Sociaal account is ontkoppeld. | ||||
| delete_account = Verwijder uw account | ||||
| delete_prompt = Deze handeling zal uw account definitief verwijderen, u kunt dit <strong> NIET </strong> terug draaien! | ||||
| confirm_delete_account = Bevestig verwijdering | ||||
| uid = uid | ||||
| change_username = Username veranderd | ||||
| change_username_desc = Gebruikersnaam is gewijzigd. Wilt u doorgaan? Dit zal gevolgen hebben voor alle koppelingen die betrekking hebben op uw account. | ||||
| continue = Doorgaan | ||||
| cancel = Annuleren | ||||
| delete_account_title = Account verwijderen | ||||
| delete_account_desc = Dit account zal permanent worden verwijderd. Wilt u doorgaan? | ||||
| 
 | ||||
| [repo] | ||||
| owner = Eigenaar | ||||
| repo_name = Repositorie naam | ||||
| repo_name_helper = Een goede repositorie naam is kort, memorabel en <strong>uniek</strong>. | ||||
| visibility = Zichtbaarheid | ||||
| visiblity_helper = Deze repositorie is <span class="label label-red label-radius">prive</span> | ||||
| repo_desc = Omschrijving | ||||
| repo_lang = Taal | ||||
| repo_lang_helper = Selecteer een .gitignore bestand | ||||
| license = Licentie | ||||
| license_helper = Selecteer een licentie bestand | ||||
| init_readme = Initialiseer deze repositorie met een README.md | ||||
| create_repo = Nieuwe Repositorie | ||||
| default_branch = Standaard branch | ||||
| mirror_interval = Mirror interval(uur) | ||||
| goget_meta = Go-Get Meta | ||||
| goget_meta_helper = Deze repositorie is nu beschikbaar voor <span class="label label-blue label-radius">Go-Get</span> | ||||
| need_auth = Autorisatie vereist | ||||
| migrate_type = Migratie type | ||||
| migrate_type_helper = Deze repositorie zal een <span class="label label-blue label-radius">mirror</span> worden | ||||
| migrate_repo = Migreer repositorie | ||||
| clone_helper = Hulp nodig bij het klonen? Kijk dan <a target="_blank" href="http://git-scm.com/book/en/Git-Basics-Getting-a-Git-Repository">hier</a> voor hulp! | ||||
| unwatch = Negeren | ||||
| watch = Volgen | ||||
| unstar = Ontster | ||||
| star = Ster | ||||
| fork = Fork | ||||
| settings = Instellingen | ||||
| settings.options = Opties | ||||
| settings.collaboration = Samenwerking | ||||
| settings.hooks = Webhooks | ||||
| settings.deploy_keys = Installeer sleutels | ||||
| settings.basic_settings = Basis instellingen | ||||
| settings.danger_zone = Gevaren zone | ||||
| settings.site = Officiële site | ||||
| settings.update_settings = Instellingen bewerken | ||||
| settings.transfer = Eigendom overdragen | ||||
| settings.transfer_desc = Draag deze repo over aan een andere gebruiker of een organisatie waar u beheerders rechten heeft. | ||||
| settings.delete = Verwijder deze repositorie | ||||
| settings.delete_desc = Als u eenmaal een repositorie verwijderd is er geen weg terug. Gelieve zeker te zijn van uw acties. | ||||
| settings.update_settings_success = Repositorie instellingen zijn succesvol bijgewerkt. | ||||
| settings.transfer_owner = Nieuwe eigenaar | ||||
| settings.make_transfer = Maak overdracht | ||||
| settings.confirm_delete = Bevestig verwijdering | ||||
| settings.add_collaborator = Nieuwe medewerker toevoegen | ||||
| settings.add_collaborator_success = medewerker is toegevoegd. | ||||
| settings.remove_collaborator_success = medewerker is verwijderd. | ||||
| settings.add_webhook = Webhook toevoegen | ||||
| settings.hooks_desc = Webhooks maken het mogelijk om externe diensten te waaarschuwen wanneer zich bepaalde gebeurtenissen voordoen op Gogs . Wanneer de opgegeven gebeurtenissen gebeuren , zullen we een POST-aanvraag aan alle URL's die u verstrekt sturen . Lees meer in onze <a target="_blank" href="http://gogs.io/docs/features/webhook.html"> Webhooks gids </a>. | ||||
| settings.remove_hook_success = Webhook is verwijderd. | ||||
| settings.add_webhook_desc = We sturen een <code>POST</code> verzoek aan de onderstaande URL met de details van het geplaatste evenementen. U kunt ook aangeven welke data u wilt ontvangen (JSON, <code>x-www-form-urlencoded</code>, <em>etc</em>). U kunt meer informatie vinden in onze <a target="_blank" href="http://gogs.io/docs/features/webhook.html"> webhooks gids</a>. | ||||
| settings.payload_url = Payload URL | ||||
| settings.content_type = Content type | ||||
| settings.secret = Geheim | ||||
| settings.event_desc = Bij welke gebeurtenissen wilt u dat deze webhook getriggerd wordt? | ||||
| settings.event_push_only = Alleen bij de <code>push</code> event. | ||||
| settings.active = Actief | ||||
| settings.active_helper = We zullen details van de gebeurtenissen af leveren wanneer deze webhook wordt geactiveerd. | ||||
| settings.add_hook_success = Nieuwe webhook toegevoegd. | ||||
| settings.update_webhook = Bewerk webhook | ||||
| settings.update_hook_success = Webhook is bijgewerkt. | ||||
| settings.delete_webhook = Webhook verwijderen | ||||
| settings.recent_deliveries = Recente bezorgingen | ||||
| copy_link = Kopieer | ||||
| click_to_copy = Kopieer link naar plakbord | ||||
| copied = Gekopieerd | ||||
| no_desc = Geen omschrijving | ||||
| quick_guide = Snelstart gids | ||||
| clone_this_repo = Kloon deze repositorie | ||||
| create_new_repo_command = Maak een nieuwe repositorie aan vanaf de console | ||||
| push_exist_repo = Push een bestaande repositorie vanaf de console | ||||
| branch = Aftakking | ||||
| tree = Boom | ||||
| branch_and_tags = Aftakkingen & labels | ||||
| branches = Aftakkingen | ||||
| tags = Labels | ||||
| issues = Issues | ||||
| commits = Commits | ||||
| releases = Publicaties | ||||
| commits.commits = Commits | ||||
| commits.search = Zoeken | ||||
| commits.find = zoek | ||||
| commits.author = Auteur | ||||
| commits.message = Bericht | ||||
| commits.date = Datum | ||||
| commits.older = Ouder | ||||
| commits.newer = Nieuwer | ||||
| settings.change_reponame = Repositorienaam aangepast | ||||
| settings.change_reponame_desc = De repositorienaam is veranderd. Wilt u doorgaan? Dit zal gevolgen hebben voor alle koppelingen die betrekking hebben op deze repositorie. | ||||
| settings.new_owner_has_same_repo = De nieuwe eigenaar heeft al een repositorie met deze naam | ||||
| settings.transfer_notices = <p> - U kan uw toegang verliezen als de nieuwe eigenaar een individuele gebruiker is</p> <p> - . .  U zal uw toegang behouden als de nieuwe eigenaar een organisatie is en u één van de eigenaren bent</p> | ||||
| settings.transfer_succeed = Eigendom repositorie succesvol overgedragen | ||||
| settings.hook_type = Type hook | ||||
| settings.add_slack_hook_desc = Voeg een <a href="http://slack.com">Slack</a> integratie toe aan uw repositorie. | ||||
| settings.slack_token = Slack token | ||||
| settings.slack_domain = Slack domein | ||||
| settings.slack_channel = Slack kanaal | ||||
| 
 | ||||
| [org] | ||||
| org_name_holder = Organisatienaam | ||||
| org_name_helper = Een goede organisatienaam is kort en memorabel. | ||||
| org_email_helper = Alle notificaties en bevestigingen worden op het e-mailadres van de organisatie ontvangen. | ||||
| create_org = Nieuwe organisatie aanmaken | ||||
| repo_updated = Geupdate | ||||
| people = Mensen | ||||
| invite_someone = Iemand uitnodigen | ||||
| teams = Teams | ||||
| lower_members = leden | ||||
| lower_repositories = repositories | ||||
| create_new_team = Nieuw team aanmaken | ||||
| org_desc = Omschrijving | ||||
| team_name = Teamnaam | ||||
| team_desc = Omschrijving | ||||
| team_name_helper = U gebruikt deze naam om dit team te vermelden in conversaties. | ||||
| team_desc_helper = Waar gaat dit team doen? | ||||
| team_permission_desc = Welke privileges zou dit team moeten hebben? | ||||
| settings = Instellingen | ||||
| settings.options = Opties | ||||
| settings.full_name = Volledige naam | ||||
| settings.website = Website | ||||
| settings.location = Locatie | ||||
| settings.update_settings = Instellingen bijwerken | ||||
| settings.update_setting_success = Organisatie instellingen zijn succesvol bijgewerkt. | ||||
| settings.delete = Verwijder organisatie | ||||
| settings.delete_account = Verwijder deze organisatie | ||||
| settings.delete_prompt = Deze actie zal de origanisatie permanent verwijderen. U kunt dit <strong>NIET</strong> terug draaien! | ||||
| settings.confirm_delete_account = Bevestig verwijdering | ||||
| members.public = Openbaar | ||||
| members.public_helper = maak prive | ||||
| members.private = Prive | ||||
| members.private_helper = maak openbaar | ||||
| members.owner = Eigenaar | ||||
| members.member = Lid | ||||
| members.conceal = Verbergen | ||||
| members.remove = Verwijderen | ||||
| members.leave = Verlaat | ||||
| members.invite_desc = Begin met het typen van een gebruikersnaam om een nieuw lid aan %s uit te nodigen: | ||||
| members.invite_now = Nu uitnodigen | ||||
| teams.join = Lid worden | ||||
| teams.leave = Vertlaat | ||||
| teams.read_access = Leestoegang | ||||
| teams.read_access_helper = Dit team is in staat om zijn repositories te bekijken en te klonen. | ||||
| teams.write_access = Schrijf toegang | ||||
| teams.write_access_helper = Dit team is in staat om zijn repositories te bekijken en push aanvragen te verwerken. | ||||
| teams.admin_access = Beheerder toegang | ||||
| teams.admin_access_helper = Dit team is in staat om push & pull aanvragen te verwerken en om nieuwe medewerkers toe te voegen. | ||||
| teams.no_desc = Dit team heeft geen omschrijving | ||||
| teams.settings = Instellingen | ||||
| teams.owners_permission_desc = Eigenaren hebben volledige toegang tot <strong>alle repositories</strong> en hebben <strong>beheerder rechten</strong> over de organisatie. | ||||
| teams.members = Team leden | ||||
| teams.update_settings = Instellingen bijwerken | ||||
| teams.delete_team = Verwijder deze team | ||||
| teams.add_team_member = Nieuwe team lid aanmaken | ||||
| teams.delete_team_success = Gekozen team is succesvol verwijderd. | ||||
| teams.read_permission_desc = Dit team heeft <strong>Lees</strong> rechten : leden kunnen repositories lezen en klonen. | ||||
| teams.write_permission_desc = Dit team heeft <strong>Schrijf</strong> rechten : leden kunnen repositories lezen en push aanvragen verwerken. | ||||
| teams.admin_permission_desc = Dit team heeft <strong>Beheerders</strong> rechten : leden kunnen repositories lezen en push aanvragen verwerken en medewerkers toevoegen. | ||||
| teams.repositories = Teamrepositories | ||||
| teams.add_team_repository = Nieuwe teamrepositorie aanmaken | ||||
| teams.remove_repo = Verwijder | ||||
| settings.change_orgname = Organisatie naam veranderd | ||||
| settings.change_orgname_desc = De naam van de organisatie is veranderd, wilt u doorgaan? Dit zal gevolgen hebben voor alle koppelingen die betrekking hebben op deze organisatie. | ||||
| settings.delete_org_title = Verwijderen organsiatie | ||||
| settings.delete_org_desc = Deze organisatie zal permanent worden verwijderd, wilt u doorgaan? | ||||
| settings.hooks_desc = Een webhook toevoegen die door <strong>alle repositories</strong> in deze organisatie getriggerd kan worden. | ||||
| teams.delete_team_title = Team verwijderen | ||||
| teams.delete_team_desc = Dit team zal worden verwijderd. De leden van dit team zullen toegang tot alle repositories van het team verliezen. Wilt u doorgaan? | ||||
| 
 | ||||
| [admin] | ||||
| dashboard = Dashboard | ||||
| users = Gebruikers | ||||
| organizations = Orgranisaties | ||||
| repositories = Repositories | ||||
| authentication = Autenticaties | ||||
| config = Configuratie | ||||
| monitor = Bijhouden | ||||
| prev = Vorige | ||||
| next = Volgende | ||||
| dashboard.statistic = Statistieken | ||||
| dashboard.operations = Bewerkingen | ||||
| dashboard.system_status = Status Systeemmonitor | ||||
| dashboard.statistic_info = Gogs database heeft <b>%d</b> gebruikers, <b>%d</b> organisaties, <b>%d</b> openbare sleutels, <b>%d</b> repositories, <b>%d</b> volgers, <b>%d</b> sterren, <b>%d</b> acties, <b>%d</b> participanten, <b>%d</b> issues, <b>%d</b> reacties, <b>%d</b> sociale accounten, <b>%d</b> volgers, <b>%d</b> mirrors, <b>%d</b> publicaties, <b>%d</b> login bronnen, <b>%d</b> webhooks, <b>%d</b> mijlpalen, <b>%d</b> labels, <b>%d</b> hook taken, <b>%d</b> teams, <b>%d</b> bijgewerkte taken, <b>%d</b> bijlagen. | ||||
| dashboard.operation_name = Bewerking naam | ||||
| dashboard.operation_switch = Omschakelen | ||||
| dashboard.operation_run = Uitvoeren | ||||
| dashboard.clean_unbind_oauth = Clean unbound OAuths | ||||
| dashboard.delete_inactivate_accounts = Verwijder alle inactieve accounts | ||||
| dashboard.server_uptime = Uptime server | ||||
| dashboard.current_goroutine = Huidige Goroutines | ||||
| dashboard.current_memory_usage = Huidige geheugen gebruik | ||||
| dashboard.total_memory_allocated = Totaal toegewezen geheugen | ||||
| dashboard.memory_obtained = Geheugen gebruikt | ||||
| dashboard.pointer_lookup_times = Pointer Lookup Times | ||||
| dashboard.memory_allocate_times = Memory Allocate Times | ||||
| dashboard.memory_free_times = Memory Free Times | ||||
| dashboard.current_heap_usage = Current Heap Usage | ||||
| dashboard.heap_memory_obtained = Heap Memory Obtained | ||||
| dashboard.heap_memory_idle = Heap Memory Idle | ||||
| dashboard.heap_memory_in_use = Heap Memory In Use | ||||
| dashboard.heap_memory_released = Heap Memory Released | ||||
| dashboard.heap_objects = Heap Objects | ||||
| dashboard.bootstrap_stack_usage = Bootstrap Stack Usage | ||||
| dashboard.stack_memory_obtained = Stack Memory Obtained | ||||
| dashboard.mspan_structures_usage = MSpan Structures Usage | ||||
| dashboard.mspan_structures_obtained = MSpan Structures Obtained | ||||
| dashboard.mcache_structures_usage = MCache Structures Usage | ||||
| dashboard.mcache_structures_obtained = MCache Structures Obtained | ||||
| dashboard.profiling_bucket_hash_table_obtained = Profiling Bucket Hash Table Obtained | ||||
| dashboard.gc_metadata_obtained = GC Metadada Obtained | ||||
| dashboard.other_system_allocation_obtained = Other System Allocation Obtained | ||||
| dashboard.next_gc_recycle = Volgende GC recycle | ||||
| dashboard.last_gc_time = Sinds vorige GC verwerkingstijd | ||||
| dashboard.total_gc_time = Totaal GC verwerkingstijd | ||||
| dashboard.total_gc_pause = Totaal GC verwerkingstijd | ||||
| dashboard.last_gc_pause = Laatste GC verwerkingstijd | ||||
| dashboard.gc_times = GC verwerkingen | ||||
| users.user_manage_panel = Gebruikers beheren | ||||
| users.new_account = Nieuw account aanmaken | ||||
| users.name = Naam | ||||
| users.activated = Geactiveerd | ||||
| users.admin = Admin | ||||
| users.repos = Repos | ||||
| users.created = Aangemaakt | ||||
| users.edit = Bewerken | ||||
| users.auth_source = Autorisatiebron | ||||
| users.local = Lokaal | ||||
| users.auth_login_name = Autorisatie inlognaam | ||||
| users.update_profile_success = Profiel is succesvol bijgewerkt. | ||||
| users.edit_account = Bewerk account | ||||
| users.is_activated = Dit account is geactiveerd | ||||
| users.is_admin = Dit account heeft beheerdersrechten | ||||
| users.update_profile = Account profiel bijwerken | ||||
| users.delete_account = Dit account verwijderen | ||||
| users.still_own_repo = Dit account is nog steeds eigendom van een repositorie. U moet deze repositorie eerst verwijderen of overdragen. | ||||
| orgs.org_manage_panel = Organisaties beheren | ||||
| orgs.name = Naam | ||||
| orgs.teams = Teams | ||||
| orgs.members = Leden | ||||
| repos.repo_manage_panel = Repositoriebeheerpaneel | ||||
| repos.owner = Eigenaar | ||||
| repos.name = Naam | ||||
| repos.private = Prive | ||||
| repos.watches = Volgers | ||||
| repos.stars = Sterren | ||||
| repos.issues = Issues | ||||
| auths.auth_manage_panel = Autorisatiebeheerpaneel | ||||
| auths.new = Nieuwe autorisatiebron | ||||
| auths.name = Naam | ||||
| auths.type = Type | ||||
| auths.enabled = Ingeschakeld | ||||
| auths.updated = Bijgewerkt | ||||
| auths.auth_type = Autorisatietype | ||||
| auths.auth_name = Autorisatienaam | ||||
| auths.domain = Domein | ||||
| auths.host = Host | ||||
| auths.port = Poort | ||||
| auths.base_dn = Base DN | ||||
| auths.attributes = Zoek attributen | ||||
| auths.filter = Zoek filter | ||||
| auths.ms_ad_sa = Ms Ad SA | ||||
| auths.smtp_auth = SMTP authenticatietype | ||||
| auths.smtphost = SMTP host | ||||
| auths.smtpport = SMTP poort | ||||
| auths.enable_tls = Activeer TLS-encryptie | ||||
| auths.enable_auto_register = Activeer automatische registratie | ||||
| auths.tips = Tips | ||||
| auths.edit = Bewerk autorisatie-instellingen | ||||
| auths.activated = Deze autorisatiemethode is geactiveerd | ||||
| auths.update_success = Autorisatie-instellingen zijn succesvol bijgewerkt. | ||||
| auths.update = Update autorisatie-instellingen | ||||
| auths.delete = Verwijder deze autorisatie | ||||
| config.server_config = Serverconfiguratie | ||||
| config.app_name = Applicatienaam | ||||
| config.app_ver = Applicatieversie | ||||
| config.app_url = Applicatie-URL | ||||
| config.domain = Domein | ||||
| config.offline_mode = Offline-modus | ||||
| config.disable_router_log = Router-log uitschakelen | ||||
| config.run_user = Uitvoerende gebruiker | ||||
| config.run_mode = Uitvoer modus | ||||
| config.repo_root_path = Repositorie basis pad | ||||
| config.static_file_root_path = Statische bestanden basis pad | ||||
| config.log_file_root_path = Log bestand basis pad | ||||
| config.script_type = Script type | ||||
| config.reverse_auth_user = Reverse Authentication User | ||||
| config.db_config = Databaseconfiguratie | ||||
| config.db_type = Type | ||||
| config.db_host = Host | ||||
| config.db_name = Naam | ||||
| config.db_user = Gebruiker | ||||
| config.db_ssl_mode = SSL modus | ||||
| config.db_ssl_mode_helper = (alleen voor "postgres") | ||||
| config.db_path = Path | ||||
| config.db_path_helper = (alleen voor "sqlite3") | ||||
| config.service_config = Serviceconfiguratie | ||||
| config.register_email_confirm = Register Email Confirmation | ||||
| config.disable_register = Registratie uitgeschakeld | ||||
| config.require_sign_in_view = Inloggen vereist om te kunnen inzien | ||||
| config.mail_notify = E-mailnotificaties | ||||
| config.enable_cache_avatar = Avatar Cache inschakelen | ||||
| config.active_code_lives = Active Code Lives | ||||
| config.reset_password_code_lives = Reset Password Code Lives | ||||
| config.webhook_config = Webhook configuratie | ||||
| config.task_interval = Taakinterval | ||||
| config.deliver_timeout = Bezorging verlooptijd | ||||
| config.mailer_config = Mailerconfiguatie | ||||
| config.mailer_enabled = Ingeschakeld | ||||
| config.mailer_name = Naam | ||||
| config.mailer_host = Host | ||||
| config.mailer_user = Gebruiker | ||||
| config.oauth_config = OAuth-configuratie | ||||
| config.oauth_enabled = Ingeschakeld | ||||
| config.cache_config = Cache-configuratie | ||||
| config.cache_adapter = Cache-adapter | ||||
| config.cache_interval = Cache-interval | ||||
| config.cache_conn = Cache-connectie | ||||
| config.session_config = Sessieconfiguratie | ||||
| config.session_provider = Sessieprovider | ||||
| config.provider_config = Provider config | ||||
| config.cookie_name = Cookie naam | ||||
| config.enable_set_cookie = Set Cookie inschakelen | ||||
| config.gc_interval_time = GC interval time | ||||
| config.session_life_time = Sessie duur | ||||
| config.https_only = Alleen HTTPS | ||||
| config.cookie_life_time = Cookie duur leeftijd | ||||
| config.session_hash_function = Sessie ID Hash functie | ||||
| config.session_hash_key = Sessie ID Hash sleutel | ||||
| config.picture_config = Foto configuratie | ||||
| config.picture_service = Foto service | ||||
| config.disable_gravatar = Gravatar uitschakelen | ||||
| config.log_config = Logconfiguratie | ||||
| config.log_mode = Log-modus | ||||
| monitor.cron = Cron-taken | ||||
| monitor.name = Naam | ||||
| monitor.schedule = Planning | ||||
| monitor.next = Volgende | ||||
| monitor.previous = Vorige | ||||
| monitor.execute_times = Aantal keren uitgevoerd | ||||
| monitor.process = Draaiende processen | ||||
| monitor.desc = Omschrijving | ||||
| monitor.start = Starttijd | ||||
| monitor.execute_time = Uitvoertijd | ||||
| auths.delete_auth_title = Verwijderings-autorisatie | ||||
| auths.delete_auth_desc = Deze autorisatiemethode wordt verwijderd. Weet u zeker dat u wilt doorgaan? | ||||
| 
 | ||||
| [action] | ||||
| create_repo = repositorie aangemaakt in <a href="%s/%s">%s</a> | ||||
| commit_repo = push update naar <a href="%s/%s/src/%s">%s</a> in <a href="%s/%s">%s</a | ||||
| create_issue = opende issue in <a href="%s/%s/issues/%s">%s#%s</a> | ||||
| comment_issue = reactie op issue <a href="%s/%s/issues/%s">%s#%s</a> | ||||
| transfer_repo = repositorie verplaatst naar <code>%s</code> naar <a href="/%s%s">%s</a> | ||||
| 
 | ||||
| [tool] | ||||
| ago = geleden | ||||
| from_now = vanaf nu | ||||
| now = nu | ||||
| 1s = 1 seconde %s | ||||
| 1m = 1 minuut %s | ||||
| 1h = 1 uur %s | ||||
| 1d = 1 dag %s | ||||
| 1w = 1 week %s | ||||
| 1mon = 1 maand %s | ||||
| 1y = 1 jaar %s | ||||
| seconds = %d seconden %s | ||||
| minutes = %d minuten %s | ||||
| hours = %d uur %s | ||||
| days = %d dagen %s | ||||
| weeks = %d weken %s | ||||
| months = %d maanden %s | ||||
| years = %d jaren %s | ||||
| raw_seconds = seconden | ||||
| raw_minutes = minuten | ||||
| 
 | ||||
| [install] | ||||
| install = Installatie | ||||
| title = Installatiestappen voor de eerste keer opstarten | ||||
| requite_db_desc = Om Gogs te gebruiken is MySQL, PostgreSQL of SQLite3 vereist (SQLite3 is beschikbaar in de officiële versie). | ||||
| db_type = Database-type | ||||
| host = Host | ||||
| user = Gebruikersnaam | ||||
| password = Wachtwoord | ||||
| db_name = Database naam | ||||
| db_helper = Gebruik InnoDB engine met utf8_general_ci karakterset voor MySQL. | ||||
| ssl_mode = SSL-modus | ||||
| path = Pad | ||||
| sqlite_helper = Het pad naar de SQLite3 database. | ||||
| general_title = Algemene instellingen van Gogs | ||||
| repo_path = Repositories basis directorie | ||||
| repo_path_helper = Alle remote Git repositories worden in deze directorie opgeslagen | ||||
| run_user = Uitvoerende gebruikersnaam | ||||
| run_user_helper = Deze gebruiker moet toegang hebben tot de git repositorie directorie en moet Gogs kunnen starten | ||||
| domain = Domein | ||||
| domain_helper = Dit heeft invloed op de SSH kloon URLs | ||||
| app_url = Applicatie URL | ||||
| app_url_helper = Dit heeft invloed op de HTTP/HTTPS kloon urls en de urls die in de email worden gebruikt | ||||
| email_title = Email service instellingen (Optioneel) | ||||
| smtp_host = SMTP host | ||||
| mailer_user = Afzender e-mail / gebruikersnaam | ||||
| mailer_password = Wachtwoord | ||||
| notify_title = Notificatie-instelligen (optioneel) | ||||
| register_confirm = Activeer registratie emails | ||||
| mail_notify = Activeer e-mailnotificaties | ||||
| admin_title = Instellingen beheerdersaccount | ||||
| admin_name = Gebruikersnaam | ||||
| admin_password = Wachtwoord | ||||
| confirm_password = Verifieer wachtwoord | ||||
| admin_email = E-mailadres | ||||
| install_gogs = Installeer Gogs | ||||
| test_git_failed = Git test niet gelukt: 'git' commando %v | ||||
| sqlite3_not_available = SQLite3 wordt niet ondersteund in uw versie. Gelieve de officiële versie downloaden vanaf http://gogs.io/docs/installation/install_from_binary.html, niet de gobuild versie downloaden. | ||||
| invalid_db_setting = Uw database instellingen zijn niet correct: %v | ||||
| invalid_repo_path = Repositorie basis pad is niet correct: %v | ||||
| run_user_not_match = De uitvoerende gebruiker is niet de huidig gebruiker: %s -> %s | ||||
| save_config_failed = Kan de configuratie niet opslaan: %v | ||||
| invalid_admin_setting = Uw admin-instellingen zijn niet geldig: %v | ||||
| install_success = Welkom! Wij zijn veheugd dat u voor Gogs heeft gekozen, veel plezier en tot ziens | ||||
| 
 | ||||
| [explore] | ||||
| repos = Repositories | ||||
| 
 | ||||
| [user] | ||||
| change_avatar = Verander uw avatar op Gravatar.com | ||||
| join_on = Aangemeld op | ||||
| repositories = repositories | ||||
| activity = Openbare activiteit | ||||
| followers = Volgers | ||||
| starred = Sterren | ||||
| following = Volgt | ||||
|  | @ -159,6 +159,7 @@ user_not_exist = 被操作的用户不存在! | |||
| last_org_owner = 被移除用户为最后一位管理员。请添加一位新的管理员再进行移除成员操作! | ||||
| 
 | ||||
| invalid_ssh_key = 很抱歉,我们无法验证您输入的 SSH 密钥:%s | ||||
| unable_verify_ssh_key = Gogs 无法验证您输入的 SSH 密钥,但我们假设那是有效的密钥,请您自行确保其有效性! | ||||
| auth_failed = 授权验证失败:%v | ||||
| 
 | ||||
| still_own_repo = 您的帐户仍然是某些仓库的拥有者,您必须先转移或删除它们才能执行删除帐户操作! | ||||
|  | @ -273,6 +274,9 @@ tags = 标签列表 | |||
| issues = 工单管理 | ||||
| commits = 提交历史 | ||||
| releases = 版本发布 | ||||
| file_raw = 原始文件 | ||||
| file_history = 文件历史 | ||||
| file_view_raw = 查看原始文件 | ||||
| 
 | ||||
| commits.commits = 次代码提交 | ||||
| commits.search = 搜索提交历史 | ||||
|  | @ -287,6 +291,7 @@ settings = 仓库设置 | |||
| settings.options = 基本设置 | ||||
| settings.collaboration = 管理协作者 | ||||
| settings.hooks = 管理 Web 钩子 | ||||
| settings.githooks = 管理 Git 钩子 | ||||
| settings.deploy_keys = 管理部署密钥 | ||||
| settings.basic_settings = 基本设置 | ||||
| settings.danger_zone = 危险操作区 | ||||
|  | @ -308,10 +313,16 @@ settings.confirm_delete = 确认删除仓库 | |||
| settings.add_collaborator = 增加新的协作者 | ||||
| settings.add_collaborator_success = 成功添加新的协作者! | ||||
| settings.remove_collaborator_success = 被操作的协作者已经被收回权限! | ||||
| settings.user_is_org_member = 被操作的用户是组织成员,因此无法添加为协作者! | ||||
| settings.add_webhook = 添加 Web 钩子 | ||||
| settings.hooks_desc = Web 钩子允许您设定在 Gogs 上发生指定事件时对指定 URL 发送 POST 通知。查看 <a target="_blank" href="http://gogs.io/docs/features/webhook.html">Webhooks 文档</a> 获取更多信息。 | ||||
| settings.remove_hook_success = Web 钩子删除成功! | ||||
| settings.add_webhook_desc = 我们会通过 <code>POST</code> 请求将订阅事件信息发送至向指定 URL 地址。您可以设置不同的数据接收方式(JSON 或 <code>x-www-form-urlencoded</code>)。 请查阅 <a target="_blank" href="http://gogs.io/docs/features/webhook.html">Webhooks 文档</a> 获取更多信息。 | ||||
| settings.githooks_desc = Git 钩子是由 Git 本身提供的功能,以下为 Gogs 所支持的钩子列表。 | ||||
| settings.githook_edit_desc = 如果钩子未启动,则会显示样例文件中的内容。如果想要删除某个钩子,则提交空白文本即可。 | ||||
| settings.githook_name = 钩子名称 | ||||
| settings.githook_content = 钩子文本 | ||||
| settings.update_githook = 更新钩子设置 | ||||
| settings.payload_url = 推送地址 | ||||
| settings.content_type = 数据格式 | ||||
| settings.secret = 密钥文本 | ||||
|  | @ -330,6 +341,15 @@ settings.slack_token = 令牌 | |||
| settings.slack_domain = 域名 | ||||
| settings.slack_channel = 频道 | ||||
| 
 | ||||
| diff.browse_source = 浏览代码 | ||||
| diff.parent = 父节点 | ||||
| diff.commit = 当前提交 | ||||
| diff.data_not_available = 暂无可用数据 | ||||
| diff.show_diff_stats = 显示文件统计 | ||||
| diff.stats_desc = 共有 <strong> %d 个文件被更改</strong>,包括 <strong>%d 次插入</strong> 和 <strong>%d 次删除</strong> | ||||
| diff.bin = 二进制 | ||||
| diff.view_file = 查看文件 | ||||
| 
 | ||||
| [org] | ||||
| org_name_holder = 组织名称 | ||||
| org_name_helper = 伟大的组织都有一个简短而寓意深刻的名字。 | ||||
|  | @ -402,6 +422,7 @@ teams.admin_permission_desc = 该团队拥有一定的 <strong>管理</strong>  | |||
| teams.repositories = 团队仓库 | ||||
| teams.add_team_repository = 添加团队仓库 | ||||
| teams.remove_repo = 移除仓库 | ||||
| teams.add_nonexistent_repo = 您尝试添加到团队的仓库不存在,请先创建仓库! | ||||
| 
 | ||||
| [admin] | ||||
| dashboard = 控制面板 | ||||
|  | @ -410,6 +431,7 @@ organizations = 组织管理 | |||
| repositories = 仓库管理 | ||||
| authentication = 授权认证管理 | ||||
| config = 应用配置管理 | ||||
| notices = 系统提示管理 | ||||
| monitor = 应用监控面板 | ||||
| prev = 上一页 | ||||
| next = 下一页 | ||||
|  | @ -587,12 +609,21 @@ monitor.desc = 进程描述 | |||
| monitor.start = 开始时间 | ||||
| monitor.execute_time = 已执行时间 | ||||
| 
 | ||||
| notices.system_notice_list = 系统提示管理 | ||||
| notices.type = 提示类型 | ||||
| notices.type_1 = 仓库 | ||||
| notices.desc = 描述 | ||||
| notices.op = 操作 | ||||
| notices.delete_success = 系统提示删除成功! | ||||
| 
 | ||||
| [action] | ||||
| create_repo = 创建了仓库 <a href="%s/%s">%s</a> | ||||
| commit_repo = 推送了 <a href="%s/%s/src/%s">%s</a> 分支的代码到 <a href="%s/%s">%s</a> | ||||
| create_issue = 创建了工单 <a href="%s/%s/issues/%s">%s#%s</a> | ||||
| comment_issue = 评论了工单 <a href="%s/%s/issues/%s">%s#%s</a> | ||||
| transfer_repo = 将仓库 <code>%s</code> 转移至 <a href="/%s%s">%s</a> | ||||
| push_tag = 推送了标签 <a href="%s/%s/src/%s">%s</a> 到 <a href="%s/%s">%s</a> | ||||
| compare_2_commits = 查看 2 次提交的内容对比 | ||||
| 
 | ||||
| [tool] | ||||
| ago = 之前 | ||||
|  |  | |||
|  | @ -0,0 +1,642 @@ | |||
| app_desc = 基於 Go 語言的自助 Git 服務 | ||||
| 
 | ||||
| home = 首頁 | ||||
| dashboard = 控制面版 | ||||
| explore = 探索 | ||||
| help = 幫助 | ||||
| sign_in = 登錄 | ||||
| social_sign_in = 社交帳號登錄:第 2 步 <small>關聯帳號</small> | ||||
| sign_out = 退出 | ||||
| sign_up = 註冊 | ||||
| register = 註冊 | ||||
| website = 官方網站 | ||||
| version = 當前版本 | ||||
| page = 頁面 | ||||
| template = 模版 | ||||
| language = 語言選項 | ||||
| 
 | ||||
| username = 用戶名 | ||||
| email = 郵箱 | ||||
| password = 密碼 | ||||
| re_type = 確認密碼 | ||||
| captcha = 驗證碼 | ||||
| 
 | ||||
| repository = 倉庫 | ||||
| organization = 組織 | ||||
| mirror = 鏡像 | ||||
| new_repo = 創建新的倉庫 | ||||
| new_migrate = 遷移外部倉庫 | ||||
| new_org = 創建新的組織 | ||||
| manage_org = 管理我的組織 | ||||
| admin_panel = 管理面版 | ||||
| account_settings = 帳戶設置 | ||||
| settings = 帳戶設置 | ||||
| 
 | ||||
| news_feed = 最新活動 | ||||
| pull_requests = 合併請求 | ||||
| issues = 問題管理 | ||||
| 
 | ||||
| cancel = 取消 | ||||
| 
 | ||||
| [install] | ||||
| install = 安裝頁面 | ||||
| title = 首次執行安裝程序 | ||||
| requite_db_desc = Gogs 允許後端數據庫為 MySQL、PostgreSQL 或 SQLite3,但是 SQLite3 一般只有官方二進制發行版才支持。 | ||||
| db_type = 數據庫類型 | ||||
| host = 數據庫主機 | ||||
| user = 數據庫用戶 | ||||
| password = 數據庫用戶密碼 | ||||
| db_name = 數據庫名稱 | ||||
| db_helper = 如果您使用 MySQL,請使用 INNODB 引擎以及 utf8_general_ci 字符集。 | ||||
| ssl_mode = SSL 模式 | ||||
| path = 數據庫文件路徑 | ||||
| sqlite_helper = SQLite3 數據庫的文件路徑。 | ||||
| general_title = 應用基本設置 | ||||
| repo_path = 倉庫根目錄 | ||||
| repo_path_helper = 所有 Git 遠程倉庫都將被存放於該目錄。 | ||||
| run_user = 執行系統用戶 | ||||
| run_user_helper = 該用戶必須具有對倉庫根目錄和執行 Gogs 的操作權限。 | ||||
| domain = 域名 | ||||
| domain_helper = 該設置影響 SSH 克隆地址。 | ||||
| app_url = 應用 URL | ||||
| app_url_helper = 該設置影響 HTTP/HTTPS 克隆地址和一些郵箱中的鏈接。 | ||||
| email_title = 郵件服務設置(可選) | ||||
| smtp_host = SMTP 主機 | ||||
| mailer_user = 發送郵箱 | ||||
| mailer_password = 發送郵箱密碼 | ||||
| notify_title = 通知提醒設置(可選) | ||||
| register_confirm = 啟用註冊郵箱確認 | ||||
| mail_notify = 啟用郵件通知提醒 | ||||
| admin_title = 管理員帳號設置 | ||||
| admin_name = 管理員用戶名 | ||||
| admin_password = 管理員密碼 | ||||
| confirm_password = 確認密碼 | ||||
| admin_email = 管理員郵箱 | ||||
| install_gogs = 立即安裝 | ||||
| test_git_failed = 無法識別 'git' 命令:%v | ||||
| sqlite3_not_available = 您所使用的發行版本不支持 SQLite3,請從 http://gogs.io/docs/installation/install_from_binary.html 下載官方二進制發行版本,而不是 gobuild 版本。 | ||||
| invalid_db_setting = 數據庫設置不正確:%v | ||||
| invalid_repo_path = 倉庫根目錄設置不正確:%v | ||||
| run_user_not_match = 執行系統用戶非當前用戶:%s -> %s | ||||
| save_config_failed = 應用配置保存失敗:%v | ||||
| invalid_admin_setting = 管理員帳戶設置不正確:%v | ||||
| install_success = 您好!我們很高興您選擇使用 Gogs,祝您使用愉快,代碼從此無 BUG! | ||||
| 
 | ||||
| [home] | ||||
| uname_holder = 用戶名或郵箱 | ||||
| password_holder = 密碼 | ||||
| switch_dashboard_context = 切換控制面版用戶 | ||||
| my_repos = 我的倉庫 | ||||
| collaborative_repos = 參與協作的倉庫 | ||||
| my_orgs = 我的組織 | ||||
| my_mirrors = 我的鏡像 | ||||
| 
 | ||||
| [explore] | ||||
| repos = 探索倉庫 | ||||
| 
 | ||||
| [auth] | ||||
| create_new_account = 創建帳戶 | ||||
| register_hepler_msg = 已經註冊?立即登錄! | ||||
| social_register_hepler_msg = 已經註冊?立即綁定! | ||||
| disable_register_prompt = 對不起,註冊功能已被關閉。請聯系網站管理員。 | ||||
| disable_register_mail = 對不起,註冊郵箱確認功能已被關閉。 | ||||
| remember_me = 記住登錄 | ||||
| forgot_password = 忘記密碼 | ||||
| forget_password = 忘記密碼? | ||||
| sign_up_now = 還沒帳戶?馬上註冊。 | ||||
| confirmation_mail_sent_prompt = 一封新的確認郵件已經被發送至 <b>%s</b>,請檢查您的收件箱並在 %d 小時內完成確認註冊操作。 | ||||
| sign_in_email = 登錄到您的郵箱 | ||||
| active_your_account = 激活您的帳戶 | ||||
| resent_limit_prompt = 對不起,您請求發送激活郵件過於頻繁,請等待 3 分鐘後再試! | ||||
| has_unconfirmed_mail = %s 您好,系統檢測到您有一封發送至 <b>%s</b> 但未被確認的郵件。如果您未收到激活郵件,或需要重新發送,請單擊下方的按鈕。 | ||||
| resend_mail = 單擊此處重新發送確認郵件 | ||||
| email_not_associate = 您輸入的郵箱地址未被關聯到任何帳號! | ||||
| send_reset_mail = 單擊此處(重新)發送您的密碼重置郵件 | ||||
| reset_password = 重置密碼 | ||||
| invalid_code = 對不起,您的確認代碼已過期或已失效。 | ||||
| reset_password_helper = 單擊此處重置密碼 | ||||
| password_too_short = 密碼長度不能少於 6 位! | ||||
| 
 | ||||
| [form] | ||||
| UserName = 用戶名 | ||||
| RepoName = 倉庫名稱 | ||||
| Email = 郵箱地址 | ||||
| Password = 密碼 | ||||
| Retype = 確認密碼 | ||||
| SSHTitle = SSH 密鑰名稱 | ||||
| HttpsUrl = HTTPS URL 地址 | ||||
| PayloadUrl = 推送地址 | ||||
| TeamName = 團隊名稱 | ||||
| AuthName = 認證名稱 | ||||
| AdminEmail = 管理員郵箱 | ||||
| 
 | ||||
| require_error = 不能為空。 | ||||
| alpha_dash_error = 必須為英文字母、阿拉伯數字或橫線(-_)。 | ||||
| alpha_dash_dot_error = 必須為英文字母、阿拉伯數字、橫線(-_)或點。 | ||||
| min_size_error = 長度最小為 %s 個字符。 | ||||
| max_size_error = 長度最大為 %s 個字符。 | ||||
| email_error = 不是一個有效的郵箱地址。 | ||||
| url_error = 不是一個有效的 URL。 | ||||
| unknown_error = 未知錯誤: | ||||
| captcha_incorrect = 驗證碼未匹配。 | ||||
| password_not_match = 密碼與確認密碼未匹配。 | ||||
| 
 | ||||
| username_been_taken = 用戶名已經被佔用。 | ||||
| repo_name_been_taken = 倉庫名稱已經被佔用。 | ||||
| org_name_been_taken = 組織名稱已經被佔用。 | ||||
| team_name_been_taken = 團隊名稱已經被佔用。 | ||||
| email_been_used = 郵箱地址已經被使用。 | ||||
| ssh_key_been_used = SSH 密鑰已經被使用。 | ||||
| illegal_username = 您的用戶名包含不合法字符。 | ||||
| illegal_repo_name = 倉庫名稱包含不合法字符。 | ||||
| illegal_org_name = 組織名稱包含不合法字符。 | ||||
| illegal_team_name = 團隊名稱包含不合法字符。 | ||||
| username_password_incorrect = 用戶名或密碼不正確。 | ||||
| enterred_invalid_repo_name = 請檢查您輸入的倉庫名稱是正確。 | ||||
| enterred_invalid_owner_name = 請檢查您輸入的新所有者用戶名是否正確。 | ||||
| enterred_invalid_password = 請檢查您輸入的密碼是否正確。 | ||||
| user_not_exist = 被操作的用戶不存在! | ||||
| last_org_owner = 被移除用戶為最後一位管理員。請添加一位新的管理員再進行移除成員操作! | ||||
| 
 | ||||
| invalid_ssh_key = 很抱歉,我們無法驗證您輸入的 SSH 密鑰:%s | ||||
| auth_failed = 授權驗證失敗:%v | ||||
| 
 | ||||
| still_own_repo = 您的帳戶仍然是某些倉庫的擁有者,您必須先轉移或刪除它們才能執行刪除帳戶操作! | ||||
| org_still_own_repo = 該組織仍然是某些倉庫的擁有者,您必須先轉移或刪除它們才能執行刪除組織操作! | ||||
| 
 | ||||
| still_own_user = 該授權認證依舊被部分用戶使用,請先刪除該部分用戶後再試! | ||||
| 
 | ||||
| [user] | ||||
| change_avatar = 到 gravatar.com 上修改您的頭像 | ||||
| join_on = 加入於 | ||||
| repositories = 倉庫列表 | ||||
| activity = 公開活動 | ||||
| followers = 關註者 | ||||
| starred = 已點讚 | ||||
| following = 關註中 | ||||
| 
 | ||||
| [settings] | ||||
| profile = 個人信息 | ||||
| password = 修改密碼 | ||||
| ssh_keys = 管理 SSH 密鑰 | ||||
| social = 社交帳號綁定 | ||||
| orgs = 管理組織 | ||||
| delete = 刪除帳戶 | ||||
| uid = 用戶 ID | ||||
| 
 | ||||
| public_profile = 公開信息 | ||||
| profile_desc = 您的郵箱地址將會被公開,並被用於接收帳戶的所有提醒和通知。 | ||||
| full_name = 自定義名稱 | ||||
| website = 個人網站 | ||||
| location = 所在地區 | ||||
| update_profile = 更新信息 | ||||
| update_profile_success = 您的個人信息更新成功! | ||||
| change_username = 用戶名將被修改 | ||||
| change_username_desc = 用戶名被修改,您確定要繼續操作嗎?這將會影響到所有與您帳戶有關的鏈接。 | ||||
| continue = 繼續操作 | ||||
| cancel = 取消操作 | ||||
| 
 | ||||
| change_password = 修改密碼 | ||||
| old_password = 當前密碼 | ||||
| new_password = 新的密碼 | ||||
| password_incorrect = 當前密碼不正確! | ||||
| change_password_success = 密碼修改成功!您現在可以使用新的密碼登錄。 | ||||
| 
 | ||||
| manage_ssh_keys = 管理 SSH 密鑰 | ||||
| add_key = 增加密鑰 | ||||
| ssh_desc = 以下是與您帳戶所關聯的 SSH 密鑰,如果您發現有陌生的密鑰,請立即刪除它! | ||||
| ssh_helper = <strong>需要幫助?</strong> 請查看有關 <a href="https://help.github.com/articles/generating-ssh-keys">如何生成 SSH 密鑰</a> 或 <a href="https://help.github.com/ssh-issues/">常見 SSH 問題</a> 尋找答案。 | ||||
| add_new_key = 增加 SSH 密鑰 | ||||
| key_name = 密鑰名稱 | ||||
| key_content = 密鑰內容 | ||||
| add_key_success = 新的 SSH 密鑰添加成功! | ||||
| delete_key = 刪除 | ||||
| add_on = 增加於 | ||||
| last_used = 上次使用在 | ||||
| no_activity = 沒有最近活動 | ||||
| 
 | ||||
| manage_social = 管理關聯社交帳戶 | ||||
| social_desc = 以下是與您帳戶所關聯的社交帳號,如果您發現有陌生的關聯,請立即解除綁定! | ||||
| unbind = 解除綁定 | ||||
| unbind_success = 社交帳號解除綁定成功! | ||||
| 
 | ||||
| delete_account = 刪除當前帳戶 | ||||
| delete_prompt = 刪除操作會永久清除您的帳戶信息,並且 <strong>不可恢復</strong>! | ||||
| confirm_delete_account = 確認刪除帳戶 | ||||
| delete_account_title = 帳戶刪除操作 | ||||
| delete_account_desc = 該帳戶將被永久性刪除,您確定要繼續操作嗎? | ||||
| 
 | ||||
| [repo] | ||||
| owner = 擁有者 | ||||
| repo_name = 倉庫名稱 | ||||
| repo_name_helper = 偉大的倉庫名稱一般都較短、令人深刻並且 <strong>獨一無二</strong> 的。 | ||||
| visibility = 可見度 | ||||
| visiblity_helper = 本倉庫將是 <span class="label label-red label-radius">私有的</span> | ||||
| repo_desc = 倉庫描述 | ||||
| repo_lang = 倉庫語言 | ||||
| repo_lang_helper = 請選擇 .gitignore 文件 | ||||
| license = 授權許可 | ||||
| license_helper = 請選擇授權許可文件 | ||||
| init_readme = 使用 README.md 文件初始化倉庫 | ||||
| create_repo = 創建倉庫 | ||||
| default_branch = 默認分支 | ||||
| mirror_interval = 鏡像同步周期(小時) | ||||
| goget_meta = Go-Get 支持 | ||||
| goget_meta_helper = 本倉庫將可以通過 <span class="label label-blue label-radius">Go Get</span> 獲取 | ||||
| 
 | ||||
| need_auth = 需要授權驗證 | ||||
| migrate_type = 遷移類型 | ||||
| migrate_type_helper = 本倉庫將是 <span class="label label-blue label-radius">鏡像</span> | ||||
| migrate_repo = 遷移倉庫 | ||||
| 
 | ||||
| copy_link = 復製鏈接 | ||||
| click_to_copy = 復製到剪切簿 | ||||
| copied = 復製成功 | ||||
| clone_helper = 不知道如何操作?訪問 <a target="_blank" href="http://git-scm.com/book/zh/Git-基礎-取得項目的-Git-倉庫">此處</a> 查看幫助! | ||||
| unwatch = 取消關註 | ||||
| watch = 關註 | ||||
| unstar = 取消點讚 | ||||
| star = 點讚 | ||||
| fork = 派生 | ||||
| 
 | ||||
| no_desc = 暫無描述 | ||||
| quick_guide = 快速幫助 | ||||
| clone_this_repo = 克隆當前倉庫 | ||||
| create_new_repo_command = 從命令行創建一個新的倉庫 | ||||
| push_exist_repo = 從命令行推送已經創建的倉庫 | ||||
| 
 | ||||
| branch = 分支 | ||||
| tree = 目錄樹 | ||||
| branch_and_tags = 分支與標籤 | ||||
| branches = 分支列表 | ||||
| tags = 標籤列表 | ||||
| issues = 問題管理 | ||||
| commits = 提交歷史 | ||||
| releases = 版本發佈 | ||||
| 
 | ||||
| commits.commits = 次代碼提交 | ||||
| commits.search = 搜索提交歷史 | ||||
| commits.find = 查找 | ||||
| commits.author = 作者 | ||||
| commits.message = 備註 | ||||
| commits.date = 提交日期 | ||||
| commits.older = 更舊的提交 | ||||
| commits.newer = 更新的提交 | ||||
| 
 | ||||
| settings = 倉庫設置 | ||||
| settings.options = 基本設置 | ||||
| settings.collaboration = 管理協作者 | ||||
| settings.hooks = 管理 Web 鉤子 | ||||
| settings.githooks = 管理 Git 鉤子 | ||||
| settings.deploy_keys = 管理部署密鑰 | ||||
| settings.basic_settings = 基本設置 | ||||
| settings.danger_zone = 危險操作區 | ||||
| settings.site = 官方網站 | ||||
| settings.update_settings = 更新倉庫設置 | ||||
| settings.change_reponame = 倉庫名稱將被修改 | ||||
| settings.change_reponame_desc = 倉庫名稱被修改,您確定要繼續操作嗎?這將會影響到所有與該倉庫有關的鏈接。 | ||||
| settings.transfer = 轉移倉庫所有權 | ||||
| settings.transfer_desc = 您可以將倉庫轉移至您擁有管理員權限的帳戶或組織。 | ||||
| settings.new_owner_has_same_repo = 新的倉庫擁有者已經存在同名倉庫! | ||||
| settings.delete = 刪除本倉庫 | ||||
| settings.delete_desc = 刪除倉庫操作不可逆轉,請三思而後行。 | ||||
| settings.transfer_notices = <p>- 如果您轉移給個人用戶,您將對倉庫失去所有權限。</p><p>- 如果您轉移給您作為擁有者的組織,則可繼續保持操作權限。</p> | ||||
| settings.update_settings_success = 倉庫設置更新成功! | ||||
| settings.transfer_owner = 新擁有者 | ||||
| settings.make_transfer = 確認轉移倉庫 | ||||
| settings.transfer_succeed = 倉庫所有權轉移成功! | ||||
| settings.confirm_delete = 確認刪除倉庫 | ||||
| settings.add_collaborator = 增加新的協作者 | ||||
| settings.add_collaborator_success = 成功添加新的協作者! | ||||
| settings.remove_collaborator_success = 被操作的協作者已經被收回權限! | ||||
| settings.add_webhook = 添加 Web 鉤子 | ||||
| settings.hooks_desc = Web 鉤子允許您設定在 Gogs 上發生指定事件時對指定 URL 發送 POST 通知。查看 <a target="_blank" href="http://gogs.io/docs/features/webhook.html">Webhooks 文檔</a> 獲取更多信息。 | ||||
| settings.remove_hook_success = Web 鉤子刪除成功! | ||||
| settings.add_webhook_desc = 我們會通過 <code>POST</code> 請求將訂閱事件信息發送至向指定 URL 地址。您可以設置不同的數據接收方式(JSON 或 <code>x-www-form-urlencoded</code>)。 請查閱 <a target="_blank" href="http://gogs.io/docs/features/webhook.html">Webhooks 文檔</a> 獲取更多信息。 | ||||
| settings.githooks_desc = Git 鉤子是由 Git 本身提供的功能,以下為 Gogs 所支持的鉤子列表。 | ||||
| settings.githook_edit_desc = 如果鉤子未啟動,則會顯示樣例文件中的內容。如果想要刪除某個鉤子,則提交空白文本即可。 | ||||
| settings.githook_name = 鉤子名稱 | ||||
| settings.githook_content = 鉤子文本 | ||||
| settings.update_githook = 更新鉤子設置 | ||||
| settings.payload_url = 推送地址 | ||||
| settings.content_type = 數據格式 | ||||
| settings.secret = 密鑰文本 | ||||
| settings.event_desc = 請設置您希望觸發 Web 鉤子的事件: | ||||
| settings.event_push_only = 只推送 <code>push</code> 事件。 | ||||
| settings.active = 是否激活 | ||||
| settings.active_helper = 當指定事件發生時我們將會觸發此 Web 鉤子。 | ||||
| settings.add_hook_success = Web 鉤子添加成功! | ||||
| settings.update_webhook = 更新 Web 鉤子 | ||||
| settings.update_hook_success = Web 鉤子更新成功! | ||||
| settings.delete_webhook = 刪除 Web 鉤子 | ||||
| settings.recent_deliveries = 最近推送記錄 | ||||
| settings.hook_type = 鉤子類型 | ||||
| settings.add_slack_hook_desc = 為您的倉庫增加 <a href="http://slack.com">Slack</a> 集成 | ||||
| settings.slack_token = 令牌 | ||||
| settings.slack_domain = 域名 | ||||
| settings.slack_channel = 頻道 | ||||
| 
 | ||||
| [org] | ||||
| org_name_holder = 組織名稱 | ||||
| org_name_helper = 偉大的組織都有一個簡短而寓意深刻的名字。 | ||||
| org_email_helper = 組織的郵箱用於接收所有通知和確認郵件。 | ||||
| create_org = 創建組織 | ||||
| repo_updated = 最後更新於 | ||||
| people = 組織成員 | ||||
| invite_someone = 邀請他人加入 | ||||
| teams = 組織團隊 | ||||
| lower_members = 名成員 | ||||
| lower_repositories = 個倉庫 | ||||
| create_new_team = 創建新的團隊 | ||||
| org_desc = 組織描述 | ||||
| team_name = 團隊名稱 | ||||
| team_desc = 團隊描述 | ||||
| team_name_helper = 您可以使用該名稱來通知改組全體成員。 | ||||
| team_desc_helper = 一句話描述這個團隊是做什麼的。 | ||||
| team_permission_desc = 請選擇該團隊所具有的權限等級: | ||||
| 
 | ||||
| settings = 組織設置 | ||||
| settings.options = 基本設置 | ||||
| settings.full_name = 組織全名 | ||||
| settings.website = 官方網站 | ||||
| settings.location = 所在地區 | ||||
| settings.update_settings = 更新組織設置 | ||||
| settings.change_orgname = 組織名稱將被修改 | ||||
| settings.change_orgname_desc = 組織名稱被修改,您確定要繼續操作嗎?這將會影響到所有與該組織有關的鏈接。 | ||||
| settings.update_setting_success = 組織設置更新成功! | ||||
| settings.delete = 刪除組織 | ||||
| settings.delete_account = 刪除當前組織 | ||||
| settings.delete_prompt = 刪除操作會永久清除該組織的信息,並且 <strong>不可恢復</strong>! | ||||
| settings.confirm_delete_account = 確認刪除組織 | ||||
| settings.delete_org_title = 組織刪除操作 | ||||
| settings.delete_org_desc = 該組織將被永久性刪除,您確定要繼續操作嗎? | ||||
| settings.hooks_desc = 在此處添加的 Web 鉤子將會應用到該組織下的 <strong>所有倉庫</strong>。 | ||||
| 
 | ||||
| members.public = 公開成員 | ||||
| members.public_helper = 設為私有 | ||||
| members.private = 私有成員 | ||||
| members.private_helper = 設為公開 | ||||
| members.owner = 管理員 | ||||
| members.member = 普通成員 | ||||
| members.conceal = 隱藏身份 | ||||
| members.remove = 移除成員 | ||||
| members.leave = 離開組織 | ||||
| members.invite_desc = 請輸入被邀請到組織 %s 的用戶名稱: | ||||
| members.invite_now = 立即邀請 | ||||
| 
 | ||||
| teams.join = 加入團隊 | ||||
| teams.leave = 離開團隊 | ||||
| teams.read_access = 讀取權限 | ||||
| teams.read_access_helper = 這個團隊將擁有查看和克隆所屬倉庫的權限。 | ||||
| teams.write_access =  寫入權限 | ||||
| teams.write_access_helper = 這個團隊將擁有查看、克隆和推送所屬倉庫的權限。 | ||||
| teams.admin_access = 管理權限 | ||||
| teams.admin_access_helper = 這個團隊將擁有查看、克隆、推送和添加其他組織成員到團隊的權限。 | ||||
| teams.no_desc = 該團隊暫無描述 | ||||
| teams.settings = 團隊設置 | ||||
| teams.owners_permission_desc = 管理員團隊對 <strong>所有倉庫</strong> 具有操作權限,且對組織具有 <strong>管理員權限</strong>。 | ||||
| teams.members = 團隊成員 | ||||
| teams.update_settings = 更新團隊設置 | ||||
| teams.delete_team = 刪除當前團隊 | ||||
| teams.add_team_member = 添加團隊成員 | ||||
| teams.delete_team_title = 團隊刪除操作 | ||||
| teams.delete_team_desc =  刪除操作會永久清除有關該團隊的信息,您確定要繼續操作嗎?團隊成員可能會失去對某些倉庫的操作權限。 | ||||
| teams.delete_team_success = 指定團隊刪除成功! | ||||
| teams.read_permission_desc = 該團隊擁有對所屬倉庫的 <strong>讀取</strong> 權限,團隊成員可以進行查看和克隆等只讀操作。 | ||||
| teams.write_permission_desc = 該團隊擁有對所屬倉庫的 <strong>讀取</strong> 和 <strong>寫入</strong> 的權限。 | ||||
| teams.admin_permission_desc = 該團隊擁有一定的 <strong>管理</strong> 權限,團隊成員可以讀取、克隆、推送以及添加其它倉庫協作者。 | ||||
| teams.repositories = 團隊倉庫 | ||||
| teams.add_team_repository = 添加團隊倉庫 | ||||
| teams.remove_repo = 移除倉庫 | ||||
| 
 | ||||
| [admin] | ||||
| dashboard = 控制面版 | ||||
| users = 用戶管理 | ||||
| organizations = 組織管理 | ||||
| repositories = 倉庫管理 | ||||
| authentication = 授權認證管理 | ||||
| config = 應用配置管理 | ||||
| notices = 系統提示管理 | ||||
| monitor = 應用監控面版 | ||||
| prev = 上一頁 | ||||
| next = 下一頁 | ||||
| 
 | ||||
| dashboard.statistic = 應用統計數據 | ||||
| dashboard.operations = 管理員操作 | ||||
| dashboard.system_status = 系統監視狀態 | ||||
| dashboard.statistic_info = Gogs 數據庫統計:<b>%d</b> 位用戶,<b>%d</b> 個組織,<b>%d</b> 個公鑰,<b>%d</b> 個倉庫,<b>%d</b> 個倉庫關註,<b>%d</b> 個贊,<b>%d</b> 次行為,<b>%d</b> 條權限記錄,<b>%d</b> 個問題,<b>%d</b> 次評論,<b>%d</b> 個社交帳號,<b>%d</b> 個用戶關註,<b>%d</b> 個鏡像,<b>%d</b> 個版本發佈,<b>%d</b> 個登錄源,<b>%d</b> 個 Web 鉤子,<b>%d</b> 個里程碑,<b>%d</b> 個標籤,<b>%d</b> 個鉤子任務,<b>%d</b> 個團隊,<b>%d</b> 個更新任務,<b>%d</b> 個附件。 | ||||
| dashboard.operation_name = 操作名稱 | ||||
| dashboard.operation_switch = 開關 | ||||
| dashboard.operation_run = 執行 | ||||
| dashboard.clean_unbind_oauth = 清理未綁定社交帳號 | ||||
| dashboard.delete_inactivate_accounts = 刪除所有未激活帳戶 | ||||
| dashboard.server_uptime = 服務執行時間 | ||||
| dashboard.current_goroutine = 當前 Goroutines 數量 | ||||
| dashboard.current_memory_usage = 當前內存使用量 | ||||
| dashboard.total_memory_allocated = 所有被分配的內存 | ||||
| dashboard.memory_obtained = 內存佔用量 | ||||
| dashboard.pointer_lookup_times = 指針查找次數 | ||||
| dashboard.memory_allocate_times = 內存分配次數 | ||||
| dashboard.memory_free_times = 內存釋放次數 | ||||
| dashboard.current_heap_usage = 當前 Heap 內存使用量 | ||||
| dashboard.heap_memory_obtained = Heap 內存佔用量 | ||||
| dashboard.heap_memory_idle = Heap 內存空閒量 | ||||
| dashboard.heap_memory_in_use = 正在使用的 Heap 內存 | ||||
| dashboard.heap_memory_released = 被釋放的 Heap 內存 | ||||
| dashboard.heap_objects = Heap 對象數量 | ||||
| dashboard.bootstrap_stack_usage = 啟動 Stack 使用量 | ||||
| dashboard.stack_memory_obtained = 被分配的 Stack 內存 | ||||
| dashboard.mspan_structures_usage = MSpan 結構內存使用量 | ||||
| dashboard.mspan_structures_obtained = 被分配的 MSpan 結構內存 | ||||
| dashboard.mcache_structures_usage = MCache 結構內存使用量 | ||||
| dashboard.mcache_structures_obtained = 被分配的 MCache 結構內存 | ||||
| dashboard.profiling_bucket_hash_table_obtained = 被分配的剖析哈希表內存 | ||||
| dashboard.gc_metadata_obtained = 被分配的垃圾收集元數據內存 | ||||
| dashboard.other_system_allocation_obtained = 其它被分配的系統內存 | ||||
| dashboard.next_gc_recycle = 下次垃圾收集內存回收量 | ||||
| dashboard.last_gc_time = 距離上次垃圾收集時間 | ||||
| dashboard.total_gc_time = 垃圾收集執行時間總量 | ||||
| dashboard.total_gc_pause = 垃圾收集暫停時間總量 | ||||
| dashboard.last_gc_pause = 上次垃圾收集暫停時間 | ||||
| dashboard.gc_times = 垃圾收集執行次數 | ||||
| 
 | ||||
| users.user_manage_panel = 用戶管理面版 | ||||
| users.new_account = 創建新的帳戶 | ||||
| users.name = 用戶名 | ||||
| users.activated = 已激活 | ||||
| users.admin = 管理員 | ||||
| users.repos = 倉庫數 | ||||
| users.created = 創建時間 | ||||
| users.edit = 編輯 | ||||
| users.auth_source = 認證源 | ||||
| users.local = 本地 | ||||
| users.auth_login_name = 認證登錄名 | ||||
| users.update_profile_success = 該用戶信息更新成功! | ||||
| users.edit_account = 編輯用戶信息 | ||||
| users.is_activated = 該用戶已被激活 | ||||
| users.is_admin = 該用戶具有管理員權限 | ||||
| users.update_profile = 更新用戶信息 | ||||
| users.delete_account = 刪除該用戶 | ||||
| users.still_own_repo = 該帳戶仍然是某些倉庫的擁有者,您必須先轉移或刪除它們才能執行刪除帳戶操作! | ||||
| 
 | ||||
| orgs.org_manage_panel = 組織管理面版 | ||||
| orgs.name = 組織名稱 | ||||
| orgs.teams = 團隊數 | ||||
| orgs.members = 成員數 | ||||
| 
 | ||||
| repos.repo_manage_panel = 倉庫管理界面 | ||||
| repos.owner = 所有者 | ||||
| repos.name = 倉庫名稱 | ||||
| repos.private = 私有庫 | ||||
| repos.watches = 關註數 | ||||
| repos.stars = 點讚數 | ||||
| repos.issues = 問題數 | ||||
| 
 | ||||
| auths.auth_manage_panel = 授權認證管理面版 | ||||
| auths.new = 添加新的認證源 | ||||
| auths.name = 認證名稱 | ||||
| auths.type = 認證類型 | ||||
| auths.enabled = 已啟用 | ||||
| auths.updated = 最後更新時間 | ||||
| auths.auth_type = 授權類型 | ||||
| auths.auth_name = 授權名稱 | ||||
| auths.domain = 域名 | ||||
| auths.host = 主機地址 | ||||
| auths.port = 主機端口 | ||||
| auths.base_dn = Base DN | ||||
| auths.attributes = 搜尋屬性 | ||||
| auths.filter = 搜尋過濾 | ||||
| auths.ms_ad_sa = Ms Ad SA | ||||
| auths.smtp_auth = SMTP 授權類型 | ||||
| auths.smtphost = SMTP 主機地址 | ||||
| auths.smtpport = SMTP 主機端口 | ||||
| auths.enable_tls = 啟用 TLS 加密 | ||||
| auths.enable_auto_register = 允許授權用戶自動註冊 | ||||
| auths.tips = 幫助提示 | ||||
| auths.edit = 修改授權認證設置 | ||||
| auths.activated = 該授權認證已經啟用 | ||||
| auths.update_success = 授權認證設置更新成功! | ||||
| auths.update = 更新授權認證信息 | ||||
| auths.delete = 刪除該授權認證 | ||||
| auths.delete_auth_title = 授權認證刪除操作 | ||||
| auths.delete_auth_desc = 該授權認證將被刪除,您確定要繼續嗎? | ||||
| 
 | ||||
| config.server_config = 服務器配置 | ||||
| config.app_name = 應用名稱 | ||||
| config.app_ver = 應用版本 | ||||
| config.app_url = 應用 URL | ||||
| config.domain = 應用域名 | ||||
| config.offline_mode = 離線模式 | ||||
| config.disable_router_log = 關閉路由日志 | ||||
| config.run_user = 執行用戶 | ||||
| config.run_mode = 執行模式 | ||||
| config.repo_root_path = 倉庫根目錄 | ||||
| config.static_file_root_path = 靜態文件根目錄 | ||||
| config.log_file_root_path = 日志文件根目錄 | ||||
| config.script_type = 腳本類型 | ||||
| config.reverse_auth_user = 反向代理認證 | ||||
| config.db_config = 數據庫配置 | ||||
| config.db_type = 數據庫類型 | ||||
| config.db_host = 主機地址 | ||||
| config.db_name = 數據庫名稱 | ||||
| config.db_user = 連接用戶 | ||||
| config.db_ssl_mode = SSL 模式 | ||||
| config.db_ssl_mode_helper = (僅限 "postgres" 使用) | ||||
| config.db_path = 數據庫路徑 | ||||
| config.db_path_helper = (僅限 "sqlite3" 使用) | ||||
| config.service_config = 服務配置 | ||||
| config.register_email_confirm = 註冊郵件確認 | ||||
| config.disable_register = 關閉註冊功能 | ||||
| config.require_sign_in_view = 強制登錄瀏覽 | ||||
| config.mail_notify = 郵件通知提醒 | ||||
| config.enable_cache_avatar = 開啟緩存頭像 | ||||
| config.active_code_lives = 激活用戶鏈接有效期 | ||||
| config.reset_password_code_lives = 重置密碼鏈接有效期 | ||||
| config.webhook_config = Web 鉤子配置 | ||||
| config.task_interval = 任務周期 | ||||
| config.deliver_timeout = 推送超時 | ||||
| config.mailer_config = 郵件配置 | ||||
| config.mailer_enabled = 啟用服務 | ||||
| config.mailer_name = 發送者名稱 | ||||
| config.mailer_host = 郵件主機地址 | ||||
| config.mailer_user = 發送者帳號 | ||||
| config.oauth_config = 社交帳號配置 | ||||
| config.oauth_enabled = 啟用服務 | ||||
| config.cache_config = Cache 配置 | ||||
| config.cache_adapter = Cache 適配器 | ||||
| config.cache_interval = Cache 周期 | ||||
| config.cache_conn = Cache 連接字符串 | ||||
| config.session_config = Session 配置 | ||||
| config.session_provider = Session 提供者 | ||||
| config.provider_config = 提供者配置 | ||||
| config.cookie_name = Cookie 名稱 | ||||
| config.enable_set_cookie = 啟用設置 Cookie | ||||
| config.gc_interval_time = 垃圾收集周期 | ||||
| config.session_life_time = Session 生命周期 | ||||
| config.https_only = 僅限 HTTPS | ||||
| config.cookie_life_time = Cookie 生命周期 | ||||
| config.session_hash_function = Session ID 哈希函數 | ||||
| config.session_hash_key = Session ID 哈希健值 | ||||
| config.picture_config = 圖片配置 | ||||
| config.picture_service = 圖片服務 | ||||
| config.disable_gravatar = 禁用 Gravatar 頭像 | ||||
| config.log_config = 日誌配置 | ||||
| config.log_mode = 日誌模式 | ||||
| 
 | ||||
| monitor.cron = Cron 任務 | ||||
| monitor.name = 任務名稱 | ||||
| monitor.schedule = 任務安排 | ||||
| monitor.next = 下次執行時間 | ||||
| monitor.previous = 上次執行時間 | ||||
| monitor.execute_times = 執行次數 | ||||
| monitor.process = 執行中進程 | ||||
| monitor.desc = 進程描述 | ||||
| monitor.start = 開始時間 | ||||
| monitor.execute_time = 已執行時間 | ||||
| 
 | ||||
| notices.system_notice_list = 系統提示管理 | ||||
| notices.type = 提示類型 | ||||
| notices.type_1 = 倉庫 | ||||
| notices.desc = 描述 | ||||
| notices.op = 操作 | ||||
| notices.delete_success = 系統提示刪除成功! | ||||
| 
 | ||||
| [action] | ||||
| create_repo = 創建了倉庫 <a href="%s/%s">%s</a> | ||||
| commit_repo = 推送了 <a href="%s/%s/src/%s">%s</a> 分支的代碼到 <a href="%s/%s">%s</a> | ||||
| create_issue = 創建了問題 <a href="%s/%s/issues/%s">%s#%s</a> | ||||
| comment_issue = 評論了問題 <a href="%s/%s/issues/%s">%s#%s</a> | ||||
| transfer_repo = 將倉庫 <code>%s</code> 轉移至 <a href="/%s%s">%s</a> | ||||
| 
 | ||||
| [tool] | ||||
| ago = 之前 | ||||
| from_now = 之後 | ||||
| now = 現在 | ||||
| 1s = 1 秒%s | ||||
| 1m = 1 分鐘%s | ||||
| 1h = 1 小時%s | ||||
| 1d = 1 天%s | ||||
| 1w = 1 周%s | ||||
| 1mon = 1 月%s | ||||
| 1y = 1 年%s | ||||
| seconds = %d 秒%s | ||||
| minutes = %d 分鐘%s | ||||
| hours = %d 小時%s | ||||
| days = %d 天%s | ||||
| weeks = %d 周%s | ||||
| months = %d 月%s | ||||
| years = %d 年%s | ||||
| raw_seconds = 秒 | ||||
| raw_minutes = 分鐘 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  | @ -1,12 +1,12 @@ | |||
| [unix_http_server] | ||||
| file=/tmp/supervisor.sock                       ; path to your socket file | ||||
| file=log/supervisor.sock                       ; path to your socket file | ||||
| 
 | ||||
| [supervisord] | ||||
| logfile=log/supervisord.log                    ; supervisord log file | ||||
| logfile_maxbytes=50MB                           ; maximum size of logfile before rotation | ||||
| logfile_backups=10                              ; number of backed up logfiles | ||||
| loglevel=warn                                   ; info, debug, warn, trace | ||||
| pidfile=/tmp/supervisord.pid                    ; pidfile location | ||||
| pidfile=log/supervisord.pid                    ; pidfile location | ||||
| nodaemon=false                                  ; run supervisord as a daemon | ||||
| minfds=1024                                     ; number of startup file descriptors | ||||
| minprocs=200                                    ; number of process descriptors | ||||
|  | @ -17,10 +17,10 @@ childlogdir=log | |||
| supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface | ||||
| 
 | ||||
| [supervisorctl] | ||||
| serverurl=unix:///tmp/supervisor.sock           ; use a unix:// URL  for a unix socket | ||||
| serverurl=unix://log/supervisor.sock           ; use a unix:// URL  for a unix socket | ||||
| 
 | ||||
| [program:gogs] | ||||
| command = /root/Developer/gopath/src/github.com/gogits/gogs/start.sh	; here must be the real url, not ~ or $GOROOT like | ||||
| command = gogs_start | ||||
| autostart = true | ||||
| stdout_logfile = log/supervisor-gogs-stderr.log | ||||
| stderr_logfile = log/supervisor-gogs-error.log | ||||
| stdout_logfile = log/supervisor-gogs-out.log | ||||
| stderr_logfile = log/supervisor-gogs-err.log | ||||
|  |  | |||
							
								
								
									
										2
									
								
								gogs.go
								
								
								
								
							
							
						
						
									
										2
									
								
								gogs.go
								
								
								
								
							|  | @ -17,7 +17,7 @@ import ( | |||
| 	"github.com/gogits/gogs/modules/setting" | ||||
| ) | ||||
| 
 | ||||
| const APP_VER = "0.5.4.1003 Beta" | ||||
| const APP_VER = "0.5.5.1013 Beta" | ||||
| 
 | ||||
| func init() { | ||||
| 	runtime.GOMAXPROCS(runtime.NumCPU()) | ||||
|  |  | |||
|  | @ -181,13 +181,19 @@ func CommitRepoAction(userId, repoUserId int64, userName, actEmail string, | |||
| 		commit = &base.PushCommits{} | ||||
| 	} | ||||
| 
 | ||||
| 	refName := git.RefEndName(refFullName) | ||||
| 	repoLink := fmt.Sprintf("%s%s/%s", setting.AppUrl, repoUserName, repoName) | ||||
| 	// if not the first commit, set the compareUrl
 | ||||
| 	if !strings.HasPrefix(oldCommitId, "0000000") { | ||||
| 		commit.CompareUrl = fmt.Sprintf("%s/compare/%s...%s", repoLink, oldCommitId, newCommitId) | ||||
| 	} | ||||
| 
 | ||||
| 	bs, err := json.Marshal(commit) | ||||
| 	if err != nil { | ||||
| 		return errors.New("action.CommitRepoAction(json): " + err.Error()) | ||||
| 	} | ||||
| 
 | ||||
| 	refName := git.RefEndName(refFullName) | ||||
| 
 | ||||
| 	// Change repository bare status and update last updated time.
 | ||||
| 	repo, err := GetRepositoryByName(repoUserId, repoName) | ||||
| 	if err != nil { | ||||
|  | @ -211,7 +217,6 @@ func CommitRepoAction(userId, repoUserId int64, userName, actEmail string, | |||
| 		return errors.New("action.CommitRepoAction(NotifyWatchers): " + err.Error()) | ||||
| 
 | ||||
| 	} | ||||
| 	//qlog.Info("action.CommitRepoAction(end): %d/%s", repoUserId, repoName)
 | ||||
| 
 | ||||
| 	// New push event hook.
 | ||||
| 	if err := repo.GetOwner(); err != nil { | ||||
|  | @ -237,13 +242,6 @@ func CommitRepoAction(userId, repoUserId int64, userName, actEmail string, | |||
| 		return nil | ||||
| 	} | ||||
| 
 | ||||
| 	repoLink := fmt.Sprintf("%s%s/%s", setting.AppUrl, repoUserName, repoName) | ||||
| 	compareUrl := "" | ||||
| 	// if not the first commit, set the compareUrl
 | ||||
| 	if !strings.HasPrefix(oldCommitId, "0000000") { | ||||
| 		compareUrl = fmt.Sprintf("%s/compare/%s...%s", repoLink, oldCommitId, newCommitId) | ||||
| 	} | ||||
| 
 | ||||
| 	pusher_email, pusher_name := "", "" | ||||
| 	pusher, err := GetUserByName(userName) | ||||
| 	if err == nil { | ||||
|  | @ -293,7 +291,7 @@ func CommitRepoAction(userId, repoUserId int64, userName, actEmail string, | |||
| 		}, | ||||
| 		Before:     oldCommitId, | ||||
| 		After:      newCommitId, | ||||
| 		CompareUrl: compareUrl, | ||||
| 		CompareUrl: commit.CompareUrl, | ||||
| 	} | ||||
| 
 | ||||
| 	for _, w := range ws { | ||||
|  |  | |||
|  | @ -0,0 +1,64 @@ | |||
| // Copyright 2014 The Gogs Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a MIT-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package models | ||||
| 
 | ||||
| import ( | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/Unknwon/com" | ||||
| ) | ||||
| 
 | ||||
| type NoticeType int | ||||
| 
 | ||||
| const ( | ||||
| 	NOTICE_REPOSITORY NoticeType = iota + 1 | ||||
| ) | ||||
| 
 | ||||
| // Notice represents a system notice for admin.
 | ||||
| type Notice struct { | ||||
| 	Id          int64 | ||||
| 	Type        NoticeType | ||||
| 	Description string    `xorm:"TEXT"` | ||||
| 	Created     time.Time `xorm:"CREATED"` | ||||
| } | ||||
| 
 | ||||
| // TrStr returns a translation format string.
 | ||||
| func (n *Notice) TrStr() string { | ||||
| 	return "admin.notices.type_" + com.ToStr(n.Type) | ||||
| } | ||||
| 
 | ||||
| // CreateNotice creates new system notice.
 | ||||
| func CreateNotice(tp NoticeType, desc string) error { | ||||
| 	n := &Notice{ | ||||
| 		Type:        tp, | ||||
| 		Description: desc, | ||||
| 	} | ||||
| 	_, err := x.Insert(n) | ||||
| 	return err | ||||
| } | ||||
| 
 | ||||
| // CreateRepositoryNotice creates new system notice with type NOTICE_REPOSITORY.
 | ||||
| func CreateRepositoryNotice(desc string) error { | ||||
| 	return CreateNotice(NOTICE_REPOSITORY, desc) | ||||
| } | ||||
| 
 | ||||
| // CountNotices returns number of notices.
 | ||||
| func CountNotices() int64 { | ||||
| 	count, _ := x.Count(new(Notice)) | ||||
| 	return count | ||||
| } | ||||
| 
 | ||||
| // GetNotices returns given number of notices with offset.
 | ||||
| func GetNotices(num, offset int) ([]*Notice, error) { | ||||
| 	notices := make([]*Notice, 0, num) | ||||
| 	err := x.Limit(num, offset).Desc("id").Find(¬ices) | ||||
| 	return notices, err | ||||
| } | ||||
| 
 | ||||
| // DeleteNotice deletes a system notice by given ID.
 | ||||
| func DeleteNotice(id int64) error { | ||||
| 	_, err := x.Id(id).Delete(new(Notice)) | ||||
| 	return err | ||||
| } | ||||
|  | @ -31,12 +31,12 @@ var ( | |||
| ) | ||||
| 
 | ||||
| func init() { | ||||
| 	tables = append(tables, new(User), new(PublicKey), | ||||
| 	tables = append(tables, new(User), new(PublicKey), new(Follow), new(Oauth2), | ||||
| 		new(Repository), new(Watch), new(Star), new(Action), new(Access), | ||||
| 		new(Issue), new(Comment), new(Oauth2), new(Follow), | ||||
| 		new(Mirror), new(Release), new(LoginSource), new(Webhook), new(IssueUser), | ||||
| 		new(Milestone), new(Label), new(HookTask), new(Team), new(OrgUser), new(TeamUser), | ||||
| 		new(UpdateTask), new(Attachment)) | ||||
| 		new(Issue), new(Comment), new(Attachment), new(IssueUser), new(Label), new(Milestone), | ||||
| 		new(Mirror), new(Release), new(LoginSource), new(Webhook), | ||||
| 		new(UpdateTask), new(HookTask), new(Team), new(OrgUser), new(TeamUser), | ||||
| 		new(Notice)) | ||||
| } | ||||
| 
 | ||||
| func LoadModelsConfig() { | ||||
|  |  | |||
|  | @ -845,20 +845,9 @@ func IsTeamMember(orgId, teamId, uid int64) bool { | |||
| 
 | ||||
| // GetTeamMembers returns all members in given team of organization.
 | ||||
| func GetTeamMembers(orgId, teamId int64) ([]*User, error) { | ||||
| 	tus := make([]*TeamUser, 0, 10) | ||||
| 	err := x.Where("org_id=?", orgId).And("team_id=?", teamId).Find(&tus) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	us := make([]*User, len(tus)) | ||||
| 	for i, tu := range tus { | ||||
| 		us[i], err = GetUserById(tu.Uid) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} | ||||
| 	return us, nil | ||||
| 	us := make([]*User, 0, 10) | ||||
| 	err := x.Sql("SELECT * FROM `user` JOIN `team_user` ON `team_user`.`team_id` = ? AND `team_user`.`uid` = `user`.`id`", teamId).Find(&us) | ||||
| 	return us, err | ||||
| } | ||||
| 
 | ||||
| // GetUserTeams returns all teams that user belongs to in given origanization.
 | ||||
|  |  | |||
|  | @ -33,6 +33,7 @@ const ( | |||
| var ( | ||||
| 	ErrKeyAlreadyExist = errors.New("Public key already exist") | ||||
| 	ErrKeyNotExist     = errors.New("Public key does not exist") | ||||
| 	ErrKeyUnableVerify = errors.New("Unable to verify public key") | ||||
| ) | ||||
| 
 | ||||
| var sshOpLocker = sync.Mutex{} | ||||
|  | @ -108,7 +109,7 @@ var ( | |||
| // CheckPublicKeyString checks if the given public key string is recognized by SSH.
 | ||||
| func CheckPublicKeyString(content string) (bool, error) { | ||||
| 	if strings.ContainsAny(content, "\n\r") { | ||||
| 		return false, errors.New("Only a single line with a single key please") | ||||
| 		return false, errors.New("only a single line with a single key please") | ||||
| 	} | ||||
| 
 | ||||
| 	// write the key to a file…
 | ||||
|  | @ -126,7 +127,7 @@ func CheckPublicKeyString(content string) (bool, error) { | |||
| 	if err != nil { | ||||
| 		return false, errors.New("ssh-keygen -l -f: " + stderr) | ||||
| 	} else if len(stdout) < 2 { | ||||
| 		return false, errors.New("ssh-keygen returned not enough output to evaluate the key") | ||||
| 		return false, errors.New("ssh-keygen returned not enough output to evaluate the key: " + stdout) | ||||
| 	} | ||||
| 
 | ||||
| 	// The ssh-keygen in Windows does not print key type, so no need go further.
 | ||||
|  | @ -134,21 +135,22 @@ func CheckPublicKeyString(content string) (bool, error) { | |||
| 		return true, nil | ||||
| 	} | ||||
| 
 | ||||
| 	fmt.Println(stdout) | ||||
| 	sshKeygenOutput := strings.Split(stdout, " ") | ||||
| 	if len(sshKeygenOutput) < 4 { | ||||
| 		return false, errors.New("Not enough fields returned by ssh-keygen -l -f") | ||||
| 		return false, ErrKeyUnableVerify | ||||
| 	} | ||||
| 
 | ||||
| 	// Check if key type and key size match.
 | ||||
| 	keySize, err := com.StrTo(sshKeygenOutput[0]).Int() | ||||
| 	if err != nil { | ||||
| 		return false, errors.New("Cannot get key size of the given key") | ||||
| 	keySize := com.StrTo(sshKeygenOutput[0]).MustInt() | ||||
| 	if keySize == 0 { | ||||
| 		return false, errors.New("cannot get key size of the given key") | ||||
| 	} | ||||
| 	keyType := strings.TrimSpace(sshKeygenOutput[len(sshKeygenOutput)-1]) | ||||
| 	if minimumKeySize := MinimumKeySize[keyType]; minimumKeySize == 0 { | ||||
| 		return false, errors.New("Sorry, unrecognized public key type") | ||||
| 		return false, errors.New("sorry, unrecognized public key type") | ||||
| 	} else if keySize < minimumKeySize { | ||||
| 		return false, fmt.Errorf("The minimum accepted size of a public key %s is %d", keyType, minimumKeySize) | ||||
| 		return false, fmt.Errorf("the minimum accepted size of a public key %s is %d", keyType, minimumKeySize) | ||||
| 	} | ||||
| 
 | ||||
| 	return true, nil | ||||
|  | @ -204,7 +206,7 @@ func AddPublicKey(key *PublicKey) (err error) { | |||
| 	if err != nil { | ||||
| 		return errors.New("ssh-keygen -l -f: " + stderr) | ||||
| 	} else if len(stdout) < 2 { | ||||
| 		return errors.New("Not enough output for calculating fingerprint") | ||||
| 		return errors.New("not enough output for calculating fingerprint: " + stdout) | ||||
| 	} | ||||
| 	key.Fingerprint = strings.Split(stdout, " ")[1] | ||||
| 
 | ||||
|  |  | |||
|  | @ -23,6 +23,7 @@ import ( | |||
| 	"github.com/Unknwon/cae/zip" | ||||
| 	"github.com/Unknwon/com" | ||||
| 
 | ||||
| 	"github.com/gogits/gogs/modules/base" | ||||
| 	"github.com/gogits/gogs/modules/git" | ||||
| 	"github.com/gogits/gogs/modules/log" | ||||
| 	"github.com/gogits/gogs/modules/process" | ||||
|  | @ -48,7 +49,7 @@ var ( | |||
| ) | ||||
| 
 | ||||
| var ( | ||||
| 	DescriptionPattern = regexp.MustCompile(`https?://\S+`) | ||||
| 	DescPattern = regexp.MustCompile(`https?://\S+`) | ||||
| ) | ||||
| 
 | ||||
| func LoadRepoConfig() { | ||||
|  | @ -165,7 +166,9 @@ type Repository struct { | |||
| } | ||||
| 
 | ||||
| func (repo *Repository) GetOwner() (err error) { | ||||
| 	repo.Owner, err = GetUserById(repo.OwnerId) | ||||
| 	if repo.Owner == nil { | ||||
| 		repo.Owner, err = GetUserById(repo.OwnerId) | ||||
| 	} | ||||
| 	return err | ||||
| } | ||||
| 
 | ||||
|  | @ -182,6 +185,14 @@ func (repo *Repository) IsOwnedBy(u *User) bool { | |||
|         return repo.OwnerId == u.Id | ||||
| } | ||||
| 
 | ||||
| func (repo *Repository) HasAccess(uname string) bool { | ||||
| 	if err := repo.GetOwner(); err != nil { | ||||
| 		return false | ||||
| 	} | ||||
| 	has, _ := HasAccess(uname, path.Join(repo.Owner.Name, repo.Name), READABLE) | ||||
| 	return has | ||||
| } | ||||
| 
 | ||||
| // DescriptionHtml does special handles to description and return HTML string.
 | ||||
| func (repo *Repository) DescriptionHtml() template.HTML { | ||||
| 	sanitize := func(s string) string { | ||||
|  | @ -189,7 +200,7 @@ func (repo *Repository) DescriptionHtml() template.HTML { | |||
| 		ss := html.EscapeString(s) | ||||
| 		return fmt.Sprintf(`<a href="%s" target="_blank">%s</a>`, ss, ss) | ||||
| 	} | ||||
| 	return template.HTML(DescriptionPattern.ReplaceAllStringFunc(repo.Description, sanitize)) | ||||
| 	return template.HTML(DescPattern.ReplaceAllStringFunc(base.XSSString(repo.Description), sanitize)) | ||||
| } | ||||
| 
 | ||||
| // IsRepositoryExist returns true if the repository with given name under user has already existed.
 | ||||
|  | @ -660,7 +671,7 @@ func RepoPath(userName, repoName string) string { | |||
| func TransferOwnership(u *User, newOwner string, repo *Repository) error { | ||||
| 	newUser, err := GetUserByName(newOwner) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 		return fmt.Errorf("fail to get new owner(%s): %v", newOwner, err) | ||||
| 	} | ||||
| 
 | ||||
| 	// Check if new owner has repository with same name.
 | ||||
|  | @ -948,9 +959,14 @@ func DeleteRepository(uid, repoId int64, userName string) error { | |||
| 		sess.Rollback() | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	// Remove repository files.
 | ||||
| 	if err = os.RemoveAll(RepoPath(userName, repo.Name)); err != nil { | ||||
| 		sess.Rollback() | ||||
| 		return err | ||||
| 		desc := fmt.Sprintf("Fail to delete repository files(%s/%s): %v", userName, repo.Name, err) | ||||
| 		log.Warn(desc) | ||||
| 		if err = CreateRepositoryNotice(desc); err != nil { | ||||
| 			log.Error(4, "Fail to add notice: %v", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return sess.Commit() | ||||
| } | ||||
|  |  | |||
|  | @ -106,7 +106,7 @@ func Update(refName, oldCommitId, newCommitId, userName, repoUserName, repoName | |||
| 
 | ||||
| 		if err = CommitRepoAction(userId, ru.Id, userName, actEmail, | ||||
| 			repos.Id, repoUserName, repoName, refName, commit, oldCommitId, newCommitId); err != nil { | ||||
| 			log.GitLogger.Fatal(4, "runUpdate.models.CommitRepoAction: %s/%s:%v", repoUserName, repoName, err) | ||||
| 			log.GitLogger.Fatal(4, "CommitRepoAction: %s/%s:%v", repoUserName, repoName, err) | ||||
| 		} | ||||
| 		return err | ||||
| 	} | ||||
|  | @ -116,8 +116,8 @@ func Update(refName, oldCommitId, newCommitId, userName, repoUserName, repoName | |||
| 		return fmt.Errorf("runUpdate GetCommit of newCommitId: %v", err) | ||||
| 	} | ||||
| 
 | ||||
| 	// Push new branch.
 | ||||
| 	var l *list.List | ||||
| 	// if a new branch
 | ||||
| 	if isNew { | ||||
| 		l, err = newCommit.CommitsBefore() | ||||
| 		if err != nil { | ||||
|  | @ -134,7 +134,7 @@ func Update(refName, oldCommitId, newCommitId, userName, repoUserName, repoName | |||
| 		return fmt.Errorf("runUpdate.Commit repoId: %v", err) | ||||
| 	} | ||||
| 
 | ||||
| 	// if commits push
 | ||||
| 	// Push commits.
 | ||||
| 	commits := make([]*base.PushCommit, 0) | ||||
| 	var actEmail string | ||||
| 	for e := l.Front(); e != nil; e = e.Next() { | ||||
|  | @ -153,9 +153,8 @@ func Update(refName, oldCommitId, newCommitId, userName, repoUserName, repoName | |||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	//commits = append(commits, []string{lastCommit.Id().String(), lastCommit.Message()})
 | ||||
| 	if err = CommitRepoAction(userId, ru.Id, userName, actEmail, | ||||
| 		repos.Id, repoUserName, repoName, refName, &base.PushCommits{l.Len(), commits}, oldCommitId, newCommitId); err != nil { | ||||
| 		repos.Id, repoUserName, repoName, refName, &base.PushCommits{l.Len(), commits, ""}, oldCommitId, newCommitId); err != nil { | ||||
| 		return fmt.Errorf("runUpdate.models.CommitRepoAction: %s/%s:%v", repoUserName, repoName, err) | ||||
| 	} | ||||
| 	return nil | ||||
|  |  | |||
|  | @ -488,7 +488,7 @@ func GetUserByName(name string) (*User, error) { | |||
| 	return user, nil | ||||
| } | ||||
| 
 | ||||
| // GetUserEmailsByNames returns a slice of e-mails corresponds to names.
 | ||||
| // GetUserEmailsByNames returns a list of e-mails corresponds to names.
 | ||||
| func GetUserEmailsByNames(names []string) []string { | ||||
| 	mails := make([]string, 0, len(names)) | ||||
| 	for _, name := range names { | ||||
|  |  | |||
|  | @ -235,8 +235,22 @@ func UpdateHookTask(t *HookTask) error { | |||
| 	return err | ||||
| } | ||||
| 
 | ||||
| var ( | ||||
| 	// Prevent duplicate deliveries.
 | ||||
| 	// This happens with massive hook tasks cannot finish delivering
 | ||||
| 	// before next shooting starts.
 | ||||
| 	isShooting = false | ||||
| ) | ||||
| 
 | ||||
| // DeliverHooks checks and delivers undelivered hooks.
 | ||||
| // FIXME: maybe can use goroutine to shoot a number of them at same time?
 | ||||
| func DeliverHooks() { | ||||
| 	if isShooting { | ||||
| 		return | ||||
| 	} | ||||
| 	isShooting = true | ||||
| 	defer func() { isShooting = false }() | ||||
| 
 | ||||
| 	tasks := make([]*HookTask, 0, 10) | ||||
| 	timeout := time.Duration(setting.WebhookDeliverTimeout) * time.Second | ||||
| 	x.Where("is_delivered=?", false).Iterate(new(HookTask), | ||||
|  | @ -255,7 +269,7 @@ func DeliverHooks() { | |||
| 
 | ||||
| 			t.IsDelivered = true | ||||
| 
 | ||||
| 			// TODO: record response.
 | ||||
| 			// FIXME: record response.
 | ||||
| 			switch t.Type { | ||||
| 			case GOGS: | ||||
| 				{ | ||||
|  |  | |||
|  | @ -102,7 +102,7 @@ func (f *NewSlackHookForm) Validate(ctx *macaron.Context, errs *binding.Errors, | |||
| //          \/     \/            \/
 | ||||
| 
 | ||||
| type CreateIssueForm struct { | ||||
| 	IssueName   string `form:"title" binding:"Required;MaxSize(50)"` | ||||
| 	IssueName   string `form:"title" binding:"Required;MaxSize(255)"` | ||||
| 	MilestoneId int64  `form:"milestoneid"` | ||||
| 	AssigneeId  int64  `form:"assigneeid"` | ||||
| 	Labels      string `form:"labels"` | ||||
|  |  | |||
|  | @ -13,7 +13,8 @@ import ( | |||
| 	"regexp" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"github.com/gogits/gfm" | ||||
| 	"github.com/russross/blackfriday" | ||||
| 
 | ||||
| 	"github.com/gogits/gogs/modules/setting" | ||||
| ) | ||||
| 
 | ||||
|  | @ -74,7 +75,7 @@ func IsReadmeFile(name string) bool { | |||
| } | ||||
| 
 | ||||
| type CustomRender struct { | ||||
| 	gfm.Renderer | ||||
| 	blackfriday.Renderer | ||||
| 	urlPrefix string | ||||
| } | ||||
| 
 | ||||
|  | @ -154,39 +155,40 @@ func RenderSpecialLink(rawBytes []byte, urlPrefix string) []byte { | |||
| 
 | ||||
| func RenderRawMarkdown(body []byte, urlPrefix string) []byte { | ||||
| 	htmlFlags := 0 | ||||
| 	// htmlFlags |= gfm.HTML_USE_XHTML
 | ||||
| 	// htmlFlags |= gfm.HTML_USE_SMARTYPANTS
 | ||||
| 	// htmlFlags |= gfm.HTML_SMARTYPANTS_FRACTIONS
 | ||||
| 	// htmlFlags |= gfm.HTML_SMARTYPANTS_LATEX_DASHES
 | ||||
| 	// htmlFlags |= gfm.HTML_SKIP_HTML
 | ||||
| 	htmlFlags |= gfm.HTML_SKIP_STYLE | ||||
| 	htmlFlags |= gfm.HTML_SKIP_SCRIPT | ||||
| 	htmlFlags |= gfm.HTML_GITHUB_BLOCKCODE | ||||
| 	htmlFlags |= gfm.HTML_OMIT_CONTENTS | ||||
| 	// htmlFlags |= gfm.HTML_COMPLETE_PAGE
 | ||||
| 	// htmlFlags |= blackfriday.HTML_USE_XHTML
 | ||||
| 	// htmlFlags |= blackfriday.HTML_USE_SMARTYPANTS
 | ||||
| 	// htmlFlags |= blackfriday.HTML_SMARTYPANTS_FRACTIONS
 | ||||
| 	// htmlFlags |= blackfriday.HTML_SMARTYPANTS_LATEX_DASHES
 | ||||
| 	// htmlFlags |= blackfriday.HTML_SKIP_HTML
 | ||||
| 	htmlFlags |= blackfriday.HTML_SKIP_STYLE | ||||
| 	// htmlFlags |= blackfriday.HTML_SKIP_SCRIPT
 | ||||
| 	// htmlFlags |= blackfriday.HTML_GITHUB_BLOCKCODE
 | ||||
| 	htmlFlags |= blackfriday.HTML_OMIT_CONTENTS | ||||
| 	// htmlFlags |= blackfriday.HTML_COMPLETE_PAGE
 | ||||
| 	renderer := &CustomRender{ | ||||
| 		Renderer:  gfm.HtmlRenderer(htmlFlags, "", ""), | ||||
| 		Renderer:  blackfriday.HtmlRenderer(htmlFlags, "", ""), | ||||
| 		urlPrefix: urlPrefix, | ||||
| 	} | ||||
| 
 | ||||
| 	// set up the parser
 | ||||
| 	extensions := 0 | ||||
| 	extensions |= gfm.EXTENSION_NO_INTRA_EMPHASIS | ||||
| 	extensions |= gfm.EXTENSION_TABLES | ||||
| 	extensions |= gfm.EXTENSION_FENCED_CODE | ||||
| 	extensions |= gfm.EXTENSION_AUTOLINK | ||||
| 	extensions |= gfm.EXTENSION_STRIKETHROUGH | ||||
| 	extensions |= gfm.EXTENSION_HARD_LINE_BREAK | ||||
| 	extensions |= gfm.EXTENSION_SPACE_HEADERS | ||||
| 	extensions |= gfm.EXTENSION_NO_EMPTY_LINE_BEFORE_BLOCK | ||||
| 	extensions |= blackfriday.EXTENSION_NO_INTRA_EMPHASIS | ||||
| 	extensions |= blackfriday.EXTENSION_TABLES | ||||
| 	extensions |= blackfriday.EXTENSION_FENCED_CODE | ||||
| 	extensions |= blackfriday.EXTENSION_AUTOLINK | ||||
| 	extensions |= blackfriday.EXTENSION_STRIKETHROUGH | ||||
| 	extensions |= blackfriday.EXTENSION_HARD_LINE_BREAK | ||||
| 	extensions |= blackfriday.EXTENSION_SPACE_HEADERS | ||||
| 	extensions |= blackfriday.EXTENSION_NO_EMPTY_LINE_BEFORE_BLOCK | ||||
| 
 | ||||
| 	body = gfm.Markdown(body, renderer, extensions) | ||||
| 	body = blackfriday.Markdown(body, renderer, extensions) | ||||
| 	return body | ||||
| } | ||||
| 
 | ||||
| func RenderMarkdown(rawBytes []byte, urlPrefix string) []byte { | ||||
| 	body := RenderSpecialLink(rawBytes, urlPrefix) | ||||
| 	body = RenderRawMarkdown(body, urlPrefix) | ||||
| 	body = XSS(body) | ||||
| 	return body | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -5,7 +5,6 @@ | |||
| package base | ||||
| 
 | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"container/list" | ||||
| 	"encoding/json" | ||||
| 	"errors" | ||||
|  | @ -107,7 +106,6 @@ var TemplateFuncs template.FuncMap = map[string]interface{}{ | |||
| 		return a + b | ||||
| 	}, | ||||
| 	"ActionIcon": ActionIcon, | ||||
| 	"ActionDesc": ActionDesc, | ||||
| 	"DateFormat": DateFormat, | ||||
| 	"List":       List, | ||||
| 	"Mail2Domain": func(mail string) string { | ||||
|  | @ -162,19 +160,6 @@ func ActionIcon(opType int) string { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // FIXME: Legacy
 | ||||
| const ( | ||||
| 	TPL_CREATE_REPO    = `<a href="%s/user/%s">%s</a> created repository <a href="%s">%s</a>` | ||||
| 	TPL_COMMIT_REPO    = `<a href="%s/user/%s">%s</a> pushed to <a href="%s/src/%s">%s</a> at <a href="%s">%s</a>%s` | ||||
| 	TPL_COMMIT_REPO_LI = `<div><img src="%s?s=16" alt="user-avatar"/> <a href="%s/commit/%s" rel="nofollow">%s</a> %s</div>` | ||||
| 	TPL_CREATE_ISSUE   = `<a href="%s/user/%s">%s</a> opened issue <a href="%s/issues/%s">%s#%s</a> | ||||
| <div><img src="%s?s=16" alt="user-avatar"/> %s</div>` | ||||
| 	TPL_TRANSFER_REPO = `<a href="%s/user/%s">%s</a> transfered repository <code>%s</code> to <a href="%s">%s</a>` | ||||
| 	TPL_PUSH_TAG      = `<a href="%s/user/%s">%s</a> pushed tag <a href="%s/src/%s" rel="nofollow">%s</a> at <a href="%s">%s</a>` | ||||
| 	TPL_COMMENT_ISSUE = `<a href="%s/user/%s">%s</a> commented on issue <a href="%s/issues/%s">%s#%s</a> | ||||
| <div><img src="%s?s=16" alt="user-avatar"/> %s</div>` | ||||
| ) | ||||
| 
 | ||||
| type PushCommit struct { | ||||
| 	Sha1        string | ||||
| 	Message     string | ||||
|  | @ -183,8 +168,9 @@ type PushCommit struct { | |||
| } | ||||
| 
 | ||||
| type PushCommits struct { | ||||
| 	Len     int | ||||
| 	Commits []*PushCommit | ||||
| 	Len        int | ||||
| 	Commits    []*PushCommit | ||||
| 	CompareUrl string | ||||
| } | ||||
| 
 | ||||
| func ActionContent2Commits(act Actioner) *PushCommits { | ||||
|  | @ -195,52 +181,6 @@ func ActionContent2Commits(act Actioner) *PushCommits { | |||
| 	return push | ||||
| } | ||||
| 
 | ||||
| // FIXME: Legacy
 | ||||
| // ActionDesc accepts int that represents action operation type
 | ||||
| // and returns the description.
 | ||||
| func ActionDesc(act Actioner) string { | ||||
| 	actUserName := act.GetActUserName() | ||||
| 	email := act.GetActEmail() | ||||
| 	repoUserName := act.GetRepoUserName() | ||||
| 	repoName := act.GetRepoName() | ||||
| 	repoLink := repoUserName + "/" + repoName | ||||
| 	branch := act.GetBranch() | ||||
| 	content := act.GetContent() | ||||
| 	switch act.GetOpType() { | ||||
| 	case 1: // Create repository.
 | ||||
| 		return fmt.Sprintf(TPL_CREATE_REPO, setting.AppSubUrl, actUserName, actUserName, repoLink, repoName) | ||||
| 	case 5: // Commit repository.
 | ||||
| 		var push *PushCommits | ||||
| 		if err := json.Unmarshal([]byte(content), &push); err != nil { | ||||
| 			return err.Error() | ||||
| 		} | ||||
| 		buf := bytes.NewBuffer([]byte("\n")) | ||||
| 		for _, commit := range push.Commits { | ||||
| 			buf.WriteString(fmt.Sprintf(TPL_COMMIT_REPO_LI, AvatarLink(commit.AuthorEmail), repoLink, commit.Sha1, commit.Sha1[:7], commit.Message) + "\n") | ||||
| 		} | ||||
| 		if push.Len > 3 { | ||||
| 			buf.WriteString(fmt.Sprintf(`<div><a href="{{AppRootSubUrl}}/%s/%s/commits/%s" rel="nofollow">%d other commits >></a></div>`, actUserName, repoName, branch, push.Len)) | ||||
| 		} | ||||
| 		return fmt.Sprintf(TPL_COMMIT_REPO, setting.AppSubUrl, actUserName, actUserName, repoLink, branch, branch, repoLink, repoLink, | ||||
| 			buf.String()) | ||||
| 	case 6: // Create issue.
 | ||||
| 		infos := strings.SplitN(content, "|", 2) | ||||
| 		return fmt.Sprintf(TPL_CREATE_ISSUE, setting.AppSubUrl, actUserName, actUserName, repoLink, infos[0], repoLink, infos[0], | ||||
| 			AvatarLink(email), infos[1]) | ||||
| 	case 8: // Transfer repository.
 | ||||
| 		newRepoLink := content + "/" + repoName | ||||
| 		return fmt.Sprintf(TPL_TRANSFER_REPO, setting.AppSubUrl, actUserName, actUserName, repoLink, newRepoLink, newRepoLink) | ||||
| 	case 9: // Push tag.
 | ||||
| 		return fmt.Sprintf(TPL_PUSH_TAG, setting.AppSubUrl, actUserName, actUserName, repoLink, branch, branch, repoLink, repoLink) | ||||
| 	case 10: // Comment issue.
 | ||||
| 		infos := strings.SplitN(content, "|", 2) | ||||
| 		return fmt.Sprintf(TPL_COMMENT_ISSUE, setting.AppSubUrl, actUserName, actUserName, repoLink, infos[0], repoLink, infos[0], | ||||
| 			AvatarLink(email), infos[1]) | ||||
| 	default: | ||||
| 		return "invalid type" | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func DiffTypeToStr(diffType int) string { | ||||
| 	diffTypes := map[int]string{ | ||||
| 		1: "add", 2: "modify", 3: "del", | ||||
|  |  | |||
|  | @ -14,6 +14,7 @@ import ( | |||
| 	"hash" | ||||
| 	"html/template" | ||||
| 	"math" | ||||
| 	"regexp" | ||||
| 	"strings" | ||||
| 	"time" | ||||
| 
 | ||||
|  | @ -446,3 +447,29 @@ func DateFormat(t time.Time, format string) string { | |||
| 	format = replacer.Replace(format) | ||||
| 	return t.Format(format) | ||||
| } | ||||
| 
 | ||||
| type xssFilter struct { | ||||
| 	reg  *regexp.Regexp | ||||
| 	repl []byte | ||||
| } | ||||
| 
 | ||||
| var ( | ||||
| 	whiteSpace = []byte(" ") | ||||
| 	xssFilters = []xssFilter{ | ||||
| 		{regexp.MustCompile(`\ [ONon]\w*=["]*`), whiteSpace}, | ||||
| 		{regexp.MustCompile(`<[SCRIPTscript]{6}`), whiteSpace}, | ||||
| 		{regexp.MustCompile(`=[` + "`" + `'"]*[JAVASCRIPTjavascript \t\0
]*:`), whiteSpace}, | ||||
| 	} | ||||
| ) | ||||
| 
 | ||||
| // XSS goes through all the XSS filters to make user input content as safe as possible.
 | ||||
| func XSS(in []byte) []byte { | ||||
| 	for _, filter := range xssFilters { | ||||
| 		in = filter.reg.ReplaceAll(in, filter.repl) | ||||
| 	} | ||||
| 	return in | ||||
| } | ||||
| 
 | ||||
| func XSSString(in string) string { | ||||
| 	return string(XSS([]byte(in))) | ||||
| } | ||||
|  |  | |||
|  | @ -0,0 +1,111 @@ | |||
| // Copyright 2014 The Gogs Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a MIT-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package git | ||||
| 
 | ||||
| import ( | ||||
| 	"errors" | ||||
| 	"io/ioutil" | ||||
| 	"os" | ||||
| 	"path" | ||||
| 	"strings" | ||||
| ) | ||||
| 
 | ||||
| // hookNames is a list of Git hooks' name that are supported.
 | ||||
| var hookNames = []string{ | ||||
| 	"pre-applypatch", | ||||
| 	"applypatch-msg", | ||||
| 	"prepare-commit-msg", | ||||
| 	"commit-msg", | ||||
| 	"pre-commit", | ||||
| 	"pre-rebase", | ||||
| 	"post-commit", | ||||
| 	"post-receive", | ||||
| 	"post-update", | ||||
| } | ||||
| 
 | ||||
| var ( | ||||
| 	ErrNotValidHook = errors.New("not a valid Git hook") | ||||
| ) | ||||
| 
 | ||||
| // IsValidHookName returns true if given name is a valid Git hook.
 | ||||
| func IsValidHookName(name string) bool { | ||||
| 	for _, hn := range hookNames { | ||||
| 		if hn == name { | ||||
| 			return true | ||||
| 		} | ||||
| 	} | ||||
| 	return false | ||||
| } | ||||
| 
 | ||||
| // Hook represents a Git hook.
 | ||||
| type Hook struct { | ||||
| 	name     string | ||||
| 	IsActive bool   // Indicates whether repository has this hook.
 | ||||
| 	Content  string // Content of hook if it's active.
 | ||||
| 	Sample   string // Sample content from Git.
 | ||||
| 	path     string // Hook file path.
 | ||||
| } | ||||
| 
 | ||||
| // GetHook returns a Git hook by given name and repository.
 | ||||
| func GetHook(repoPath, name string) (*Hook, error) { | ||||
| 	if !IsValidHookName(name) { | ||||
| 		return nil, ErrNotValidHook | ||||
| 	} | ||||
| 	h := &Hook{ | ||||
| 		name: name, | ||||
| 		path: path.Join(repoPath, "hooks", name), | ||||
| 	} | ||||
| 	if isFile(h.path) { | ||||
| 		data, err := ioutil.ReadFile(h.path) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		h.IsActive = true | ||||
| 		h.Content = string(data) | ||||
| 	} else if isFile(h.path + ".sample") { | ||||
| 		data, err := ioutil.ReadFile(h.path + ".sample") | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		h.Sample = string(data) | ||||
| 	} | ||||
| 	return h, nil | ||||
| } | ||||
| 
 | ||||
| func (h *Hook) Name() string { | ||||
| 	return h.name | ||||
| } | ||||
| 
 | ||||
| // Update updates hook settings.
 | ||||
| func (h *Hook) Update() error { | ||||
| 	if len(strings.TrimSpace(h.Content)) == 0 { | ||||
| 		return os.Remove(h.path) | ||||
| 	} | ||||
| 	return ioutil.WriteFile(h.path, []byte(strings.Replace(h.Content, "\r", "", -1)), os.ModePerm) | ||||
| } | ||||
| 
 | ||||
| // ListHooks returns a list of Git hooks of given repository.
 | ||||
| func ListHooks(repoPath string) (_ []*Hook, err error) { | ||||
| 	if !isDir(path.Join(repoPath, "hooks")) { | ||||
| 		return nil, errors.New("hooks path does not exist") | ||||
| 	} | ||||
| 
 | ||||
| 	hooks := make([]*Hook, len(hookNames)) | ||||
| 	for i, name := range hookNames { | ||||
| 		hooks[i], err = GetHook(repoPath, name) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} | ||||
| 	return hooks, nil | ||||
| } | ||||
| 
 | ||||
| func (repo *Repository) GetHook(name string) (*Hook, error) { | ||||
| 	return GetHook(repo.Path, name) | ||||
| } | ||||
| 
 | ||||
| func (repo *Repository) Hooks() ([]*Hook, error) { | ||||
| 	return ListHooks(repo.Path) | ||||
| } | ||||
|  | @ -22,6 +22,9 @@ func (repo *Repository) IsTagExist(tagName string) bool { | |||
| 
 | ||||
| // GetTags returns all tags of given repository.
 | ||||
| func (repo *Repository) GetTags() ([]string, error) { | ||||
| 	if gitVer.AtLeast(MustParseVersion("2.0.0")) { | ||||
| 		return repo.getTagsReversed() | ||||
| 	} | ||||
| 	stdout, stderr, err := com.ExecCmdDir(repo.Path, "git", "tag", "-l") | ||||
| 	if err != nil { | ||||
| 		return nil, errors.New(stderr) | ||||
|  | @ -30,6 +33,15 @@ func (repo *Repository) GetTags() ([]string, error) { | |||
| 	return tags[:len(tags)-1], nil | ||||
| } | ||||
| 
 | ||||
| func (repo *Repository) getTagsReversed() ([]string, error) { | ||||
| 	stdout, stderr, err := com.ExecCmdDir(repo.Path, "git", "tag", "-l", "--sort=-v:refname") | ||||
| 	if err != nil { | ||||
| 		return nil, errors.New(stderr) | ||||
| 	} | ||||
| 	tags := strings.Split(stdout, "\n") | ||||
| 	return tags[:len(tags)-1], nil | ||||
| } | ||||
| 
 | ||||
| func (repo *Repository) CreateTag(tagName, idStr string) error { | ||||
| 	_, stderr, err := com.ExecCmdDir(repo.Path, "git", "tag", tagName, idStr) | ||||
| 	if err != nil { | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ package git | |||
| import ( | ||||
| 	"bytes" | ||||
| 	"container/list" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"strings" | ||||
| ) | ||||
|  | @ -46,3 +47,23 @@ func RefEndName(refStr string) string { | |||
| func filepathFromSHA1(rootdir, sha1 string) string { | ||||
| 	return filepath.Join(rootdir, "objects", sha1[:2], sha1[2:]) | ||||
| } | ||||
| 
 | ||||
| // isDir returns true if given path is a directory,
 | ||||
| // or returns false when it's a file or does not exist.
 | ||||
| func isDir(dir string) bool { | ||||
| 	f, e := os.Stat(dir) | ||||
| 	if e != nil { | ||||
| 		return false | ||||
| 	} | ||||
| 	return f.IsDir() | ||||
| } | ||||
| 
 | ||||
| // isFile returns true if given path is a file,
 | ||||
| // or returns false when it's a directory or does not exist.
 | ||||
| func isFile(filePath string) bool { | ||||
| 	f, e := os.Stat(filePath) | ||||
| 	if e != nil { | ||||
| 		return false | ||||
| 	} | ||||
| 	return !f.IsDir() | ||||
| } | ||||
|  |  | |||
|  | @ -74,6 +74,10 @@ func (v *Version) LessThan(that *Version) bool { | |||
| 	return v.Compare(that) < 0 | ||||
| } | ||||
| 
 | ||||
| func (v *Version) AtLeast(that *Version) bool { | ||||
| 	return v.Compare(that) >= 0 | ||||
| } | ||||
| 
 | ||||
| // GetVersion returns current Git version installed.
 | ||||
| func GetVersion() (*Version, error) { | ||||
| 	if gitVer != nil { | ||||
|  |  | |||
|  | @ -5,7 +5,9 @@ | |||
| package mailer | ||||
| 
 | ||||
| import ( | ||||
| 	"crypto/tls" | ||||
| 	"fmt" | ||||
| 	"net" | ||||
| 	"net/smtp" | ||||
| 	"strings" | ||||
| 
 | ||||
|  | @ -33,7 +35,7 @@ func (m Message) Content() string { | |||
| 	} | ||||
| 
 | ||||
| 	// create mail content
 | ||||
| 	content := "From: " + m.From + "<" + m.User + | ||||
| 	content := "From: \"" + m.From + "\" <" + m.User + | ||||
| 		">\r\nSubject: " + m.Subject + "\r\nContent-Type: " + contentType + "\r\n\r\n" + m.Body | ||||
| 	return content | ||||
| } | ||||
|  | @ -64,6 +66,53 @@ func processMailQueue() { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // sendMail allows mail with self-signed certificates.
 | ||||
| func sendMail(hostAddressWithPort string, auth smtp.Auth, from string, recipients []string, msgContent []byte) error { | ||||
| 	client, err := smtp.Dial(hostAddressWithPort) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	host, _, _ := net.SplitHostPort(hostAddressWithPort) | ||||
| 	tlsConn := &tls.Config{ | ||||
| 		InsecureSkipVerify: true, | ||||
| 		ServerName:         host, | ||||
| 	} | ||||
| 	if err = client.StartTLS(tlsConn); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	if auth != nil { | ||||
| 		if err = client.Auth(auth); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	if err = client.Mail(from); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	for _, rec := range recipients { | ||||
| 		if err = client.Rcpt(rec); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	w, err := client.Data() | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if _, err = w.Write([]byte(msgContent)); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	if err = w.Close(); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	return client.Quit() | ||||
| } | ||||
| 
 | ||||
| // Direct Send mail message
 | ||||
| func Send(msg *Message) (int, error) { | ||||
| 	log.Trace("Sending mails to: %s", strings.Join(msg.To, "; ")) | ||||
|  | @ -85,7 +134,7 @@ func Send(msg *Message) (int, error) { | |||
| 		num := 0 | ||||
| 		for _, to := range msg.To { | ||||
| 			body := []byte("To: " + to + "\r\n" + content) | ||||
| 			err := smtp.SendMail(setting.MailService.Host, auth, msg.From, []string{to}, body) | ||||
| 			err := sendMail(setting.MailService.Host, auth, msg.From, []string{to}, body) | ||||
| 			if err != nil { | ||||
| 				return num, err | ||||
| 			} | ||||
|  | @ -96,7 +145,7 @@ func Send(msg *Message) (int, error) { | |||
| 		body := []byte("To: " + strings.Join(msg.To, ";") + "\r\n" + content) | ||||
| 
 | ||||
| 		// send to multiple emails in one message
 | ||||
| 		err := smtp.SendMail(setting.MailService.Host, auth, msg.From, msg.To, body) | ||||
| 		err := sendMail(setting.MailService.Host, auth, msg.From, msg.To, body) | ||||
| 		if err != nil { | ||||
| 			return 0, err | ||||
| 		} else { | ||||
|  |  | |||
|  | @ -29,7 +29,6 @@ import ( | |||
| // Context represents context of a request.
 | ||||
| type Context struct { | ||||
| 	*macaron.Context | ||||
| 	i18n.Locale | ||||
| 	Cache   cache.Cache | ||||
| 	csrf    csrf.CSRF | ||||
| 	Flash   *session.Flash | ||||
|  | @ -76,12 +75,6 @@ type Context struct { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Query querys form parameter.
 | ||||
| func (ctx *Context) Query(name string) string { | ||||
| 	ctx.Req.ParseForm() | ||||
| 	return ctx.Req.Form.Get(name) | ||||
| } | ||||
| 
 | ||||
| // HasError returns true if error occurs in form validation.
 | ||||
| func (ctx *Context) HasApiError() bool { | ||||
| 	hasErr, ok := ctx.Data["HasError"] | ||||
|  | @ -162,7 +155,6 @@ func Contexter() macaron.Handler { | |||
| 	return func(c *macaron.Context, l i18n.Locale, cache cache.Cache, sess session.Store, f *session.Flash, x csrf.CSRF) { | ||||
| 		ctx := &Context{ | ||||
| 			Context: c, | ||||
| 			Locale:  l, | ||||
| 			Cache:   cache, | ||||
| 			csrf:    x, | ||||
| 			Flash:   f, | ||||
|  |  | |||
|  | @ -308,3 +308,13 @@ func RequireTrueOwner() macaron.Handler { | |||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // GitHookService checks if repsitory Git hooks service has been enabled.
 | ||||
| func GitHookService() macaron.Handler { | ||||
| 	return func(ctx *Context) { | ||||
| 		if !setting.Service.EnableGitHooks { | ||||
| 			ctx.Handle(404, "GitHookService", nil) | ||||
| 			return | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  |  | |||
|  | @ -275,6 +275,7 @@ var Service struct { | |||
| 	LdapAuth               bool | ||||
| 	ActiveCodeLives        int | ||||
| 	ResetPwdCodeLives      int | ||||
| 	EnableGitHooks         bool | ||||
| } | ||||
| 
 | ||||
| func newService() { | ||||
|  | @ -284,6 +285,7 @@ func newService() { | |||
| 	Service.RequireSignInView = Cfg.MustBool("service", "REQUIRE_SIGNIN_VIEW") | ||||
| 	Service.EnableCacheAvatar = Cfg.MustBool("service", "ENABLE_CACHE_AVATAR") | ||||
| 	Service.EnableReverseProxyAuth = Cfg.MustBool("service", "ENABLE_REVERSE_PROXY_AUTHENTICATION") | ||||
| 	Service.EnableGitHooks = Cfg.MustBool("service", "ENABLE_GIT_HOOKS") | ||||
| } | ||||
| 
 | ||||
| var logLevels = map[string]string{ | ||||
|  |  | |||
|  | @ -88,6 +88,7 @@ img.avatar-100 { | |||
|   z-index: 100; | ||||
|   font-size: 12px; | ||||
|   width: 120%; | ||||
|   min-width: 100px; | ||||
| } | ||||
| #footer-lang .drop-down li > a { | ||||
|   padding: 3px 9px; | ||||
|  | @ -270,6 +271,10 @@ img.avatar-100 { | |||
| .pagination li { | ||||
|   display: inline; | ||||
| } | ||||
| .list-unstyled { | ||||
|   padding-left: 0; | ||||
|   list-style: none; | ||||
| } | ||||
| .markdown { | ||||
|   background-color: white; | ||||
|   font-size: 16px; | ||||
|  | @ -1397,12 +1402,10 @@ The register and sign-in page style | |||
| } | ||||
| .code-view .lines-num span { | ||||
|   font-family: Monaco, Menlo, Consolas, "Courier New", monospace; | ||||
|   line-height: 18px; | ||||
|   padding: 0 8px 0 10px; | ||||
|   line-height: 1.6; | ||||
|   padding: 0 10px; | ||||
|   cursor: pointer; | ||||
|   display: block; | ||||
|   margin-top: 2px; | ||||
|   font-size: 12px; | ||||
| } | ||||
| .code-view .lines-code > pre { | ||||
|   border: none; | ||||
|  | @ -1486,6 +1489,106 @@ The register and sign-in page style | |||
|   font-family: Consolas, Menlo, Monaco, "Lucida Console", monospace; | ||||
|   font-size: 14px; | ||||
| } | ||||
| .diff-head-box { | ||||
|   margin-top: 10px; | ||||
| } | ||||
| .diff-head-box .panel-body { | ||||
|   padding: 10px 15px 5px 10px; | ||||
| } | ||||
| .diff-head-box .author img { | ||||
|   margin-top: -7px; | ||||
| } | ||||
| .diff-detail-box { | ||||
|   margin: 15px 0; | ||||
|   line-height: 30px; | ||||
| } | ||||
| .diff-detail-box ol { | ||||
|   clear: both; | ||||
|   padding-left: 0; | ||||
|   margin-bottom: 28px; | ||||
| } | ||||
| .diff-detail-box ol li { | ||||
|   list-style: none; | ||||
|   padding-bottom: 4px; | ||||
|   margin-bottom: 4px; | ||||
|   border-bottom: 1px dashed #DDD; | ||||
|   padding-left: 6px; | ||||
| } | ||||
| .diff-detail-box span.status { | ||||
|   display: inline-block; | ||||
|   width: 12px; | ||||
|   height: 12px; | ||||
|   margin-right: 8px; | ||||
|   vertical-align: middle; | ||||
| } | ||||
| .diff-detail-box span.status.modify { | ||||
|   background-color: #f0db88; | ||||
| } | ||||
| .diff-detail-box span.status.add { | ||||
|   background-color: #b4e2b4; | ||||
| } | ||||
| .diff-detail-box span.status.del { | ||||
|   background-color: #e9aeae; | ||||
| } | ||||
| .diff-detail-box span.status.rename { | ||||
|   background-color: #dad8ff; | ||||
| } | ||||
| .diff-box .count { | ||||
|   margin-right: 12px; | ||||
| } | ||||
| .diff-box .count .bar { | ||||
|   background-color: #e75316; | ||||
|   height: 12px; | ||||
|   width: 40px; | ||||
|   display: inline-block; | ||||
|   margin: 2px 4px 0 4px; | ||||
|   vertical-align: text-top; | ||||
| } | ||||
| .diff-box .count .bar .add { | ||||
|   background-color: #77c64a; | ||||
|   height: 12px; | ||||
| } | ||||
| .diff-box .file { | ||||
|   color: #888; | ||||
| } | ||||
| .diff-box .panel-header { | ||||
|   font-size: 14px; | ||||
| } | ||||
| .diff-file-box .code-diff tbody tr:hover td, | ||||
| .diff-file-box .code-diff tbody tr:hover pre { | ||||
|   background-color: #FFF8D2 !important; | ||||
|   border-color: #F0DB88 !important; | ||||
| } | ||||
| .diff-file-box .file-body.file-code .lines-num-old { | ||||
|   border-right: 1px solid #DDD; | ||||
| } | ||||
| .file-content .file-body.file-code .lines-num { | ||||
|   text-align: right; | ||||
|   color: #999; | ||||
|   background: #fafafa; | ||||
|   width: 1%; | ||||
| } | ||||
| .diff-file-box .code-diff tbody tr.tag-code td, | ||||
| .diff-file-box .code-diff tbody tr.tag-code pre { | ||||
|   background-color: #E0E0E0 !important; | ||||
|   border-color: #ADADAD !important; | ||||
| } | ||||
| .diff-file-box .code-diff tbody tr.del-code td, | ||||
| .diff-file-box .code-diff tbody tr.del-code pre { | ||||
|   background-color: #ffe2dd !important; | ||||
|   border-color: #e9aeae !important; | ||||
| } | ||||
| .diff-file-box .code-diff tbody tr.add-code td, | ||||
| .diff-file-box .code-diff tbody tr.add-code pre { | ||||
|   background-color: #d1ffd6 !important; | ||||
|   border-color: #b4e2b4 !important; | ||||
| } | ||||
| .compare-head-box { | ||||
|   margin-top: 10px; | ||||
| } | ||||
| .compare-head-box .compare { | ||||
|   padding: 0 15px 15px 15px; | ||||
| } | ||||
| #admin-wrapper, | ||||
| #setting-wrapper { | ||||
|   padding-bottom: 100px; | ||||
|  |  | |||
|  | @ -366,6 +366,9 @@ dt { | |||
| .grid-4-5 { | ||||
|   width: 80%; | ||||
| } | ||||
| .btn { | ||||
|   white-space: nowrap; | ||||
| } | ||||
| .btn-small { | ||||
|   font-size: 10.8px; | ||||
|   padding: .4em .9em; | ||||
|  | @ -457,6 +460,9 @@ dt { | |||
|   box-sizing: content-box; | ||||
|   text-align: center; | ||||
| } | ||||
| .btn-comb { | ||||
|   margin-left: -1px; | ||||
| } | ||||
| .btn-disabled { | ||||
|   opacity: .6; | ||||
|   cursor: not-allowed; | ||||
|  | @ -480,6 +486,10 @@ dt { | |||
| .ipt-large { | ||||
|   font-size: 14.4px; | ||||
| } | ||||
| .ipt-textarea { | ||||
|   height: auto !important; | ||||
|   width: auto; | ||||
| } | ||||
| .ipt-disabled, | ||||
| input[disabled] { | ||||
|   background-color: #f2f2f2 !important; | ||||
|  | @ -709,6 +719,14 @@ ul.menu-radius > li:last-child > a { | |||
|   border-bottom-left-radius: .3em; | ||||
|   border-bottom-right-radius: .3em; | ||||
| } | ||||
| .panel.panel-info { | ||||
|   border-color: #85c5e5; | ||||
| } | ||||
| .panel.panel-info > .panel-header { | ||||
|   color: #31708f; | ||||
|   background-color: #d9edf7; | ||||
|   border-color: #85c5e5; | ||||
| } | ||||
| .panel.panel-warning { | ||||
|   border-color: #F0C36D; | ||||
| } | ||||
|  |  | |||
|  | @ -299,6 +299,9 @@ function initCore() { | |||
|         e.preventDefault(); | ||||
|         $.magnificPopup.close(); | ||||
|     }); | ||||
| 
 | ||||
|     // Collapse.
 | ||||
|     $('.collapse').hide(); | ||||
| } | ||||
| 
 | ||||
| function initUserSetting() { | ||||
|  | @ -698,6 +701,37 @@ function initProfile() { | |||
|     }); | ||||
| } | ||||
| 
 | ||||
| function initTimeSwitch() { | ||||
|     // Time switch.
 | ||||
|     $(".time-since[title]").on("click", function () { | ||||
|         var $this = $(this); | ||||
| 
 | ||||
|         var title = $this.attr("title"); | ||||
|         var text = $this.text(); | ||||
| 
 | ||||
|         $this.text(title); | ||||
|         $this.attr("title", text); | ||||
|     }); | ||||
| } | ||||
| 
 | ||||
| function initDiff() { | ||||
|     $('.diff-detail-box>a').click(function () { | ||||
|         $($(this).data('target')).slideToggle(100); | ||||
|     }) | ||||
| 
 | ||||
|     var $counter = $('.diff-counter'); | ||||
|     if ($counter.length < 1) { | ||||
|         return; | ||||
|     } | ||||
|     $counter.each(function (i, item) { | ||||
|         var $item = $(item); | ||||
|         var addLine = $item.find('span[data-line].add').data("line"); | ||||
|         var delLine = $item.find('span[data-line].del').data("line"); | ||||
|         var addPercent = parseFloat(addLine) / (parseFloat(addLine) + parseFloat(delLine)) * 100; | ||||
|         $item.find(".bar .add").css("width", addPercent + "%"); | ||||
|     }); | ||||
| } | ||||
| 
 | ||||
| $(document).ready(function () { | ||||
|     Gogs.AppSubUrl = $('head').data('suburl') || ''; | ||||
|     initCore(); | ||||
|  | @ -737,6 +771,10 @@ $(document).ready(function () { | |||
|     if ($('#user-profile-page').length) { | ||||
|         initProfile(); | ||||
|     } | ||||
|     if ($('#diff-page').length) { | ||||
|         initTimeSwitch(); | ||||
|         initDiff(); | ||||
|     } | ||||
| 
 | ||||
|     $('#dashboard-sidebar-menu').tabs(); | ||||
|     $('#pull-issue-preview').markdown_preview(".issue-add-comment"); | ||||
|  |  | |||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -102,6 +102,7 @@ clear: both; | |||
|         z-index: 100; | ||||
|         font-size: 12px; | ||||
|         width: 120%; | ||||
|         min-width: 100px; | ||||
|         li > a { | ||||
|             padding: 3px 9px; | ||||
|         } | ||||
|  | @ -290,4 +291,8 @@ clear: both; | |||
|     li { | ||||
|         display: inline; | ||||
|     } | ||||
| } | ||||
| .list-unstyled { | ||||
|     padding-left: 0; | ||||
|     list-style: none; | ||||
| } | ||||
|  | @ -444,13 +444,11 @@ | |||
|     background: #f5f5f5; | ||||
|     width: 1%; | ||||
|     span { | ||||
|       font-family: Monaco, Menlo, Consolas, "Courier New", monospace; | ||||
|       line-height: 18px; | ||||
|       padding: 0 8px 0 10px; | ||||
|       cursor: pointer; | ||||
|       display: block; | ||||
|       margin-top: 2px; | ||||
|       font-size: 12px; | ||||
|         font-family: Monaco,Menlo,Consolas,"Courier New",monospace; | ||||
|         line-height: 1.6; | ||||
|         padding: 0 10px;   | ||||
|         cursor: pointer; | ||||
|         display: block; | ||||
|     } | ||||
|   } | ||||
|   .lines-code > pre { | ||||
|  | @ -494,37 +492,138 @@ | |||
|   } | ||||
| } | ||||
| .repo-user-list-block { | ||||
|   position: relative; | ||||
|   top: 5px; | ||||
|     position: relative; | ||||
|     top: 5px; | ||||
| } | ||||
| .setting-list { | ||||
|   width: 100%; | ||||
|   list-style: none; | ||||
|     width: 100%; | ||||
|     list-style: none; | ||||
| } | ||||
| #commits-list { | ||||
|   padding-top: 20px; | ||||
|   h4{ | ||||
|     line-height: 30px; | ||||
|     margin-bottom: 0; | ||||
|   } | ||||
|     padding-top: 20px; | ||||
|     h4{ | ||||
|         line-height: 30px; | ||||
|         margin-bottom: 0; | ||||
|     } | ||||
| } | ||||
| .commit-list { | ||||
|   th { | ||||
|     background-color: #FFF; | ||||
|     line-height: 28px !important; | ||||
|   } | ||||
|   .date { | ||||
|     width: 120px; | ||||
|   } | ||||
|   .author { | ||||
|     padding-left: 20px; | ||||
|     min-width: 180px; | ||||
|     img { | ||||
|       margin-top: -4px; | ||||
|     th { | ||||
|         background-color: #FFF; | ||||
|         line-height: 28px !important; | ||||
|     } | ||||
|     .date { | ||||
|         width: 120px; | ||||
|     } | ||||
|     .author { | ||||
|         padding-left: 20px; | ||||
|         min-width: 180px; | ||||
|         img { | ||||
|             margin-top: -4px; | ||||
|         } | ||||
|     } | ||||
|     .sha a { | ||||
|         font-family: Consolas, Menlo, Monaco, "Lucida Console", monospace; | ||||
|         font-size: 14px; | ||||
|     } | ||||
| } | ||||
| .diff-head-box { | ||||
|     margin-top: 10px; | ||||
|     .panel-body { | ||||
|         padding: 10px 15px 5px 10px; | ||||
|     } | ||||
|     .author { | ||||
|         img { | ||||
|             margin-top: -7px; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| .diff-detail-box { | ||||
|     margin: 15px 0; | ||||
|     line-height: 30px; | ||||
|     ol { | ||||
|         clear: both; | ||||
|         padding-left: 0; | ||||
|         margin-bottom: 28px; | ||||
|         li { | ||||
|             list-style: none; | ||||
|             padding-bottom: 4px; | ||||
|             margin-bottom: 4px; | ||||
|             border-bottom: 1px dashed #DDD; | ||||
|             padding-left: 6px; | ||||
|         } | ||||
|     } | ||||
|     span.status{ | ||||
|         display: inline-block; | ||||
|         width: 12px; | ||||
|         height: 12px; | ||||
|         margin-right: 8px; | ||||
|         vertical-align: middle; | ||||
|         &.modify { | ||||
|             background-color: #f0db88; | ||||
|         } | ||||
|         &.add { | ||||
|             background-color: #b4e2b4; | ||||
|         } | ||||
|         &.del { | ||||
|             background-color: #e9aeae; | ||||
|         } | ||||
|         &.rename { | ||||
|             background-color: #dad8ff; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| .diff-box { | ||||
|     .count { | ||||
|         margin-right: 12px; | ||||
|         .bar { | ||||
|             background-color: #e75316; | ||||
|             height: 12px; | ||||
|             width: 40px; | ||||
|             display: inline-block; | ||||
|             margin: 2px 4px 0 4px; | ||||
|             vertical-align: text-top; | ||||
|             .add { | ||||
|                 background-color: #77c64a; | ||||
|                 height: 12px; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     .file { | ||||
|         color: #888; | ||||
|     } | ||||
|     .panel-header { | ||||
|         font-size: 14px; | ||||
|     } | ||||
| } | ||||
| .diff-file-box .code-diff tbody tr:hover td, .diff-file-box .code-diff tbody tr:hover pre { | ||||
|     background-color: #FFF8D2 !important; | ||||
|     border-color: #F0DB88 !important; | ||||
| } | ||||
| .diff-file-box .file-body.file-code .lines-num-old { | ||||
| border-right: 1px solid #DDD; | ||||
| } | ||||
| .file-content .file-body.file-code .lines-num { | ||||
| text-align: right; | ||||
| color: #999; | ||||
| background: #fafafa; | ||||
| width: 1%; | ||||
| } | ||||
| .diff-file-box .code-diff tbody tr.tag-code td, .diff-file-box .code-diff tbody tr.tag-code pre { | ||||
| background-color: #E0E0E0 !important; | ||||
| border-color: #ADADAD !important; | ||||
| } | ||||
| .diff-file-box .code-diff tbody tr.del-code td, .diff-file-box .code-diff tbody tr.del-code pre { | ||||
| background-color: #ffe2dd !important; | ||||
| border-color: #e9aeae !important; | ||||
| } | ||||
| .diff-file-box .code-diff tbody tr.add-code td, .diff-file-box .code-diff tbody tr.add-code pre { | ||||
| background-color: #d1ffd6 !important; | ||||
| border-color: #b4e2b4 !important; | ||||
| } | ||||
| 
 | ||||
| .compare-head-box { | ||||
|     margin-top: 10px; | ||||
|     .compare { | ||||
|         padding: 0 15px 15px 15px; | ||||
|     } | ||||
|   } | ||||
|   .sha a { | ||||
|     font-family: Consolas, Menlo, Monaco, "Lucida Console", monospace; | ||||
|     font-size: 14px; | ||||
|   } | ||||
| } | ||||
|  | @ -1,9 +1,8 @@ | |||
| @import "var"; | ||||
| 
 | ||||
| // colored buttons | ||||
| // Button. | ||||
| .btn { | ||||
|   &:hover { | ||||
|   } | ||||
|     white-space: nowrap; | ||||
| } | ||||
| .btn-small { | ||||
|   font-size: 0.9*@baseFontSize; | ||||
|  | @ -102,6 +101,9 @@ | |||
|     box-sizing: content-box; | ||||
|     text-align: center; | ||||
| } | ||||
| .btn-comb { | ||||
|     margin-left: -1px; | ||||
| } | ||||
| 
 | ||||
| .btn-disabled { | ||||
|   opacity: .6; | ||||
|  | @ -116,25 +118,24 @@ | |||
| } | ||||
| 
 | ||||
| // input form elements | ||||
| 
 | ||||
| .ipt { | ||||
|   &:focus { | ||||
|     border-color: @iptFocusBorderColor; | ||||
|   } | ||||
|     &:focus { | ||||
|         border-color: @iptFocusBorderColor; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| .ipt-radius { | ||||
|   border-radius: .25em; | ||||
|     border-radius: .25em; | ||||
| } | ||||
| 
 | ||||
| .ipt-small { | ||||
|   font-size: .8*@baseFontSize; | ||||
|     font-size: .8*@baseFontSize; | ||||
| } | ||||
| 
 | ||||
| .ipt-large { | ||||
|   font-size: 1.2*@baseFontSize; | ||||
|     font-size: 1.2*@baseFontSize; | ||||
| } | ||||
| .ipt-textarea { | ||||
|     height: auto !important; | ||||
|     width: auto; | ||||
| } | ||||
| 
 | ||||
| .ipt-disabled, | ||||
| input[disabled] { | ||||
|   background-color: @iptDisabledColor !important; | ||||
|  | @ -144,14 +145,12 @@ input[disabled] { | |||
|   color: #888; | ||||
|   cursor: not-allowed; | ||||
| } | ||||
| 
 | ||||
| .ipt-readonly, | ||||
| input[readonly] { | ||||
|   &:focus { | ||||
|     background-color: @iptDisabledColor !important; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .ipt-error { | ||||
|   border-color: @iptErrorBorderColor !important; | ||||
|   background-color: @iptErrorFocusColor !important; | ||||
|  |  | |||
|  | @ -36,6 +36,14 @@ | |||
|           border-bottom-right-radius: .3em; | ||||
|         } | ||||
|     } | ||||
|     &.panel-info { | ||||
|         border-color: #85c5e5; | ||||
|         > .panel-header { | ||||
|             color: #31708f; | ||||
|             background-color: #d9edf7; | ||||
|             border-color: #85c5e5; | ||||
|         } | ||||
|     } | ||||
|     &.panel-warning { | ||||
|         border-color: #F0C36D; | ||||
|         > .panel-header { | ||||
|  |  | |||
|  | @ -0,0 +1,46 @@ | |||
| // Copyright 2014 The Gogs Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a MIT-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package admin | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/Unknwon/com" | ||||
| 
 | ||||
| 	"github.com/gogits/gogs/models" | ||||
| 	"github.com/gogits/gogs/modules/base" | ||||
| 	"github.com/gogits/gogs/modules/log" | ||||
| 	"github.com/gogits/gogs/modules/middleware" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	NOTICES base.TplName = "admin/notice" | ||||
| ) | ||||
| 
 | ||||
| func Notices(ctx *middleware.Context) { | ||||
| 	ctx.Data["Title"] = ctx.Tr("admin.notices") | ||||
| 	ctx.Data["PageIsAdmin"] = true | ||||
| 	ctx.Data["PageIsAdminNotices"] = true | ||||
| 
 | ||||
| 	pageNum := 50 | ||||
| 	p := pagination(ctx, models.CountNotices(), pageNum) | ||||
| 
 | ||||
| 	notices, err := models.GetNotices(pageNum, (p-1)*pageNum) | ||||
| 	if err != nil { | ||||
| 		ctx.Handle(500, "GetNotices", err) | ||||
| 		return | ||||
| 	} | ||||
| 	ctx.Data["Notices"] = notices | ||||
| 	ctx.HTML(200, NOTICES) | ||||
| } | ||||
| 
 | ||||
| func DeleteNotice(ctx *middleware.Context) { | ||||
| 	id := com.StrTo(ctx.Params(":id")).MustInt64() | ||||
| 	if err := models.DeleteNotice(id); err != nil { | ||||
| 		ctx.Handle(500, "DeleteNotice", err) | ||||
| 		return | ||||
| 	} | ||||
| 	log.Trace("System notice deleted by admin(%s): %d", ctx.User.Name, id) | ||||
| 	ctx.Flash.Success(ctx.Tr("admin.notices.delete_success")) | ||||
| 	ctx.Redirect("/admin/notices") | ||||
| } | ||||
|  | @ -25,7 +25,7 @@ func Organizations(ctx *middleware.Context) { | |||
| 	var err error | ||||
| 	ctx.Data["Orgs"], err = models.GetOrganizations(pageNum, (p-1)*pageNum) | ||||
| 	if err != nil { | ||||
| 		ctx.Handle(500, "GetUsers", err) | ||||
| 		ctx.Handle(500, "GetOrganizations", err) | ||||
| 		return | ||||
| 	} | ||||
| 	ctx.HTML(200, ORGS) | ||||
|  |  | |||
|  | @ -24,14 +24,14 @@ const ( | |||
| ) | ||||
| 
 | ||||
| func pagination(ctx *middleware.Context, count int64, pageNum int) int { | ||||
| 	p := com.StrTo(ctx.Query("p")).MustInt() | ||||
| 	p := ctx.QueryInt("p") | ||||
| 	if p < 1 { | ||||
| 		p = 1 | ||||
| 	} | ||||
| 	curCount := int64((p-1)*pageNum + pageNum) | ||||
| 	if curCount > count { | ||||
| 	if curCount >= count { | ||||
| 		p = int(count) / pageNum | ||||
| 	} else if count > curCount { | ||||
| 	} else { | ||||
| 		ctx.Data["NextPageNum"] = p + 1 | ||||
| 	} | ||||
| 	if p > 1 { | ||||
|  | @ -48,12 +48,12 @@ func Users(ctx *middleware.Context) { | |||
| 	pageNum := 50 | ||||
| 	p := pagination(ctx, models.CountUsers(), pageNum) | ||||
| 
 | ||||
| 	var err error | ||||
| 	ctx.Data["Users"], err = models.GetUsers(pageNum, (p-1)*pageNum) | ||||
| 	users, err := models.GetUsers(pageNum, (p-1)*pageNum) | ||||
| 	if err != nil { | ||||
| 		ctx.Handle(500, "GetUsers", err) | ||||
| 		return | ||||
| 	} | ||||
| 	ctx.Data["Users"] = users | ||||
| 	ctx.HTML(200, USERS) | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -92,7 +92,7 @@ func SettingsDelete(ctx *middleware.Context) { | |||
| 				ctx.Handle(500, "DeleteOrganization", err) | ||||
| 			} | ||||
| 		} else { | ||||
| 			log.Trace("Organization deleted: %s", ctx.User.Name) | ||||
| 			log.Trace("Organization deleted: %s", org.Name) | ||||
| 			ctx.Redirect(setting.AppSubUrl + "/") | ||||
| 		} | ||||
| 		return | ||||
|  |  | |||
|  | @ -124,6 +124,11 @@ func TeamsRepoAction(ctx *middleware.Context) { | |||
| 		var repo *models.Repository | ||||
| 		repo, err = models.GetRepositoryByName(ctx.Org.Organization.Id, repoName) | ||||
| 		if err != nil { | ||||
| 			if err == models.ErrRepoNotExist { | ||||
| 				ctx.Flash.Error(ctx.Tr("org.teams.add_nonexistent_repo")) | ||||
| 				ctx.Redirect(ctx.Org.OrgLink + "/teams/" + ctx.Org.Team.LowerName + "/repositories") | ||||
| 				return | ||||
| 			} | ||||
| 			ctx.Handle(500, "GetRepositoryByName", err) | ||||
| 			return | ||||
| 		} | ||||
|  |  | |||
|  | @ -159,6 +159,7 @@ func Diff(ctx *middleware.Context) { | |||
| 	ctx.Data["IsImageFile"] = isImageFile | ||||
| 	ctx.Data["Title"] = commit.Summary() + " · " + base.ShortSha(commitId) | ||||
| 	ctx.Data["Commit"] = commit | ||||
| 	ctx.Data["Author"] = models.ValidateCommitWithEmail(commit) | ||||
| 	ctx.Data["Diff"] = diff | ||||
| 	ctx.Data["Parents"] = parents | ||||
| 	ctx.Data["DiffNotAvailable"] = diff.NumFiles() == 0 | ||||
|  | @ -212,6 +213,7 @@ func CompareDiff(ctx *middleware.Context) { | |||
| 		ctx.Handle(500, "CommitsBeforeUntil", err) | ||||
| 		return | ||||
| 	} | ||||
| 	commits = models.ValidateCommitsWithEmails(commits) | ||||
| 
 | ||||
| 	ctx.Data["Commits"] = commits | ||||
| 	ctx.Data["CommitCount"] = commits.Len() | ||||
|  | @ -274,13 +276,15 @@ func FileHistory(ctx *middleware.Context) { | |||
| 		nextPage = 0 | ||||
| 	} | ||||
| 
 | ||||
| 	ctx.Data["Commits"], err = ctx.Repo.GitRepo.CommitsByFileAndRange( | ||||
| 	commits, err := ctx.Repo.GitRepo.CommitsByFileAndRange( | ||||
| 		branchName, fileName, page) | ||||
| 	if err != nil { | ||||
| 		ctx.Handle(500, "repo.FileHistory(CommitsByRange)", err) | ||||
| 		return | ||||
| 	} | ||||
| 	commits = models.ValidateCommitsWithEmails(commits) | ||||
| 
 | ||||
| 	ctx.Data["Commits"] = commits | ||||
| 	ctx.Data["Username"] = userName | ||||
| 	ctx.Data["Reponame"] = repoName | ||||
| 	ctx.Data["FileName"] = fileName | ||||
|  |  | |||
|  | @ -16,6 +16,7 @@ import ( | |||
| 	"github.com/gogits/gogs/models" | ||||
| 	"github.com/gogits/gogs/modules/auth" | ||||
| 	"github.com/gogits/gogs/modules/base" | ||||
| 	"github.com/gogits/gogs/modules/git" | ||||
| 	"github.com/gogits/gogs/modules/log" | ||||
| 	"github.com/gogits/gogs/modules/mailer" | ||||
| 	"github.com/gogits/gogs/modules/middleware" | ||||
|  | @ -26,6 +27,8 @@ const ( | |||
| 	SETTINGS_OPTIONS base.TplName = "repo/settings/options" | ||||
| 	COLLABORATION    base.TplName = "repo/settings/collaboration" | ||||
| 	HOOKS            base.TplName = "repo/settings/hooks" | ||||
| 	GITHOOKS         base.TplName = "repo/settings/githooks" | ||||
| 	GITHOOK_EDIT     base.TplName = "repo/settings/githook_edit" | ||||
| 	HOOK_NEW         base.TplName = "repo/settings/hook_new" | ||||
| 	ORG_HOOK_NEW     base.TplName = "org/settings/hook_new" | ||||
| ) | ||||
|  | @ -193,9 +196,16 @@ func SettingsCollaboration(ctx *middleware.Context) { | |||
| 			return | ||||
| 		} | ||||
| 
 | ||||
| 		// Check if user is organization member.
 | ||||
| 		if ctx.Repo.Owner.IsOrganization() && ctx.Repo.Owner.IsOrgMember(u.Id) { | ||||
| 			ctx.Flash.Info(ctx.Tr("repo.settings.user_is_org_member")) | ||||
| 			ctx.Redirect(ctx.Repo.RepoLink + "/settings/collaboration") | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
| 		if err = models.AddAccess(&models.Access{UserName: name, RepoName: repoLink, | ||||
| 			Mode: models.WRITABLE}); err != nil { | ||||
| 			ctx.Handle(500, "AddAccess2", err) | ||||
| 			ctx.Handle(500, "AddAccess", err) | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
|  | @ -244,16 +254,20 @@ func SettingsCollaboration(ctx *middleware.Context) { | |||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	us := make([]*models.User, len(names)) | ||||
| 	for i, name := range names { | ||||
| 		us[i], err = models.GetUserByName(name) | ||||
| 	collaborators := make([]*models.User, 0, len(names)) | ||||
| 	for _, name := range names { | ||||
| 		u, err := models.GetUserByName(name) | ||||
| 		if err != nil { | ||||
| 			ctx.Handle(500, "GetUserByName", err) | ||||
| 			return | ||||
| 		} | ||||
| 		// Does not show organization members.
 | ||||
| 		if ctx.Repo.Owner.IsOrganization() && ctx.Repo.Owner.IsOrgMember(u.Id) { | ||||
| 			continue | ||||
| 		} | ||||
| 		collaborators = append(collaborators, u) | ||||
| 	} | ||||
| 
 | ||||
| 	ctx.Data["Collaborators"] = us | ||||
| 	ctx.Data["Collaborators"] = collaborators | ||||
| 	ctx.HTML(200, COLLABORATION) | ||||
| } | ||||
| 
 | ||||
|  | @ -591,3 +605,54 @@ func getOrgRepoCtx(ctx *middleware.Context) (*OrgRepoCtx, error) { | |||
| 		return &OrgRepoCtx{}, errors.New("Unable to set OrgRepo context") | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func GitHooks(ctx *middleware.Context) { | ||||
| 	ctx.Data["Title"] = ctx.Tr("repo.settings") | ||||
| 	ctx.Data["PageIsSettingsGitHooks"] = true | ||||
| 
 | ||||
| 	hooks, err := ctx.Repo.GitRepo.Hooks() | ||||
| 	if err != nil { | ||||
| 		ctx.Handle(500, "Hooks", err) | ||||
| 		return | ||||
| 	} | ||||
| 	ctx.Data["Hooks"] = hooks | ||||
| 
 | ||||
| 	ctx.HTML(200, GITHOOKS) | ||||
| } | ||||
| 
 | ||||
| func GitHooksEdit(ctx *middleware.Context) { | ||||
| 	ctx.Data["Title"] = ctx.Tr("repo.settings") | ||||
| 	ctx.Data["PageIsSettingsGitHooks"] = true | ||||
| 
 | ||||
| 	name := ctx.Params(":name") | ||||
| 	hook, err := ctx.Repo.GitRepo.GetHook(name) | ||||
| 	if err != nil { | ||||
| 		if err == git.ErrNotValidHook { | ||||
| 			ctx.Handle(404, "GetHook", err) | ||||
| 		} else { | ||||
| 			ctx.Handle(500, "GetHook", err) | ||||
| 		} | ||||
| 		return | ||||
| 	} | ||||
| 	ctx.Data["Hook"] = hook | ||||
| 	ctx.HTML(200, GITHOOK_EDIT) | ||||
| } | ||||
| 
 | ||||
| func GitHooksEditPost(ctx *middleware.Context) { | ||||
| 	name := ctx.Params(":name") | ||||
| 	hook, err := ctx.Repo.GitRepo.GetHook(name) | ||||
| 	if err != nil { | ||||
| 		if err == git.ErrNotValidHook { | ||||
| 			ctx.Handle(404, "GetHook", err) | ||||
| 		} else { | ||||
| 			ctx.Handle(500, "GetHook", err) | ||||
| 		} | ||||
| 		return | ||||
| 	} | ||||
| 	hook.Content = ctx.Query("content") | ||||
| 	if err = hook.Update(); err != nil { | ||||
| 		ctx.Handle(500, "hook.Update", err) | ||||
| 		return | ||||
| 	} | ||||
| 	ctx.Redirect(ctx.Repo.RepoLink + "/settings/hooks/git") | ||||
| } | ||||
|  |  | |||
|  | @ -166,7 +166,7 @@ func Home(ctx *middleware.Context) { | |||
| 		} | ||||
| 
 | ||||
| 		if readmeFile != nil { | ||||
| 			ctx.Data["ReadmeInHome"] = true | ||||
| 			ctx.Data["ReadmeInList"] = true | ||||
| 			ctx.Data["ReadmeExist"] = true | ||||
| 			if dataRc, err := readmeFile.Data(); err != nil { | ||||
| 				ctx.Handle(404, "repo.SinglereadmeFile.LookupBlob", err) | ||||
|  |  | |||
|  | @ -177,9 +177,13 @@ func SettingsSSHKeysPost(ctx *middleware.Context, form auth.AddSSHKeyForm) { | |||
| 		cleanContent := strings.Replace(form.Content, "\n", "", -1) | ||||
| 
 | ||||
| 		if ok, err := models.CheckPublicKeyString(cleanContent); !ok { | ||||
| 			ctx.Flash.Error(ctx.Tr("form.invalid_ssh_key", err.Error())) | ||||
| 			ctx.Redirect(setting.AppSubUrl + "/user/settings/ssh") | ||||
| 			return | ||||
| 			if err == models.ErrKeyUnableVerify { | ||||
| 				ctx.Flash.Info(ctx.Tr("form.unable_verify_ssh_key")) | ||||
| 			} else { | ||||
| 				ctx.Flash.Error(ctx.Tr("form.invalid_ssh_key", err.Error())) | ||||
| 				ctx.Redirect(setting.AppSubUrl + "/user/settings/ssh") | ||||
| 				return | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		k := &models.PublicKey{ | ||||
|  |  | |||
|  | @ -0,0 +1,2 @@ | |||
| #!/bin/sh | ||||
| su git -c "/home/git/gogs/scripts/gogs_supervisord.sh restart" | ||||
|  | @ -1,10 +1,15 @@ | |||
| #!/bin/sh | ||||
| 
 | ||||
| echo 'plase remember to modify the command path in etc/supervisord.conf(line 23)' | ||||
| 
 | ||||
| PID="/tmp/supervisord.pid" | ||||
| PID="log/supervisord.pid" | ||||
| CONF="etc/supervisord.conf" | ||||
| 
 | ||||
| EXEPATH='/usr/bin/gogs_start' | ||||
| if [ ! -f $EXEPATH ]; then | ||||
|     gogs_scripts_path=$(cd `dirname $0`; pwd) | ||||
|     echo $gogs_scripts_path | ||||
|     sudo ln -s $gogs_scripts_path'/start.sh' /usr/bin/gogs_start | ||||
| fi | ||||
| 
 | ||||
| LOGDIR="log" | ||||
| if [ ! -d $LOGDIR ]; then | ||||
|     mkdir $LOGDIR | ||||
|  |  | |||
|  | @ -1 +1 @@ | |||
| 0.5.4.1003 Beta | ||||
| 0.5.5.1013 Beta | ||||
|  | @ -58,7 +58,7 @@ | |||
|                                             <td>{{.Pid}}</td> | ||||
|                                             <td>{{.Description}}</td> | ||||
|                                             <td>{{.Start}}</td> | ||||
|                                             <td>{{TimeSince .Start}}</td> | ||||
|                                             <td>{{TimeSince .Start $.Lang}}</td> | ||||
|                                         </tr> | ||||
|                                         {{end}} | ||||
|                                     </tbody> | ||||
|  |  | |||
|  | @ -8,6 +8,7 @@ | |||
|             <li {{if .PageIsAdminRepositories}}class="current"{{end}}><a href="{{AppSubUrl}}/admin/repos">{{.i18n.Tr "admin.repositories"}}</a></li> | ||||
|             <li {{if .PageIsAdminAuthentications}}class="current"{{end}}><a href="{{AppSubUrl}}/admin/auths">{{.i18n.Tr "admin.authentication"}}</a></li> | ||||
|             <li {{if .PageIsAdminConfig}}class="current"{{end}}><a href="{{AppSubUrl}}/admin/config">{{.i18n.Tr "admin.config"}}</a></li> | ||||
|             <li {{if .PageIsAdminNotices}}class="current"{{end}}><a href="{{AppSubUrl}}/admin/notices">{{.i18n.Tr "admin.notices"}}</a></li> | ||||
|             <li {{if .PageIsAdminMonitor}}class="current"{{end}}><a href="{{AppSubUrl}}/admin/monitor">{{.i18n.Tr "admin.monitor"}}</a></li> | ||||
|         </ul> | ||||
|     </div> | ||||
|  |  | |||
|  | @ -0,0 +1,54 @@ | |||
| {{template "ng/base/head" .}} | ||||
| {{template "ng/base/header" .}} | ||||
| <div id="admin-wrapper"> | ||||
|     <div id="setting-wrapper" class="main-wrapper"> | ||||
|         <div id="admin-setting" class="container clear"> | ||||
|             {{template "admin/nav" .}} | ||||
|             <div class="grid-4-5 left"> | ||||
|                 <div class="setting-content"> | ||||
|                     {{template "ng/base/alert" .}} | ||||
|                     <div id="setting-content"> | ||||
|                         <div class="panel panel-radius"> | ||||
|                             <div class="panel-header"> | ||||
|                                 <strong>{{.i18n.Tr "admin.notices.system_notice_list"}}</strong> | ||||
|                             </div> | ||||
|                             <div class="panel-body admin-panel"> | ||||
|                                 <div class="admin-table"> | ||||
| 					                <table class="table table-striped"> | ||||
| 					                    <thead> | ||||
| 					                        <tr> | ||||
| 					                            <th>Id</th> | ||||
| 					                            <th>{{.i18n.Tr "admin.notices.type"}}</th> | ||||
| 					                            <th>{{.i18n.Tr "admin.notices.desc"}}</th> | ||||
| 					                            <th>{{.i18n.Tr "admin.users.created"}}</th> | ||||
| 					                            <th>{{.i18n.Tr "admin.notices.op"}}</th> | ||||
| 					                        </tr> | ||||
| 					                    </thead> | ||||
| 					                    <tbody> | ||||
| 					                        {{range .Notices}} | ||||
| 					                        <tr> | ||||
| 					                            <td>{{.Id}}</td> | ||||
| 					                            <td>{{$.i18n.Tr .TrStr}}</td> | ||||
| 					                            <td class="grid-1-2"><span>{{.Description}}</span></td> | ||||
| 					                            <td>{{.Created}}</td> | ||||
| 					                            <td><a href="{{AppSubUrl}}/admin/notices/{{.Id}}/delete"><i class="fa fa-trash-o text-red"></i></a></td> | ||||
| 					                        </tr> | ||||
| 					                        {{end}} | ||||
| 					                    </tbody> | ||||
| 					                </table> | ||||
| 					                {{if or .LastPageNum .NextPageNum}} | ||||
| 					                <ul class="pagination"> | ||||
| 					                    {{if .LastPageNum}}<li><a class="btn btn-medium btn-gray btn-radius" href="{{AppSubUrl}}/admin/users?p={{.LastPageNum}}">« {{.i18n.Tr "admin.prev"}}</a></li>{{end}} | ||||
| 					                    {{if .NextPageNum}}<li><a class="btn btn-medium btn-gray btn-radius" href="{{AppSubUrl}}/admin/users?p={{.NextPageNum}}">» {{.i18n.Tr "admin.next"}}</a></li>{{end}} | ||||
| 					                </ul> | ||||
| 					                {{end}} | ||||
| 				                </div> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </div> | ||||
| </div> | ||||
| {{template "ng/base/footer" .}} | ||||
|  | @ -24,7 +24,28 @@ | |||
| </div> | ||||
| <div id="feature-wrapper"> | ||||
|     <div class="container clear"> | ||||
|         {{if eq .Lang "zh-CN"}} | ||||
|         {{if eq .Lang "de-DE"}} | ||||
|         <div class="grid-1-2 left"> | ||||
|             <i class="octicon octicon-flame"></i> | ||||
|             <b>Einfach zu installieren</b> | ||||
|             <p>Starte einfach <a target="_blank" href="http://gogs.io/docs/installation/install_from_binary.html">die Anwendung</a> für deine Plattform. Gogs gibt es auch für <a target="_blank" href="https://github.com/gogits/gogs/tree/master/dockerfiles">Docker</a>, <a target="_blank" href="https://github.com/geerlingguy/ansible-vagrant-examples/tree/master/gogs">Vagrant</a> oder als <a target="_blank" href="http://gogs.io/docs/installation/install_from_packages.html">Installationspaket</a>.</p> | ||||
|         </div> | ||||
|         <div class="grid-1-2 left"> | ||||
|             <i class="octicon octicon-device-desktop"></i> | ||||
|             <b>Plattformübergreifend</b> | ||||
|             <p>Gogs läuft überall. <a target="_blank" href="http://golang.org/">Go</a> kompiliert für: Windows, Mac OS X, Linux, ARM, etc. Wähle dasjenige System, was dir am meisten gefällt!</p> | ||||
|         </div> | ||||
|         <div class="grid-1-2 left"> | ||||
|             <i class="octicon octicon-rocket"></i> | ||||
|             <b>Leichtgewicht</b> | ||||
|             <p>Gogs hat minimale Systemanforderungen und kann selbst auf einem günstigen und stromsparenden Raspberry Pi betrieben werden.</p> | ||||
|         </div> | ||||
|         <div class="grid-1-2 left"> | ||||
|             <i class="octicon octicon-code"></i> | ||||
|             <b>Quelloffen</b> | ||||
|             <p>Der komplette Code befindet sich auf <a target="_blank" href="https://github.com/gogits/gogs/">GitHub</a>! Unterstütze uns bei der Verbesserung dieses Projekts. Trau dich!</p> | ||||
|         </div> | ||||
|         {{else if eq .Lang "zh-CN"}} | ||||
|         <div class="grid-1-2 left"> | ||||
|             <i class="octicon octicon-flame"></i> | ||||
|             <b>易安装</b> | ||||
|  |  | |||
|  | @ -1,2 +1,3 @@ | |||
| {{if .Flash.ErrorMsg}}<span class="alert alert-red alert-radius block text-bold"><i class="octicon octicon-alert"></i>{{.Flash.ErrorMsg}}</span>{{end}} | ||||
| {{if .Flash.SuccessMsg}}<div class="alert alert-green alert-radius block"><i class="octicon octicon-check"></i>{{.Flash.SuccessMsg}}</div>{{end}} | ||||
| {{if .Flash.SuccessMsg}}<div class="alert alert-green alert-radius block"><i class="octicon octicon-check"></i>{{.Flash.SuccessMsg}}</div>{{end}} | ||||
| {{if .Flash.InfoMsg}}<div class="alert alert-blue alert-radius block"><i class="octicon octicon-info"></i>{{.Flash.InfoMsg}}</div>{{end}} | ||||
|  | @ -27,7 +27,7 @@ | |||
|         </div> | ||||
|         <div id="org-repo-list"> | ||||
| 			{{range .Repos}} | ||||
| 				{{if or $isMember (not .IsPrivate)}} | ||||
| 				{{if .HasAccess $.SignedUser.Name}} | ||||
| 				<div class="org-repo-item"> | ||||
|                     <ul class="org-repo-status right"> | ||||
|                         <li><i class="octicon octicon-star"></i> {{.NumStars}}</li> | ||||
|  |  | |||
|  | @ -1,10 +1,12 @@ | |||
| <div id="commits-list"> | ||||
|     <div class="panel panel-radius"> | ||||
|         <div class="panel-header"> | ||||
|             {{if not .IsDiffCompare}} | ||||
|             <form class="search pull-right" action="{{.RepoLink}}/commits/{{.BranchName}}/search" method="get" id="commits-search-form"> | ||||
|                 <input class="ipt ipt-radius" type="search" name="q" placeholder="{{.i18n.Tr "repo.commits.search"}}" value="{{.Keyword}}" /> | ||||
|                 <button class="btn btn-black btn-small btn-radius">{{.i18n.Tr "repo.commits.find"}}</button> | ||||
|             </form> | ||||
|             {{end}} | ||||
|             <h4>{{.CommitCount}} {{.i18n.Tr "repo.commits.commits"}}</h4> | ||||
|         </div> | ||||
|         <table class="panel-body table commit-list table-striped"> | ||||
|  | @ -31,7 +33,7 @@ | |||
|             </tbody> | ||||
|         </table> | ||||
|     </div> | ||||
|     {{if not .IsSearchPage}} | ||||
|     {{if and (not .IsSearchPage) (not .IsDiffCompare)}} | ||||
|     <ul class="pagination"> | ||||
|         {{if .LastPageNum}}<li><a class="btn btn-medium btn-gray btn-radius" href="{{.RepoLink}}/commits/{{.BranchName}}{{if .FileName}}/{{.FileName}}{{end}}?p={{.LastPageNum}}" rel="nofollow">« {{.i18n.Tr "repo.commits.newer"}}</a></li>{{end}} | ||||
|         {{if .NextPageNum}}<li><a class="btn btn-medium btn-gray btn-radius" href="{{.RepoLink}}/commits/{{.BranchName}}{{if .FileName}}/{{.FileName}}{{end}}?p={{.NextPageNum}}" rel="nofollow">» {{.i18n.Tr "repo.commits.older"}}</a></li>{{end}} | ||||
|  |  | |||
|  | @ -1,49 +1,54 @@ | |||
| {{template "base/head" .}} | ||||
| {{template "base/navbar" .}} | ||||
| {{template "repo/nav" .}} | ||||
| <div id="body" class="container" data-page="repo"> | ||||
|     <div id="source"> | ||||
|       {{if .IsDiffCompare }} | ||||
|         <div class="panel panel-info diff-box diff-head-box"> | ||||
|             <div class="panel-heading"> | ||||
|                 <a class="pull-right btn btn-primary btn-sm" rel="nofollow" href="{{.SourcePath}}">Browse Source</a> | ||||
|                 <h4><a href="{{$.RepoLink}}/commit/{{.BeforeCommitId}}" class="label label-success">{{ShortSha .BeforeCommitId}}</a> ... <a href="{{$.RepoLink}}/commit/{{.AfterCommitId}}" class="label label-success">{{ShortSha .AfterCommitId}}</a></h4> | ||||
| {{template "ng/base/head" .}} | ||||
| {{template "ng/base/header" .}} | ||||
| <div id="repo-wrapper"> | ||||
|     {{template "repo/header" .}} | ||||
|     <div class="container clear" id="diff-page"> | ||||
|         {{if .IsDiffCompare }} | ||||
|         <div class="panel panel-info panel-radius compare-head-box"> | ||||
|             <div class="panel-header"> | ||||
|                 <a class="pull-right btn btn-blue btn-header btn-medium btn-radius" rel="nofollow" href="{{.SourcePath}}">{{.i18n.Tr "repo.diff.browse_source"}}</a> | ||||
|                 <h4><a href="{{$.RepoLink}}/commit/{{.BeforeCommitId}}" class="label label-green">{{ShortSha .BeforeCommitId}}</a> ... <a href="{{$.RepoLink}}/commit/{{.AfterCommitId}}" class="label label-green">{{ShortSha .AfterCommitId}}</a></h4> | ||||
|             </div> | ||||
|             <div class="panel-body compare"> | ||||
|               {{template "repo/commits_table" .}} | ||||
|                 {{template "repo/commits_table" .}} | ||||
|             </div> | ||||
|         </div> | ||||
|       {{else}} | ||||
|           <div class="panel panel-info diff-box diff-head-box"> | ||||
|             <div class="panel-heading"> | ||||
|                 <a class="pull-right btn btn-primary btn-sm" rel="nofollow" href="{{.SourcePath}}">Browse Source</a> | ||||
|         {{else}} | ||||
|         <div class="panel panel-info panel-radius diff-head-box"> | ||||
|             <div class="panel-header"> | ||||
|                 <a class="pull-right btn btn-blue btn-header btn-medium btn-radius" rel="nofollow" href="{{.SourcePath}}">{{.i18n.Tr "repo.diff.browse_source"}}</a> | ||||
|                 <h4>{{.Commit.Message}}</h4> | ||||
|             </div> | ||||
|             <div class="panel-body"> | ||||
|                 <span class="pull-right"> | ||||
|                 <ul class="list-unstyled"> | ||||
|                     {{range .Parents}} | ||||
|                     <li>parent <a href="{{$.RepoLink}}/commit/{{.}}"><span class="label label-default sha">{{ShortSha .}}</span></a></li> | ||||
|                     {{end}} | ||||
|                     <li>commit <span class="label label-default sha">{{ShortSha .CommitId}}</span></li> | ||||
|                 </ul> | ||||
|                     <ul class="list-unstyled"> | ||||
|                         <li class="inline">{{.i18n.Tr "repo.diff.parent"}}</li> | ||||
|                         {{range .Parents}} | ||||
|                         <li class="inline"><a href="{{$.RepoLink}}/commit/{{.}}"><span class="label label-blue">{{ShortSha .}}</span></a></li> | ||||
|                         {{end}} | ||||
|                         <li class="inline">{{.i18n.Tr "repo.diff.commit"}} <span class="label label-blue">{{ShortSha .CommitId}}</span></li> | ||||
|                     </ul> | ||||
|                 </span> | ||||
|                 <p class="author"> | ||||
|                     <img class="avatar" src="{{AvatarLink .Commit.Author.Email}}" alt=""/> | ||||
|                     <a class="name" href="{{AppSubUrl}}/user/email2user?email={{.Commit.Author.Email}}"><strong>{{.Commit.Author.Name}}</strong></a> | ||||
|                     <span class="time">{{TimeSince .Commit.Author.When $.Lang}}</span> | ||||
|                     <img class="avatar-30" src="{{AvatarLink .Commit.Author.Email}}" /> | ||||
|                     {{if .Author}} | ||||
|                     <a href="{{AppSubUrl}}/{{.Author}}"><strong>{{.Commit.Author.Name}}</strong></a> | ||||
|                     {{else}} | ||||
|                     <strong>{{.Commit.Author.Name}}</strong> | ||||
|                     {{end}} | ||||
|                     <span class="text-grey" id="authored-time">{{TimeSince .Commit.Author.When $.Lang}}</span>  | ||||
|                 </p> | ||||
|           </div> | ||||
|             </div> | ||||
|         </div> | ||||
|       {{end}} | ||||
|         {{end}} | ||||
|         {{if .DiffNotAvailable}} | ||||
|         <h4>Diff Data Not Available.</h4> | ||||
|         <h4>{{.i18n.Tr "repo.diff.data_not_available"}}</h4> | ||||
|         {{else}} | ||||
|         <div class="diff-detail-box diff-box"> | ||||
|             <a class="pull-right btn btn-default" data-toggle="collapse" data-target="#diff-files">Show Diff Stats</a> | ||||
|             <a class="pull-right btn btn-gray btn-header btn-radius text-black" data-target="#diff-files">{{.i18n.Tr "repo.diff.show_diff_stats"}}</a> | ||||
|             <p class="showing"> | ||||
|                 <i class="fa fa-retweet"></i> | ||||
|                 <strong> {{.Diff.NumFiles}} changed files</strong> with <strong>{{.Diff.TotalAddition}} additions</strong> and <strong>{{.Diff.TotalDeletion}} deletions</strong>. | ||||
|                 {{.i18n.Tr "repo.diff.stats_desc" .Diff.NumFiles .Diff.TotalAddition .Diff.TotalDeletion | Str2html}} | ||||
|             </p> | ||||
|             <ol class="detail-files collapse" id="diff-files"> | ||||
|                 {{range .Diff.Files}} | ||||
|  | @ -57,7 +62,7 @@ | |||
|                         </span> | ||||
|                         <span class="del" data-line="{{.Deletion}}">{{.Deletion}}</span> | ||||
|                         {{else}} | ||||
|                         <span>BIN</span> | ||||
|                         <span>{{$.i18n.Tr "repo.diff.bin"}}</span> | ||||
|                         {{end}} | ||||
|                     </div> | ||||
|                     <!-- todo finish all file status, now modify, add, delete and rename --> | ||||
|  | @ -69,8 +74,8 @@ | |||
|         </div> | ||||
| 
 | ||||
|         {{range .Diff.Files}} | ||||
|         <div class="panel panel-default diff-file-box diff-box file-content" id="diff-{{.Index}}"> | ||||
|             <div class="panel-heading"> | ||||
|         <div class="panel panel-radius diff-file-box diff-box file-content" id="diff-{{.Index}}"> | ||||
|             <div class="panel-header"> | ||||
|                 <div class="diff-counter count pull-left"> | ||||
|                     {{if not .IsBin}} | ||||
|                     <span class="add" data-line="{{.Addition}}">+ {{.Addition}}</span> | ||||
|  | @ -80,10 +85,10 @@ | |||
|                     </span> | ||||
|                     <span class="del" data-line="{{.Deletion}}">- {{.Deletion}}</span> | ||||
|                     {{else}} | ||||
|                     BIN | ||||
|                     {{$.i18n.Tr "repo.diff.bin"}} | ||||
|                     {{end}} | ||||
|                 </div> | ||||
|                 <a class="btn btn-default btn-sm pull-right" rel="nofollow" href="{{$.SourcePath}}/{{.Name}}">View File</a> | ||||
|                 <a class="btn btn-gray btn-header btn-radius text-black pull-right" rel="nofollow" href="{{$.SourcePath}}/{{.Name}}">{{$.i18n.Tr "repo.diff.view_file"}}</a> | ||||
|                 <span class="file">{{.Name}}</span> | ||||
|             </div> | ||||
|             {{$isImage := (call $.IsImageFile .Name)}} | ||||
|  | @ -117,8 +122,9 @@ | |||
|                 {{end}} | ||||
|             </div> | ||||
|         </div> | ||||
|         <br>  | ||||
|         {{end}} | ||||
|         {{end}} | ||||
|     </div> | ||||
| </div> | ||||
| {{template "base/footer" .}} | ||||
| {{template "ng/base/footer" .}} | ||||
|  |  | |||
|  | @ -54,16 +54,16 @@ | |||
|                         {{end}} | ||||
|                     {{end}} | ||||
|                 </li> | ||||
|                 <!-- <li id="repo-commits-jump" class="repo-jump right"> | ||||
|                 <li id="repo-commits-jump" class="repo-jump right"> | ||||
|                     <a href="#"> | ||||
|                         <button class="btn btn-small btn-gray btn-right-radius"><i class="octicon octicon-git-commit"></i></button> | ||||
|                     </a> | ||||
|                 </li> | ||||
|                 <li id="repo-find-jump" class="repo-jump right"> | ||||
|                     <a href="#"> | ||||
|                         <button class="btn btn-small btn-gray btn-left-radius"><i class="octicon octicon-list-unordered"></i></button> | ||||
|                         <button class="btn btn-small btn btn-small btn-gray btn-left-radius"><i class="octicon octicon-list-unordered"></i></button> | ||||
|                     </a> | ||||
|                 </li> --> | ||||
|                 </li> | ||||
|             </ul> | ||||
|             {{if .IsFile}} | ||||
|                 {{template "repo/view_file" .}} | ||||
|  |  | |||
|  | @ -71,7 +71,7 @@ | |||
|                                                 {{range .ClosedMilestones}} | ||||
|                                                 <li class="milestone-item" data-id="{{.Id}}"> | ||||
|                                                     <p><strong>{{.Name}}</strong></p> | ||||
|                                                     <p>Closed {{TimeSince .ClosedDate}}</p> | ||||
|                                                     <p>Closed {{TimeSince .ClosedDate $.Lang}}</p> | ||||
|                                                 </li> | ||||
|                                                 {{end}} | ||||
|                                             </ul> | ||||
|  |  | |||
|  | @ -236,7 +236,7 @@ | |||
|                                                 {{range .ClosedMilestones}} | ||||
|                                                 <li class="milestone-item" data-id="{{.Id}}"> | ||||
|                                                     <p><strong>{{.Name}}</strong></p> | ||||
|                                                     <p>Closed {{TimeSince .ClosedDate}}</p> | ||||
|                                                     <p>Closed {{TimeSince .ClosedDate $.Lang}}</p> | ||||
|                                                 </li> | ||||
|                                                 {{end}} | ||||
|                                             </ul> | ||||
|  |  | |||
|  | @ -0,0 +1,41 @@ | |||
| {{template "ng/base/head" .}} | ||||
| {{template "ng/base/header" .}} | ||||
| <div id="repo-wrapper"> | ||||
|     {{template "repo/header" .}} | ||||
| 	<div id="setting-wrapper" class="main-wrapper"> | ||||
| 	    <div id="repo-setting" class="container clear"> | ||||
| 	        {{template "repo/settings/nav" .}} | ||||
| 	        <div class="grid-4-5 left"> | ||||
| 	            <div class="setting-content"> | ||||
| 	                {{template "ng/base/alert" .}} | ||||
| 	                <div id="setting-content"> | ||||
| 	                    <div id="repo-hooks-panel" class="panel panel-radius"> | ||||
| 	                        <div class="panel-header"> | ||||
| 	                        	<strong>{{.i18n.Tr "repo.settings.githooks"}}</strong> | ||||
| 	                        </div> | ||||
| 	                        <form class="form form-align panel-body" id="repo-setting-form" action="{{.RepoLink}}/settings/hooks/git/{{.Hook.Name}}" method="post"> | ||||
| 	                            {{.CsrfTokenHtml}} | ||||
|                         		<div class="text-center panel-desc">{{.i18n.Tr "repo.settings.githook_edit_desc"}}</div> | ||||
| 	                            {{with .Hook}} | ||||
| 	                            <div class="field"> | ||||
| 	                                <label>{{$.i18n.Tr "repo.settings.githook_name"}}</label> | ||||
| 	                                <label class="text-left">{{.Name}}</label> | ||||
| 	                            </div> | ||||
| 					            <div class="field clear"> | ||||
| 					                <label class="left" for="content">{{$.i18n.Tr "repo.settings.githook_content"}}</label> | ||||
| 					                <textarea class="ipt-textarea ipt-large ipt-radius" id="content" name="content" cols="60" rows="20" wrap="off">{{if .IsActive}}{{.Content}}{{else}}{{.Sample}}{{end}}</textarea> | ||||
| 					            </div> | ||||
| 	                            <div class="field"> | ||||
| 	                                <span class="form-label"></span> | ||||
| 	                                <button class="btn btn-green btn-large btn-radius" id="change-reponame-btn" href="#change-reponame-modal">{{$.i18n.Tr "repo.settings.update_githook"}}</button> | ||||
| 	                            </div> | ||||
| 	                            {{end}} | ||||
| 	                        </form> | ||||
| 	                    </div> | ||||
| 	                </div> | ||||
| 	            </div> | ||||
| 	        </div> | ||||
| 	    </div> | ||||
| 	</div> | ||||
| </div> | ||||
| {{template "ng/base/footer" .}} | ||||
|  | @ -0,0 +1,37 @@ | |||
| {{template "ng/base/head" .}} | ||||
| {{template "ng/base/header" .}} | ||||
| <div id="repo-wrapper"> | ||||
|     {{template "repo/header" .}} | ||||
| 	<div id="setting-wrapper" class="main-wrapper"> | ||||
| 	    <div id="repo-setting" class="container clear"> | ||||
| 	        {{template "repo/settings/nav" .}} | ||||
| 	        <div class="grid-4-5 left"> | ||||
| 	            <div class="setting-content"> | ||||
| 	                {{template "ng/base/alert" .}} | ||||
| 	                <div id="setting-content"> | ||||
| 	                    <div id="repo-hooks-panel" class="panel panel-radius"> | ||||
| 	                        <div class="panel-header"> | ||||
| 	                        	<strong>{{.i18n.Tr "repo.settings.githooks"}}</strong> | ||||
| 	                        </div> | ||||
| 	                        <ul class="panel-body setting-list"> | ||||
|                             	<li>{{.i18n.Tr "repo.settings.githooks_desc" | Str2html}}</li> | ||||
|                             	{{range .Hooks}} | ||||
| 								<li> | ||||
| 									{{if .IsActive}} | ||||
| 									<span class="left text-success"><i class="octicon octicon-check"></i></span> | ||||
| 									{{else}} | ||||
| 									<span class="left text-grey"><i class="octicon octicon-primitive-dot"></i></span> | ||||
| 									{{end}} | ||||
| 									<span>{{.Name}}</span> | ||||
|                         			<a href="{{$.RepoLink}}/settings/hooks/git/{{.Name}}" class="text-blue right"><i class="fa fa-pencil"></i></a> | ||||
| 								</li> | ||||
|                             	{{end}} | ||||
| 	                       	</ul> | ||||
| 	                    </div> | ||||
| 	                </div> | ||||
| 	            </div> | ||||
| 	        </div> | ||||
| 	    </div> | ||||
| 	</div> | ||||
| </div> | ||||
| {{template "ng/base/footer" .}} | ||||
|  | @ -5,6 +5,7 @@ | |||
|             <li {{if .PageIsSettingsOptions}}class="current"{{end}}><a href="{{.RepoLink}}/settings">{{.i18n.Tr "repo.settings.options"}}</a></li> | ||||
|             <li {{if .PageIsSettingsCollaboration}}class="current"{{end}}><a href="{{.RepoLink}}/settings/collaboration">{{.i18n.Tr "repo.settings.collaboration"}}</a></li> | ||||
|             <li {{if .PageIsSettingsHooks}}class="current"{{end}}><a href="{{.RepoLink}}/settings/hooks">{{.i18n.Tr "repo.settings.hooks"}}</a></li> | ||||
|             <li {{if .PageIsSettingsGitHooks}}class="current"{{end}}><a href="{{.RepoLink}}/settings/hooks/git">{{.i18n.Tr "repo.settings.githooks"}}</a></li> | ||||
|             <!-- <li {{if .PageIsSettingsKeys}}class="current"{{end}}><a href="{{.RepoLink}}/settings/keys">{{.i18n.Tr "repo.settings.deploy_keys"}}</a></li> --> | ||||
|         </ul> | ||||
|     </div> | ||||
|  |  | |||
|  | @ -1,40 +0,0 @@ | |||
| {{template "base/head" .}} | ||||
| {{template "base/navbar" .}} | ||||
| {{template "repo/nav" .}} | ||||
| {{template "repo/toolbar" .}} | ||||
| <div id="body" class="container"> | ||||
|     <div id="source"> | ||||
|         <div class="source-toolbar"> | ||||
|             {{ $n := len .Treenames}} | ||||
|             {{if not .IsFile}}<button class="btn btn-default pull-right hidden"><i class="fa fa-plus-square"></i>Add File</button>{{end}} | ||||
|             <div class="dropdown branch-switch"> | ||||
|                 <a href="#" class="btn btn-success dropdown-toggle" data-toggle="dropdown"><i class="fa fa-chain"></i>{{if .IsBranch}}{{.BranchName}}{{else}}{{ShortSha .CommitId}}{{end}}   | ||||
|                     <b class="caret"></b></a> | ||||
|                 <ul class="dropdown-menu"> | ||||
|                     {{range .Branches}} | ||||
|                     <li><a {{if eq . $.BranchName}}class="current" {{end}}href="{{AppSubUrl}}/{{$.Username}}/{{$.Reponame}}/src/{{.}}">{{.}}</a></li> | ||||
|                     {{end}} | ||||
|                 </ul> | ||||
|             </div> | ||||
|             {{ $l := Subtract $n 1}} | ||||
|             <ol class="breadcrumb"> | ||||
|                 <li class="root dir"> | ||||
|                     <a href="{{.BranchLink}}">{{.Repository.Name}}</a></li> | ||||
|                 {{range $i, $v := .Treenames}} | ||||
|                 <li class="dir"> | ||||
|                     {{if eq $i $l}}{{$v}} | ||||
|                     {{else}} | ||||
|                     <a href="{{$.BranchLink}}/{{index $.Paths $i}}">{{$v}}</a>  | ||||
|                     {{end}} | ||||
|                 </li> | ||||
|                 {{end}} | ||||
|             </ol> | ||||
|         </div> | ||||
|         {{if .IsFile}} | ||||
|             {{template "repo/single_file" .}} | ||||
|         {{else}} | ||||
|             {{template "repo/single_list" .}} | ||||
|         {{end}} | ||||
|     </div> | ||||
| </div> | ||||
| {{template "base/footer" .}} | ||||
|  | @ -1,40 +0,0 @@ | |||
| {{template "base/head" .}} | ||||
| {{template "base/navbar" .}} | ||||
| {{template "repo/nav" .}} | ||||
| {{template "repo/toolbar" .}} | ||||
| <div id="body" class="container"> | ||||
|     <div id="source"> | ||||
|         <div class="panel panel-default guide-box clone-group-btn"> | ||||
|             <div class="panel-heading guide-head"> | ||||
|                 <h4>Quick Guide</h4> | ||||
|             </div> | ||||
|             <div class="panel-body guide-content text-center"> | ||||
|                 <h3>Clone this repository</h3> | ||||
|                 <div class="input-group col-md-8 col-md-offset-2 guide-buttons"> | ||||
|                     <span class="input-group-btn"> | ||||
|                         <button class="btn btn-default" data-link="{{.CloneLink.SSH}}" type="button">SSH</button> | ||||
|                         <button class="btn btn-default" data-link="{{.CloneLink.HTTPS}}" type="button">HTTPS</button> | ||||
|                     </span> | ||||
|                     <input type="text" class="form-control clone-group-url" id="guide-clone-url" value="" readonly/> | ||||
|                     <span class="input-group-btn" style="position: relative"> | ||||
|                         <button class="btn btn-default" type="button" data-toggle="tooltip" title="copy to clipboard" data-placement="top" data-init="copy" data-copy-val="val" data-copy-from="#guide-clone-url"><i class="fa fa-copy"></i></button> | ||||
|                     </span> | ||||
|                 </div> | ||||
|                 <p>We recommend every repository include a <strong>README</strong>, <strong>LICENSE</strong>, and <strong>.gitignore</strong>.</p> | ||||
|                 <hr/> | ||||
|                 <h3>Create a new repository on the command line</h3> | ||||
|                     <pre class="text-left"><code>touch README.md | ||||
| git init | ||||
| git add README.md | ||||
| git commit -m "first commit" | ||||
| git remote add origin <span class="clone-url"></span> | ||||
| git push -u origin master</code></pre> | ||||
|                 <hr/> | ||||
|                 <h3>Push an existing repository from the command line</h3> | ||||
|                 <pre class="text-left"><code>git remote add origin <span class="clone-url"></span> | ||||
| git push -u origin master</code></pre> | ||||
|             </div> | ||||
|         </div> | ||||
|     </div> | ||||
| </div> | ||||
| {{template "base/footer" .}} | ||||
|  | @ -1,51 +0,0 @@ | |||
| <div class="panel panel-default file-content"> | ||||
|     <div class="panel-heading file-head"> | ||||
|         {{if .ReadmeExist}} | ||||
|             <i class="icon fa fa-book"></i> | ||||
|             {{if .ReadmeInSingle}} | ||||
|             {{.FileName}} | ||||
|             {{else}} | ||||
|             {{.FileName}} <span class="file-size">{{FileSize .FileSize}}</span> | ||||
|             {{end}} | ||||
|         {{else}} | ||||
|             <i class="icon fa fa-file-text-o"></i> | ||||
|             {{.FileName}} <span class="file-size">{{FileSize .FileSize}}</span> | ||||
|         {{end}} | ||||
|         {{if not .ReadmeInSingle}} | ||||
|         <div class="btn-group pull-right"> | ||||
|             <a class="btn btn-default hidden" href="#">Edit</a> | ||||
|             <a class="btn btn-default" href="{{.FileLink}}" rel="nofollow">Raw</a> | ||||
|             <a class="btn btn-default hidden" href="#">Blame</a> | ||||
|             <a class="btn btn-default" href="{{.RepoLink}}/commits/{{.BranchName}}/{{.TreeName}}">History</a> | ||||
|             <a class="btn btn-danger hidden" href="#">Delete</a> | ||||
|         </div> | ||||
|         {{end}} | ||||
|     </div> | ||||
| 
 | ||||
|     {{if not .FileIsText}} | ||||
|     <div class="panel-body file-body file-code code-view"> | ||||
|         {{if .IsImageFile}} | ||||
|             <img src="{{.FileLink}}"> | ||||
|         {{else}} | ||||
|             <a href="{{.FileLink}}" rel="nofollow" class="btn btn-default">View Raw</a> | ||||
|         {{end}} | ||||
|     </div> | ||||
|     {{else}} | ||||
|     {{if .ReadmeExist}} | ||||
|     <div class="panel-body file-body markdown"> | ||||
|         {{.FileContent|str2html}} | ||||
|     </div> | ||||
|     {{else}} | ||||
|     <div class="panel-body file-body file-code code-view"> | ||||
|         <table> | ||||
|             <tbody> | ||||
|                 <tr> | ||||
|                     <td class="lines-num"></td> | ||||
|                     <td class="lines-code markdown"><pre class="prettyprint linenums{{if .FileExt}} lang-{{.FileExt}}{{end}}">{{.FileContent}}</pre></td> | ||||
|                 </tr> | ||||
|             </tbody> | ||||
|         </table> | ||||
|     </div> | ||||
|     {{end}} | ||||
|     {{end}} | ||||
| </div> | ||||
|  | @ -1,51 +0,0 @@ | |||
| <div class="panel panel-default info-box"> | ||||
|     <div class="panel-heading info-head"> | ||||
|         <a href="{{AppSubUrl}}/{{.Username}}/{{.Reponame}}/commit/{{.LastCommit.Id}}" rel="nofollow">{{.LastCommit.Summary}}</a> | ||||
|     </div> | ||||
|     <div class="panel-body info-content"> | ||||
|         <a href="{{AppSubUrl}}/user/{{.LastCommit.Author.Name}}">{{.LastCommit.Author.Name}}</a> <span class="text-muted">{{TimeSince .LastCommit.Author.When}}</span> | ||||
|     </div> | ||||
|     <table class="panel-footer table file-list"> | ||||
|         <thead class="hidden"> | ||||
|         <tr> | ||||
|             <th class="icon"></th> | ||||
|             <th class="name">Filename</th> | ||||
|             <th class="text">Message</th> | ||||
|             <th class="date">Date modified</th> | ||||
|         </tr> | ||||
|         </thead> | ||||
|         <tbody> | ||||
|             {{if .HasParentPath}} | ||||
|                 <tr class="has-parent"> | ||||
|                     <td class="icon"><a href="{{.BranchLink}}{{.ParentPath}}"><i class="fa fa-reply"></i></a></td> | ||||
|                     <td class="name"><a href="{{.BranchLink}}{{.ParentPath}}">..</a></td> | ||||
|                     <td class="text"></td> | ||||
|                     <td class="date"></td> | ||||
|                 </tr> | ||||
|             {{end}} | ||||
|             {{range $item := .Files}} | ||||
|                 {{$entry := index $item 0}} | ||||
|                 {{$commit := index $item 1}} | ||||
|                 <tr {{if $entry.IsDir}}class="is-dir"{{end}}> | ||||
|                     <td class="icon"> | ||||
|                         <i class="fa {{if $entry.IsDir}}fa-folder{{else}}fa-file-text-o{{end}}"></i> | ||||
|                     </td> | ||||
|                     <td class="name"> | ||||
|                         <span class="wrap"> | ||||
|                             <a href="{{$.BranchLink}}/{{$.TreePath}}{{$entry.Name}}">{{$entry.Name}}</a> | ||||
|                         </span> | ||||
|                     </td> | ||||
|                     <td class="text"> | ||||
|                         <span class="wrap"><a rel="nofollow" href="{{AppSubUrl}}/{{$.Username}}/{{$.Reponame}}/commit/{{$commit.Id}}">{{$commit.Summary}}</a></span> | ||||
|                     </td> | ||||
|                     <td class="date"> | ||||
|                         <span class="wrap">{{TimeSince $commit.Committer.When}}</span> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|             {{end}} | ||||
|         </tbody> | ||||
|     </table> | ||||
| </div> | ||||
| {{if .ReadmeExist}} | ||||
|     {{template "repo/single_file" .}} | ||||
| {{end}} | ||||
|  | @ -2,15 +2,23 @@ | |||
|     <p class="panel-header"> | ||||
|         {{if .ReadmeExist}} | ||||
|             <i class="icon fa fa-book fa-lg"></i> | ||||
| 	        {{if .ReadmeInHome}} | ||||
| 	        {{if .ReadmeInList}} | ||||
| 	        <strong class="file-name">{{.FileName}}</strong> | ||||
| 	        {{else}} | ||||
| 	        <strong>{{.FileName}}</strong><span class="file-size">{{FileSize .FileSize}}</span> | ||||
| 	        {{end}} | ||||
| 	    {{else}} | ||||
|         <i class="icon fa fa-file-text-o"></i> | ||||
|         <strong class="file-name">{{.FileName}}</strong><span class="file-size">{{FileSize .FileSize}}</span> | ||||
|             <i class="icon fa fa-file-text-o"></i> | ||||
|             <strong class="file-name">{{.FileName}}</strong><span class="file-size">{{FileSize .FileSize}}</span> | ||||
| 	    {{end}} | ||||
|         {{if not .ReadmeInList}} | ||||
|             <a class="right" href="{{.RepoLink}}/commits/{{.BranchName}}/{{.TreeName}}"> | ||||
|                 <button class="btn btn-medium btn-gray btn-right-radius btn-comb">{{.i18n.Tr "repo.file_history"}}</button> | ||||
|             </a> | ||||
|             <a class="right" href="{{.FileLink}}"> | ||||
|                 <button class="btn btn-medium btn-gray btn-left-radius btn-comb">{{.i18n.Tr "repo.file_raw"}}</button> | ||||
|             </a> | ||||
|         {{end}} | ||||
|     </p> | ||||
|     <div class="{{if .ReadmeExist}}panel-content markdown{{end}} code-view" id="repo-code-view"> | ||||
|     	{{if .ReadmeExist}} | ||||
|  | @ -20,7 +28,7 @@ | |||
|             {{if .IsImageFile}} | ||||
|             <img src="{{.FileLink}}"> | ||||
|             {{else}} | ||||
|             <a href="{{.FileLink}}" rel="nofollow" class="btn btn-gray btn-radius">View Raw</a> | ||||
|             <a href="{{.FileLink}}" rel="nofollow" class="btn btn-gray btn-radius">{{.i18n.Tr "repo.file_view_raw"}}</a> | ||||
|             {{end}} | ||||
|         </div> | ||||
|     	{{else if .FileSize}} | ||||
|  |  | |||
|  | @ -10,7 +10,7 @@ | |||
|                 <strong>{{ShortSha .LastCommit.Id.String}}</strong></a> | ||||
|                 <span class="text-truncate">{{.LastCommit.Summary}}</span> | ||||
|             </span> | ||||
|             <span class="age right">{{TimeSince .LastCommit.Author.When .i18n.Lang}}</span> | ||||
|             <span class="age right">{{TimeSince .LastCommit.Author.When $.Lang}}</span> | ||||
|         </th> | ||||
|     </tr> | ||||
|     </thead> | ||||
|  | @ -45,7 +45,7 @@ | |||
|                 <td class="msg"> | ||||
|                     <a class="text-truncate" href="{{AppSubUrl}}/{{$.Username}}/{{$.Reponame}}/commit/{{$commit.Id}}" rel="nofollow">{{$commit.Summary}}</a> | ||||
|                 </td> | ||||
|                 <td class="age">{{TimeSince $commit.Committer.When $.i18n.Lang}}</td> | ||||
|                 <td class="age">{{TimeSince $commit.Committer.When $.Lang}}</td> | ||||
|             </tr> | ||||
|         {{end}} | ||||
|     </tbody> | ||||
|  |  | |||
|  | @ -15,6 +15,8 @@ | |||
|             {{$.i18n.Tr "action.create_issue" AppSubUrl .GetRepoLink $index .GetRepoLink $index | Str2html}} | ||||
|             {{else if eq .GetOpType 8}} | ||||
|             {{$.i18n.Tr "action.transfer_repo" .GetContent AppSubUrl .GetRepoLink .GetRepoLink | Str2html}} | ||||
|             {{else if eq .GetOpType 9}} | ||||
|             {{$.i18n.Tr "action.push_tag" AppSubUrl .GetRepoLink .GetBranch .GetBranch AppSubUrl .GetRepoLink .GetRepoLink | Str2html}} | ||||
|             {{else if eq .GetOpType 10}} | ||||
|             {{ $index := index .GetIssueInfos 0}} | ||||
|             {{$.i18n.Tr "action.comment_issue" AppSubUrl .GetRepoLink $index .GetRepoLink $index | Str2html}} | ||||
|  | @ -28,6 +30,7 @@ | |||
|                 {{range $push.Commits}} | ||||
|                 <li><img class="avatar-16" src="{{AvatarLink .AuthorEmail}}?s=16"> <a href="{{AppSubUrl}}/{{$repoLink}}/commit/{{.Sha1}}">{{ShortSha .Sha1}}</a> <span class="text-truncate grid-4-5">{{.Message}}</span></li> | ||||
|                 {{end}} | ||||
|                 {{if $push.CompareUrl}}<li><a href="{{$push.CompareUrl}}">{{$.i18n.Tr "action.compare_2_commits"}} »</a></li>{{end}} | ||||
|             </ul> | ||||
|         </div> | ||||
|         {{else if eq .GetOpType 6}} | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue