|
@@ -12,6 +12,7 @@ import (
|
|
|
"path/filepath"
|
|
|
"strings"
|
|
|
"time"
|
|
|
+ "unicode/utf8"
|
|
|
|
|
|
git "github.com/libgit2/git2go"
|
|
|
|
|
@@ -59,7 +60,7 @@ func IsRepositoryExist(user *User, repoName string) (bool, error) {
|
|
|
}
|
|
|
|
|
|
// CreateRepository creates a repository for given user or orgnaziation.
|
|
|
-func CreateRepository(user *User, repoName, desc string, private bool, initReadme bool, repoLang string) (*Repository, error) {
|
|
|
+func CreateRepository(user *User, repoName, desc, repoLang string, private bool, initReadme bool) (*Repository, error) {
|
|
|
isExist, err := IsRepositoryExist(user, repoName)
|
|
|
if err != nil {
|
|
|
return nil, err
|
|
@@ -67,11 +68,6 @@ func CreateRepository(user *User, repoName, desc string, private bool, initReadm
|
|
|
return nil, ErrRepoAlreadyExist
|
|
|
}
|
|
|
|
|
|
- f := RepoPath(user.Name, repoName)
|
|
|
- err = initRepository(f, initReadme, repoLang)
|
|
|
- if err != nil {
|
|
|
- return nil, err
|
|
|
- }
|
|
|
repo := &Repository{
|
|
|
OwnerId: user.Id,
|
|
|
Name: repoName,
|
|
@@ -79,6 +75,11 @@ func CreateRepository(user *User, repoName, desc string, private bool, initReadm
|
|
|
Description: desc,
|
|
|
Private: private,
|
|
|
}
|
|
|
+
|
|
|
+ f := RepoPath(user.Name, repoName)
|
|
|
+ if err = initRepository(f, user, repo, initReadme, repoLang); err != nil {
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
session := orm.NewSession()
|
|
|
defer session.Close()
|
|
|
session.Begin()
|
|
@@ -127,30 +128,35 @@ func CreateRepository(user *User, repoName, desc string, private bool, initReadm
|
|
|
return repo, nil
|
|
|
}
|
|
|
|
|
|
-var (
|
|
|
- defaultREADME = "readme first"
|
|
|
-)
|
|
|
-
|
|
|
// InitRepository initializes README and .gitignore if needed.
|
|
|
-func initRepository(f string, initReadme bool, repoLang string) error {
|
|
|
- readme := "README"
|
|
|
- workdir := os.TempDir()
|
|
|
+func initRepository(f string, user *User, repo *Repository, initReadme bool, repoLang string) error {
|
|
|
+ fileName := map[string]string{
|
|
|
+ "readme": "README.md",
|
|
|
+ "gitign": ".gitignore",
|
|
|
+ }
|
|
|
+ workdir := os.TempDir() + fmt.Sprintf("%d", time.Now().Nanosecond())
|
|
|
|
|
|
sig := &git.Signature{
|
|
|
- Name: "Rand Om Hacker",
|
|
|
- Email: "[email protected]",
|
|
|
+ Name: user.Name,
|
|
|
+ Email: user.Email,
|
|
|
When: time.Now(),
|
|
|
}
|
|
|
|
|
|
// README
|
|
|
- err := ioutil.WriteFile(filepath.Join(workdir, readme),
|
|
|
- []byte(defaultREADME), 0644)
|
|
|
- if err != nil {
|
|
|
+ defaultReadme := repo.Name + "\n" + strings.Repeat("=",
|
|
|
+ utf8.RuneCountInString(repo.Name)) + "\n\n" + repo.Description
|
|
|
+ if err := ioutil.WriteFile(filepath.Join(workdir, fileName["readme"]),
|
|
|
+ []byte(defaultReadme), 0644); err != nil {
|
|
|
return err
|
|
|
}
|
|
|
|
|
|
// .gitignore
|
|
|
- // TODO:
|
|
|
+ // if err := ioutil.WriteFile(filepath.Join(workdir, gitIgn),
|
|
|
+ // []byte(defaultREADME), 0644); err != nil {
|
|
|
+ // return err
|
|
|
+ // }
|
|
|
+
|
|
|
+ // LICENSE
|
|
|
|
|
|
rp, err := git.InitRepository(f, true)
|
|
|
if err != nil {
|
|
@@ -163,8 +169,7 @@ func initRepository(f string, initReadme bool, repoLang string) error {
|
|
|
return err
|
|
|
}
|
|
|
|
|
|
- err = idx.AddByPath(readme)
|
|
|
- if err != nil {
|
|
|
+ if err = idx.AddByPath(fileName["readme"]); err != nil {
|
|
|
return err
|
|
|
}
|
|
|
|
|
@@ -173,14 +178,13 @@ func initRepository(f string, initReadme bool, repoLang string) error {
|
|
|
return err
|
|
|
}
|
|
|
|
|
|
- message := "add readme"
|
|
|
+ message := "Init commit"
|
|
|
tree, err := rp.LookupTree(treeId)
|
|
|
if err != nil {
|
|
|
return err
|
|
|
}
|
|
|
|
|
|
- _, err = rp.CreateCommit("HEAD", sig, sig, message, tree)
|
|
|
- if err != nil {
|
|
|
+ if _, err = rp.CreateCommit("HEAD", sig, sig, message, tree); err != nil {
|
|
|
return err
|
|
|
}
|
|
|
|