Skip to content

Commit

Permalink
without using the cancel possible context leak
Browse files Browse the repository at this point in the history
  • Loading branch information
林益帆 committed Jan 3, 2018
1 parent bd39a99 commit 1abd58f
Showing 1 changed file with 8 additions and 7 deletions.
15 changes: 8 additions & 7 deletions hook.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,11 @@ import (
)

var (
// Fired if the
// index is not created
// ErrCannotCreateIndex Fired if the index is not created
ErrCannotCreateIndex = fmt.Errorf("Cannot create index")
)

// IndexNameFunc get index name
type IndexNameFunc func() string

type fireFunc func(entry *logrus.Entry, hook *ElasticHook, indexName string) error
Expand All @@ -42,7 +42,7 @@ func NewElasticHook(client *elastic.Client, host string, level logrus.Level, ind
return NewElasticHookWithFunc(client, host, level, func() string { return index })
}

// NewElasticHook creates new hook with asynchronous log
// NewAsyncElasticHook creates new hook with asynchronous log
// client - ElasticSearch client using gopkg.in/olivere/elastic.v5
// host - host of system
// level - log level
Expand Down Expand Up @@ -94,14 +94,17 @@ func newHookFuncAndFireFunc(client *elastic.Client, host string, level logrus.Le
exists, err := client.IndexExists(indexFunc()).Do(ctx)
if err != nil {
// Handle error
cancel()
return nil, err
}
if !exists {
createIndex, err := client.CreateIndex(indexFunc()).Do(ctx)
if err != nil {
cancel()
return nil, err
}
if !createIndex.Acknowledged {
cancel()
return nil, ErrCannotCreateIndex
}
}
Expand Down Expand Up @@ -161,14 +164,12 @@ func syncFireFunc(entry *logrus.Entry, hook *ElasticHook, indexName string) erro
return err
}

// Required for logrus
// hook implementation
// Levels Required for logrus hook implementation
func (hook *ElasticHook) Levels() []logrus.Level {
return hook.levels
}

// Cancels all calls to
// elastic
// Cancel all calls to elastic
func (hook *ElasticHook) Cancel() {
hook.ctxCancel()
}

0 comments on commit 1abd58f

Please sign in to comment.