8 changed files with 435 additions and 69 deletions
@ -0,0 +1,129 @@ |
|||
package rest |
|||
|
|||
import ( |
|||
"net/http" |
|||
"strconv" |
|||
) |
|||
|
|||
type SecurityVisitController struct { |
|||
BaseController |
|||
securityVisitDao *SecurityVisitDao |
|||
securityVisitService *SecurityVisitService |
|||
} |
|||
|
|||
//初始化方法
|
|||
func (this *SecurityVisitController) Init(context *Context) { |
|||
this.BaseController.Init(context) |
|||
|
|||
//手动装填本实例的Bean. 这里必须要用中间变量方可。
|
|||
b := context.GetBean(this.securityVisitDao) |
|||
if b, ok := b.(*SecurityVisitDao); ok { |
|||
this.securityVisitDao = b |
|||
} |
|||
|
|||
b = context.GetBean(this.securityVisitService) |
|||
if b, ok := b.(*SecurityVisitService); ok { |
|||
this.securityVisitService = b |
|||
} |
|||
|
|||
} |
|||
|
|||
//注册自己的路由。
|
|||
func (this *SecurityVisitController) RegisterRoutes() map[string]func(writer http.ResponseWriter, request *http.Request) { |
|||
|
|||
routeMap := make(map[string]func(writer http.ResponseWriter, request *http.Request)) |
|||
|
|||
//每个Controller需要主动注册自己的路由。
|
|||
routeMap["/api/security/visit/delete"] = this.Wrap(this.Delete, USER_ROLE_USER) |
|||
routeMap["/api/security/visit/detail"] = this.Wrap(this.Detail, USER_ROLE_USER) |
|||
routeMap["/api/security/visit/page"] = this.Wrap(this.Page, USER_ROLE_USER) |
|||
|
|||
return routeMap |
|||
} |
|||
|
|||
//查看详情。
|
|||
func (this *SecurityVisitController) Detail(writer http.ResponseWriter, request *http.Request) *WebResult { |
|||
|
|||
uuid := request.FormValue("uuid") |
|||
if uuid == "" { |
|||
return this.Error("图片缓存的uuid必填") |
|||
} |
|||
|
|||
securityVisit := this.securityVisitService.Detail(uuid) |
|||
|
|||
//验证当前之人是否有权限查看这么详细。
|
|||
user := this.checkUser(writer, request) |
|||
if user.Role != USER_ROLE_ADMINISTRATOR { |
|||
if securityVisit.UserUuid != user.Uuid { |
|||
panic("没有权限查看该图片缓存") |
|||
} |
|||
} |
|||
|
|||
return this.Success(securityVisit) |
|||
|
|||
} |
|||
|
|||
//按照分页的方式查询
|
|||
func (this *SecurityVisitController) Page(writer http.ResponseWriter, request *http.Request) *WebResult { |
|||
|
|||
//如果是根目录,那么就传入root.
|
|||
pageStr := request.FormValue("page") |
|||
pageSizeStr := request.FormValue("pageSize") |
|||
userUuid := request.FormValue("userUuid") |
|||
orderCreateTime := request.FormValue("orderCreateTime") |
|||
orderSize := request.FormValue("orderSize") |
|||
|
|||
user := this.checkUser(writer, request) |
|||
if user.Role != USER_ROLE_ADMINISTRATOR { |
|||
userUuid = user.Uuid |
|||
} |
|||
|
|||
var page int |
|||
if pageStr != "" { |
|||
page, _ = strconv.Atoi(pageStr) |
|||
} |
|||
|
|||
pageSize := 200 |
|||
if pageSizeStr != "" { |
|||
tmp, err := strconv.Atoi(pageSizeStr) |
|||
if err == nil { |
|||
pageSize = tmp |
|||
} |
|||
} |
|||
|
|||
sortArray := []OrderPair{ |
|||
{ |
|||
key: "create_time", |
|||
value: orderCreateTime, |
|||
}, |
|||
{ |
|||
key: "size", |
|||
value: orderSize, |
|||
}, |
|||
} |
|||
|
|||
pager := this.securityVisitDao.Page(page, pageSize, userUuid, sortArray) |
|||
|
|||
return this.Success(pager) |
|||
} |
|||
|
|||
//删除一条记录
|
|||
func (this *SecurityVisitController) Delete(writer http.ResponseWriter, request *http.Request) *WebResult { |
|||
|
|||
uuid := request.FormValue("uuid") |
|||
if uuid == "" { |
|||
return this.Error("图片缓存的uuid必填") |
|||
} |
|||
|
|||
securityVisit := this.securityVisitDao.FindByUuid(uuid) |
|||
|
|||
//判断图片缓存的所属人是否正确
|
|||
user := this.checkUser(writer, request) |
|||
if user.Role != USER_ROLE_ADMINISTRATOR && securityVisit.UserUuid != user.Uuid { |
|||
return this.Error(CODE_WRAPPER_UNAUTHORIZED) |
|||
} |
|||
|
|||
this.securityVisitDao.Delete(securityVisit) |
|||
|
|||
return this.Success("删除成功!") |
|||
} |
|||
@ -0,0 +1,90 @@ |
|||
package rest |
|||
|
|||
import ( |
|||
"github.com/jinzhu/gorm" |
|||
_ "github.com/jinzhu/gorm/dialects/mysql" |
|||
"github.com/nu7hatch/gouuid" |
|||
"time" |
|||
) |
|||
|
|||
type SecurityVisitDao struct { |
|||
BaseDao |
|||
} |
|||
|
|||
//按照Id查询文件
|
|||
func (this *SecurityVisitDao) FindByUuid(uuid string) *SecurityVisit { |
|||
|
|||
// Read
|
|||
var securityVisit SecurityVisit |
|||
db := this.context.DB.Where(&SecurityVisit{Base: Base{Uuid: uuid}}).First(&securityVisit) |
|||
if db.Error != nil { |
|||
return nil |
|||
} |
|||
return &securityVisit |
|||
} |
|||
|
|||
//按照Id查询文件
|
|||
func (this *SecurityVisitDao) CheckByUuid(uuid string) *SecurityVisit { |
|||
|
|||
// Read
|
|||
var securityVisit SecurityVisit |
|||
db := this.context.DB.Where(&SecurityVisit{Base: Base{Uuid: uuid}}).First(&securityVisit) |
|||
this.PanicError(db.Error) |
|||
|
|||
return &securityVisit |
|||
|
|||
} |
|||
|
|||
//按分页条件获取分页
|
|||
func (this *SecurityVisitDao) Page(page int, pageSize int, userUuid string, sortArray []OrderPair) *Pager { |
|||
|
|||
var wp = &WherePair{} |
|||
|
|||
if userUuid != "" { |
|||
wp = wp.And(&WherePair{Query: "user_uuid = ?", Args: []interface{}{userUuid}}) |
|||
} |
|||
|
|||
var conditionDB *gorm.DB |
|||
conditionDB = this.context.DB.Model(&SecurityVisit{}).Where(wp.Query, wp.Args...) |
|||
|
|||
count := 0 |
|||
db := conditionDB.Count(&count) |
|||
this.PanicError(db.Error) |
|||
|
|||
var securityVisits []*SecurityVisit |
|||
db = conditionDB.Order(this.GetSortString(sortArray)).Offset(page * pageSize).Limit(pageSize).Find(&securityVisits) |
|||
this.PanicError(db.Error) |
|||
pager := NewPager(page, pageSize, count, securityVisits) |
|||
|
|||
return pager |
|||
} |
|||
|
|||
//创建
|
|||
func (this *SecurityVisitDao) Create(securityVisit *SecurityVisit) *SecurityVisit { |
|||
|
|||
timeUUID, _ := uuid.NewV4() |
|||
securityVisit.Uuid = string(timeUUID.String()) |
|||
securityVisit.CreateTime = time.Now() |
|||
securityVisit.UpdateTime = time.Now() |
|||
db := this.context.DB.Create(securityVisit) |
|||
this.PanicError(db.Error) |
|||
|
|||
return securityVisit |
|||
} |
|||
|
|||
//修改一条记录
|
|||
func (this *SecurityVisitDao) Save(securityVisit *SecurityVisit) *SecurityVisit { |
|||
|
|||
securityVisit.UpdateTime = time.Now() |
|||
db := this.context.DB.Save(securityVisit) |
|||
this.PanicError(db.Error) |
|||
|
|||
return securityVisit |
|||
} |
|||
|
|||
//删除一条记录
|
|||
func (this *SecurityVisitDao) Delete(securityVisit *SecurityVisit) { |
|||
|
|||
db := this.context.DB.Delete(&securityVisit) |
|||
this.PanicError(db.Error) |
|||
} |
|||
@ -0,0 +1,21 @@ |
|||
package rest |
|||
|
|||
/** |
|||
* 系统的所有访问记录均记录在此 |
|||
*/ |
|||
type SecurityVisit struct { |
|||
Base |
|||
SessionId string `json:"sessionId"` |
|||
UserUuid string `json:"userUuid"` |
|||
Ip string `json:"ip"` |
|||
Host string `json:"host"` |
|||
Uri string `json:"uri"` |
|||
Params string `json:"params"` |
|||
Cost int64 `json:"cost"` |
|||
Success bool `json:"success"` |
|||
} |
|||
|
|||
// set File's table name to be `profiles`
|
|||
func (SecurityVisit) TableName() string { |
|||
return TABLE_PREFIX + "security_visit" |
|||
} |
|||
@ -0,0 +1,32 @@ |
|||
package rest |
|||
|
|||
//@Service
|
|||
type SecurityVisitService struct { |
|||
Bean |
|||
securityVisitDao *SecurityVisitDao |
|||
userDao *UserDao |
|||
} |
|||
|
|||
//初始化方法
|
|||
func (this *SecurityVisitService) Init(context *Context) { |
|||
|
|||
//手动装填本实例的Bean. 这里必须要用中间变量方可。
|
|||
b := context.GetBean(this.securityVisitDao) |
|||
if b, ok := b.(*SecurityVisitDao); ok { |
|||
this.securityVisitDao = b |
|||
} |
|||
|
|||
b = context.GetBean(this.userDao) |
|||
if b, ok := b.(*UserDao); ok { |
|||
this.userDao = b |
|||
} |
|||
|
|||
} |
|||
|
|||
//获取某个文件的详情,会把父级依次倒着装进去。如果中途出错,直接抛出异常。
|
|||
func (this *SecurityVisitService) Detail(uuid string) *SecurityVisit { |
|||
|
|||
securityVisit := this.securityVisitDao.CheckByUuid(uuid) |
|||
|
|||
return securityVisit |
|||
} |
|||
Loading…
Reference in new issue