Browse Source

Add code of delete user

tags/v1.2.0-rc1
Unknown 11 years ago
parent
commit
4b92a6c2df
6 changed files with 35 additions and 25 deletions
  1. +3
    -1
      bee.json
  2. +1
    -0
      conf/app.ini
  3. +6
    -15
      gogs.go
  4. +15
    -5
      models/models.go
  5. +1
    -1
      models/repo.go
  6. +9
    -3
      models/user.go

+ 3
- 1
bee.json View File

@@ -14,6 +14,8 @@
"utils"
]
},
"cmd_args": [],
"cmd_args": [
"web"
],
"envs": []
}

+ 1
- 0
conf/app.ini View File

@@ -10,3 +10,4 @@ HOST =
NAME = gogs
USER = root
PASSWD =
PASSWD_jiahua = root

+ 6
- 15
gogs.go View File

@@ -1,16 +1,6 @@
// Copyright 2013-2014 gogs authors.
//
// Licensed under the Apache License, Version 2.0 (the "License"): you may
// not use this file except in compliance with the License. You may obtain
// a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
// License for the specific language governing permissions and limitations
// under the License.
// 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.

// gogs(Go Git Service) is a Go clone of Github.
package main
@@ -27,7 +17,7 @@ import (
// Test that go1.1 tag above is included in builds. main.go refers to this definition.
const go11tag = true

const APP_VER = "0.0.0.0218"
const APP_VER = "0.0.0.0219"

func init() {
runtime.GOMAXPROCS(runtime.NumCPU())
@@ -35,7 +25,7 @@ func init() {

func main() {
app := cli.NewApp()
app.Name = "gogs"
app.Name = "Gogs"
app.Usage = "Go Git Service"
app.Version = APP_VER
app.Commands = []cli.Command{
@@ -46,4 +36,5 @@ func main() {
cli.BoolFlag{"noterm", "disable color output"},
}...)
app.Run(os.Args)
println("wo cao???")
}

+ 15
- 5
models/models.go View File

@@ -7,6 +7,7 @@ package models
import (
"fmt"
"os"
"os/user"

_ "github.com/go-sql-driver/mysql"
"github.com/lunny/xorm"
@@ -47,18 +48,27 @@ func setEngine() {
dbUser := utils.Cfg.MustValue("database", "USER")
dbPwd := utils.Cfg.MustValue("database", "PASSWD")

var err error
uname, err := user.Current()
if err != nil {
fmt.Printf("models.init -> fail to get user: %s\n", err)
os.Exit(2)
}

if uname.Username == "jiahuachen" {
dbPwd = utils.Cfg.MustValue("database", "PASSWD_jiahua")
}

switch dbType {
case "mysql":
orm, err = xorm.NewEngine("mysql", fmt.Sprintf("%v:%v@%v/%v?charset=utf8",
dbUser, dbPwd, dbHost, dbName))
default:
log.Critical("Unknown database type: %s", dbType)
fmt.Printf("Unknown database type: %s\n", dbType)
os.Exit(2)
}

if err != nil {
log.Critical("models.init -> Conntect database: %s", dbType)
fmt.Printf("models.init -> fail to conntect database: %s\n", dbType)
os.Exit(2)
}

@@ -73,7 +83,7 @@ func init() {
setEngine()
err := orm.Sync(new(User), new(PublicKey), new(Repo), new(Access))
if err != nil {
log.Error("sync database struct error: %s", err)
os.Exit(1)
fmt.Printf("sync database struct error: %s\n", err)
os.Exit(2)
}
}

+ 1
- 1
models/repo.go View File

@@ -77,7 +77,7 @@ func CreateRepository(user *User, reposName string) (*Repo, error) {
return &repo, nil
}

// list one user's repository
// GetRepositories returns the list of repositories of given user.
func GetRepositories(user *User) ([]Repo, error) {
repos := make([]Repo, 0)
err := orm.Find(&repos, &Repo{OwnerId: user.Id})


+ 9
- 3
models/user.go View File

@@ -74,6 +74,7 @@ type Action struct {
}

var (
ErrUserOwnRepos = errors.New("User still have ownership of repositories")
ErrUserAlreadyExist = errors.New("User already exist")
ErrUserNotExist = errors.New("User does not exist")
)
@@ -95,7 +96,6 @@ func RegisterUser(user *User) (err error) {

user.LowerName = strings.ToLower(user.Name)
user.Avatar = utils.EncodeMd5(user.Email)
user.Created = time.Now()
user.Updated = time.Now()
user.EncodePasswd()
_, err = orm.Insert(user)
@@ -110,8 +110,14 @@ func UpdateUser(user *User) (err error) {

// DeleteUser completely deletes everything of the user.
func DeleteUser(user *User) error {
// TODO: check if has ownership of any repository.
_, err := orm.Delete(user)
repos, err := GetRepositories(user)
if err != nil {
return errors.New("modesl.GetRepositories: " + err.Error())
} else if len(repos) > 0 {
return ErrUserOwnRepos
}

_, err = orm.Delete(user)
// TODO: delete and update follower information.
return err
}


Loading…
Cancel
Save