}
}
- if err = sess.Commit(); err != nil {
- return nil, err
- }
+
if u.IsOrganization() {
t, err := u.GetOwnerTeam()
if err = NewRepoAction(u, repo); err != nil {
log.Error(4, "NewRepoAction: %v", err)
}
-
+
+ if _, err = sess.Exec(
+ "UPDATE `repository` SET num_forks = num_forks + 1 WHERE id = ?", oldRepo.Id); err != nil {
+ sess.Rollback()
+ return nil, err
+ }
+
+ if err = sess.Commit(); err != nil {
+ return nil, err
+ }
repoPath := RepoPath(u.Name, repo.Name)
_, stderr, err := process.ExecTimeout(10*time.Minute,
}
return repo, nil
+
}
err = models.StarRepo(ctx.User.Id, ctx.Repo.Repository.Id, false)
case "fork":
repo, error := models.ForkRepository(ctx.User, ctx.Repo.Repository)
- log.Info("Tried to fork a repo!")
- log.Info("Repo thing is " + repo.Name)
if error != nil {
+ log.Error(4, "Action(%s): %v", ctx.Params(":action"), error)
+ ctx.JSON(200, map[string]interface{}{
+ "ok": false,
+ "err": error.Error(),
+ })
+ return
+ }
+ if error == nil {
+ ctx.Redirect(setting.AppSubUrl + "/" + repo.Owner.Name + "/" + repo.Name)
- ctx.Redirect(setting.AppSubUrl + "/" + ctx.User.Name + "/" + repo.Name)
return
}
case "desc":