mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-29 10:57:44 +09:00 
			
		
		
		
	fix delete repo will hang on postgres (#1044)
This commit is contained in:
		| @@ -55,27 +55,30 @@ func (n *Notice) TrStr() string { | |||||||
|  |  | ||||||
| // CreateNotice creates new system notice. | // CreateNotice creates new system notice. | ||||||
| func CreateNotice(tp NoticeType, desc string) error { | func CreateNotice(tp NoticeType, desc string) error { | ||||||
| 	// prevent panic if database connection is not available at this point | 	return createNotice(x, tp, desc) | ||||||
| 	if x == nil { |  | ||||||
| 		return fmt.Errorf("Could not save notice due database connection not being available: %d %s", tp, desc) |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func createNotice(e Engine, tp NoticeType, desc string) error { | ||||||
| 	n := &Notice{ | 	n := &Notice{ | ||||||
| 		Type:        tp, | 		Type:        tp, | ||||||
| 		Description: desc, | 		Description: desc, | ||||||
| 	} | 	} | ||||||
| 	_, err := x.Insert(n) | 	_, err := e.Insert(n) | ||||||
| 	return err | 	return err | ||||||
| } | } | ||||||
|  |  | ||||||
| // CreateRepositoryNotice creates new system notice with type NoticeRepository. | // CreateRepositoryNotice creates new system notice with type NoticeRepository. | ||||||
| func CreateRepositoryNotice(desc string) error { | func CreateRepositoryNotice(desc string) error { | ||||||
| 	return CreateNotice(NoticeRepository, desc) | 	return createNotice(x, NoticeRepository, desc) | ||||||
| } | } | ||||||
|  |  | ||||||
| // RemoveAllWithNotice removes all directories in given path and | // RemoveAllWithNotice removes all directories in given path and | ||||||
| // creates a system notice when error occurs. | // creates a system notice when error occurs. | ||||||
| func RemoveAllWithNotice(title, path string) { | func RemoveAllWithNotice(title, path string) { | ||||||
|  | 	removeAllWithNotice(x, title, path) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func removeAllWithNotice(e Engine, title, path string) { | ||||||
| 	var err error | 	var err error | ||||||
| 	// workaround for Go not being able to remove read-only files/folders: https://github.com/golang/go/issues/9606 | 	// workaround for Go not being able to remove read-only files/folders: https://github.com/golang/go/issues/9606 | ||||||
| 	// this bug should be fixed on Go 1.7, so the workaround should be removed when Gogs don't support Go 1.6 anymore: | 	// this bug should be fixed on Go 1.7, so the workaround should be removed when Gogs don't support Go 1.6 anymore: | ||||||
| @@ -91,7 +94,7 @@ func RemoveAllWithNotice(title, path string) { | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		desc := fmt.Sprintf("%s [%s]: %v", title, path, err) | 		desc := fmt.Sprintf("%s [%s]: %v", title, path, err) | ||||||
| 		log.Warn(desc) | 		log.Warn(desc) | ||||||
| 		if err = CreateRepositoryNotice(desc); err != nil { | 		if err = createNotice(e, NoticeRepository, desc); err != nil { | ||||||
| 			log.Error(4, "CreateRepositoryNotice: %v", err) | 			log.Error(4, "CreateRepositoryNotice: %v", err) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -412,13 +412,18 @@ func (repo *Repository) ComposeMetas() map[string]string { | |||||||
| } | } | ||||||
|  |  | ||||||
| // DeleteWiki removes the actual and local copy of repository wiki. | // DeleteWiki removes the actual and local copy of repository wiki. | ||||||
| func (repo *Repository) DeleteWiki() { | func (repo *Repository) DeleteWiki() error { | ||||||
| 	wikiPaths := []string{repo.WikiPath(), repo.LocalWikiPath()} | 	return repo.deleteWiki(x) | ||||||
| 	for _, wikiPath := range wikiPaths { |  | ||||||
| 		RemoveAllWithNotice("Delete repository wiki", wikiPath) |  | ||||||
| } | } | ||||||
|  |  | ||||||
| 	x.Where("repo_id = ?", repo.ID).And("type = ?", UnitTypeWiki).Delete(new(RepoUnit)) | func (repo *Repository) deleteWiki(e Engine) error { | ||||||
|  | 	wikiPaths := []string{repo.WikiPath(), repo.LocalWikiPath()} | ||||||
|  | 	for _, wikiPath := range wikiPaths { | ||||||
|  | 		removeAllWithNotice(e, "Delete repository wiki", wikiPath) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	_, err := e.Where("repo_id = ?", repo.ID).And("type = ?", UnitTypeWiki).Delete(new(RepoUnit)) | ||||||
|  | 	return err | ||||||
| } | } | ||||||
|  |  | ||||||
| func (repo *Repository) getAssignees(e Engine) (_ []*User, err error) { | func (repo *Repository) getAssignees(e Engine) (_ []*User, err error) { | ||||||
| @@ -1620,27 +1625,25 @@ func DeleteRepository(uid, repoID int64) error { | |||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// Remove repository files. | 	// FIXME: Remove repository files should be executed after transaction succeed. | ||||||
| 	repoPath := repo.repoPath(sess) | 	repoPath := repo.repoPath(sess) | ||||||
| 	RemoveAllWithNotice("Delete repository files", repoPath) | 	removeAllWithNotice(sess, "Delete repository files", repoPath) | ||||||
|  |  | ||||||
| 	repo.DeleteWiki() | 	repo.deleteWiki(sess) | ||||||
|  |  | ||||||
| 	// Remove attachment files. | 	// Remove attachment files. | ||||||
| 	for i := range attachmentPaths { | 	for i := range attachmentPaths { | ||||||
| 		RemoveAllWithNotice("Delete attachment", attachmentPaths[i]) | 		removeAllWithNotice(sess, "Delete attachment", attachmentPaths[i]) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// Remove LFS objects | 	// Remove LFS objects | ||||||
| 	var lfsObjects []*LFSMetaObject | 	var lfsObjects []*LFSMetaObject | ||||||
|  |  | ||||||
| 	if err = sess.Where("repository_id=?", repoID).Find(&lfsObjects); err != nil { | 	if err = sess.Where("repository_id=?", repoID).Find(&lfsObjects); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	for _, v := range lfsObjects { | 	for _, v := range lfsObjects { | ||||||
| 		count, err := sess.Count(&LFSMetaObject{Oid: v.Oid}) | 		count, err := sess.Count(&LFSMetaObject{Oid: v.Oid}) | ||||||
|  |  | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return err | 			return err | ||||||
| 		} | 		} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user