forked from jdavid/walkhub-service
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathembedlog.go
71 lines (61 loc) · 1.86 KB
/
embedlog.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
// Walkhub
// Copyright (C) 2015 Pronovix
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
package walkhub
import (
"errors"
"fmt"
"net/http"
"time"
"gitlab.com/tamasd/ab"
)
type EmbedLog struct {
UUID string `dbtype:"uuid" dbdefault:"uuid_generate_v4()" json:"uuid"`
IPAddr string `json:"ip"`
Created time.Time `json:"created"`
Site string `json:"site"`
Mail string `json:"mail"`
}
func (el *EmbedLog) GetID() string {
return el.UUID
}
func (el *EmbedLog) Validate() error {
if el.Site == "" {
return errors.New("site is empty")
}
return nil
}
func embedlogService(ec *ab.EntityController) ab.Service {
res := ab.EntityResource(ec, &EmbedLog{}, ab.EntityResourceConfig{
DisableList: true,
DisableGet: true,
DisablePut: true,
DisableDelete: true,
})
res.AddPostEvent(ab.ResourceEventCallback{
BeforeCallback: func(r *http.Request, d ab.Resource) {
el := d.(*EmbedLog)
el.UUID = ""
el.Created = time.Now()
el.IPAddr = r.RemoteAddr
},
AfterCallback: func(r *http.Request, d ab.Resource) {
db := ab.GetDB(r)
el := d.(*EmbedLog)
DBLog(db, ec, "embedlog", fmt.Sprintf("%s (%s) has created an embed log on %s at %s", el.Mail, el.IPAddr, el.Site, el.Created.String()))
},
})
return res
}