Merge pull request #5696 from xiang90/fix_panic

etcdserver: fix panic when getting header of raft request
This commit is contained in:
Xiang Li 2016-06-16 13:58:50 -07:00 committed by GitHub
commit 2d08e093c1

View File

@ -30,7 +30,12 @@ func newAuthApplierV3(as auth.AuthStore, base applierV3) *authApplierV3 {
}
func (aa *authApplierV3) Apply(r *pb.InternalRaftRequest) *applyResult {
user := r.Header.Username
var user string
if r.Header != nil {
// backward-compatible with pre-3.0 releases when internalRaftRequest
// does not have header field
user = r.Header.Username
}
if needAdminPermission(r) && !aa.as.IsAdminPermitted(user) {
return &applyResult{err: auth.ErrPermissionDenied}
}