|  | @@ -113,8 +113,34 @@ func ViewIssue(ctx *middleware.Context, params martini.Params) {
 | 
	
		
			
				|  |  |  		return
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	// Get posters.
 | 
	
		
			
				|  |  | +	u, err := models.GetUserById(issue.PosterId)
 | 
	
		
			
				|  |  | +	if err != nil {
 | 
	
		
			
				|  |  | +		ctx.Handle(200, "issue.ViewIssue(get poster): %v", err)
 | 
	
		
			
				|  |  | +		return
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +	issue.Poster = u
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	// Get comments.
 | 
	
		
			
				|  |  | +	comments, err := models.GetIssueComments(issue.Id)
 | 
	
		
			
				|  |  | +	if err != nil {
 | 
	
		
			
				|  |  | +		ctx.Handle(200, "issue.ViewIssue(get comments): %v", err)
 | 
	
		
			
				|  |  | +		return
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	// Get posters.
 | 
	
		
			
				|  |  | +	for i := range comments {
 | 
	
		
			
				|  |  | +		u, err := models.GetUserById(comments[i].PosterId)
 | 
	
		
			
				|  |  | +		if err != nil {
 | 
	
		
			
				|  |  | +			ctx.Handle(200, "issue.ViewIssue(get poster): %v", err)
 | 
	
		
			
				|  |  | +			return
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +		comments[i].Poster = u
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  	ctx.Data["Title"] = issue.Name
 | 
	
		
			
				|  |  |  	ctx.Data["Issue"] = issue
 | 
	
		
			
				|  |  | +	ctx.Data["Comments"] = comments
 | 
	
		
			
				|  |  |  	ctx.Data["IsRepoToolbarIssues"] = true
 | 
	
		
			
				|  |  |  	ctx.Data["IsRepoToolbarIssuesList"] = false
 | 
	
		
			
				|  |  |  	ctx.HTML(200, "issue/view")
 | 
	
	
		
			
				|  | @@ -132,7 +158,7 @@ func UpdateIssue(ctx *middleware.Context, params martini.Params, form auth.Creat
 | 
	
		
			
				|  |  |  		if err == models.ErrIssueNotExist {
 | 
	
		
			
				|  |  |  			ctx.Handle(404, "issue.UpdateIssue", err)
 | 
	
		
			
				|  |  |  		} else {
 | 
	
		
			
				|  |  | -			ctx.Handle(200, "issue.UpdateIssue", err)
 | 
	
		
			
				|  |  | +			ctx.Handle(200, "issue.UpdateIssue(get issue)", err)
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  |  		return
 | 
	
		
			
				|  |  |  	}
 | 
	
	
		
			
				|  | @@ -148,10 +174,48 @@ func UpdateIssue(ctx *middleware.Context, params martini.Params, form auth.Creat
 | 
	
		
			
				|  |  |  	issue.Labels = form.Labels
 | 
	
		
			
				|  |  |  	issue.Content = form.Content
 | 
	
		
			
				|  |  |  	if err = models.UpdateIssue(issue); err != nil {
 | 
	
		
			
				|  |  | -		ctx.Handle(200, "issue.UpdateIssue", err)
 | 
	
		
			
				|  |  | +		ctx.Handle(200, "issue.UpdateIssue(update issue)", err)
 | 
	
		
			
				|  |  |  		return
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	ctx.Data["Title"] = issue.Name
 | 
	
		
			
				|  |  |  	ctx.Data["Issue"] = issue
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +func Comment(ctx *middleware.Context, params martini.Params) {
 | 
	
		
			
				|  |  | +	index, err := base.StrTo(ctx.Query("issueIndex")).Int()
 | 
	
		
			
				|  |  | +	if err != nil {
 | 
	
		
			
				|  |  | +		ctx.Handle(404, "issue.Comment", err)
 | 
	
		
			
				|  |  | +		return
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	issue, err := models.GetIssueByIndex(ctx.Repo.Repository.Id, int64(index))
 | 
	
		
			
				|  |  | +	if err != nil {
 | 
	
		
			
				|  |  | +		if err == models.ErrIssueNotExist {
 | 
	
		
			
				|  |  | +			ctx.Handle(404, "issue.Comment", err)
 | 
	
		
			
				|  |  | +		} else {
 | 
	
		
			
				|  |  | +			ctx.Handle(200, "issue.Comment(get issue)", err)
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +		return
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	content := ctx.Query("content")
 | 
	
		
			
				|  |  | +	if len(content) == 0 {
 | 
	
		
			
				|  |  | +		ctx.Handle(404, "issue.Comment", err)
 | 
	
		
			
				|  |  | +		return
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	switch params["action"] {
 | 
	
		
			
				|  |  | +	case "new":
 | 
	
		
			
				|  |  | +		if err = models.CreateComment(ctx.User.Id, issue.Id, 0, 0, content); err != nil {
 | 
	
		
			
				|  |  | +			ctx.Handle(500, "issue.Comment(create comment)", err)
 | 
	
		
			
				|  |  | +			return
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +		log.Trace("%s Comment created: %d", ctx.Req.RequestURI, issue.Id)
 | 
	
		
			
				|  |  | +	default:
 | 
	
		
			
				|  |  | +		ctx.Handle(404, "issue.Comment", err)
 | 
	
		
			
				|  |  | +		return
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	ctx.Redirect(fmt.Sprintf("/%s/%s/issues/%d", ctx.User.Name, ctx.Repo.Repository.Name, index))
 | 
	
		
			
				|  |  | +}
 |