mirror of https://github.com/hashicorp/consul
agent: fix deadlock reading tokens from state
parent
bebb5d9641
commit
1264f7edf3
|
@ -538,7 +538,7 @@ func TestAgent_PersistService(t *testing.T) {
|
||||||
t.Fatalf("err: %s", err)
|
t.Fatalf("err: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
expected, err := json.Marshal(svc)
|
expected, err := json.Marshal(&persistedService{Service: svc})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("err: %s", err)
|
t.Fatalf("err: %s", err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -133,9 +133,8 @@ func (l *localState) AddServiceToken(id, token string) {
|
||||||
|
|
||||||
// ServiceToken returns the configured ACL token for the given
|
// ServiceToken returns the configured ACL token for the given
|
||||||
// service ID. If none is present, the agent's token is returned.
|
// service ID. If none is present, the agent's token is returned.
|
||||||
|
// Assumes a lock is already established on the state.
|
||||||
func (l *localState) ServiceToken(id string) string {
|
func (l *localState) ServiceToken(id string) string {
|
||||||
l.RLock()
|
|
||||||
defer l.RUnlock()
|
|
||||||
token := l.serviceTokens[id]
|
token := l.serviceTokens[id]
|
||||||
if token == "" {
|
if token == "" {
|
||||||
token = l.config.ACLToken
|
token = l.config.ACLToken
|
||||||
|
@ -193,10 +192,9 @@ func (l *localState) AddCheckToken(id, token string) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// CheckToken is used to return the configured health check token, or
|
// CheckToken is used to return the configured health check token, or
|
||||||
// if none is configured, the default agent ACL token.
|
// if none is configured, the default agent ACL token. Assumes a lock
|
||||||
|
// has already been taken on the state.
|
||||||
func (l *localState) CheckToken(id string) string {
|
func (l *localState) CheckToken(id string) string {
|
||||||
l.RLock()
|
|
||||||
defer l.RUnlock()
|
|
||||||
token := l.checkTokens[id]
|
token := l.checkTokens[id]
|
||||||
if token == "" {
|
if token == "" {
|
||||||
token = l.config.ACLToken
|
token = l.config.ACLToken
|
||||||
|
|
Loading…
Reference in New Issue