forked from medcl/infini-gateway
-
Notifications
You must be signed in to change notification settings - Fork 1
/
logging.go
32 lines (26 loc) · 930 Bytes
/
logging.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
package pipelines
import (
"github.com/infinitbyte/framework/core/pipeline"
"github.com/nickanderegg/elasticsearch-proxy/config"
"github.com/nickanderegg/elasticsearch-proxy/model"
)
type LoggingJoint struct {
}
func (joint LoggingJoint) Name() string {
return "logging"
}
func (joint LoggingJoint) Process(c *pipeline.Context) error {
request := model.Request{}
request.Url = c.MustGetString(config.Url)
request.Upstream = c.GetStringOrDefault(config.Upstream, "")
request.Method = c.MustGetString(config.Method)
request.Body = c.GetStringOrDefault(config.Body, "")
request.Message = c.GetStringOrDefault(config.Message, "")
if c.Has(config.ResponseStatusCode) {
request.ResponseStatusCode = c.MustGetInt(config.ResponseStatusCode)
}
request.Response = c.GetStringOrDefault(config.Response, "")
request.ResponseSize = c.GetInt64OrDefault(config.ResponseSize, 0)
model.CreateRequest(&request)
return nil
}