Skip to content

Commit

Permalink
[rbac] Fix read of uninitialized variable (grpc#36244)
Browse files Browse the repository at this point in the history
When parsing `action` fails we don't touch that memory in the object loader, yet we still call `PostLoad` to fill in any other errors. In that case we are currently relying on undefined behavior to have this test work -- why msan didn't flag it upsets me.

Default `action` to some safe value to avoid the undefined behavior, and log the bad action in the error message to ease debugging here in the future.

Closes grpc#36244

COPYBARA_INTEGRATE_REVIEW=grpc#36244 from ctiller:rbac-undef d94b04a
PiperOrigin-RevId: 621599880
  • Loading branch information
ctiller authored and copybara-github committed Apr 3, 2024
1 parent 0aebe1c commit 74176f5
Showing 1 changed file with 2 additions and 2 deletions.
4 changes: 2 additions & 2 deletions src/core/ext/filters/rbac/rbac_service_config_parser.cc
Original file line number Diff line number Diff line change
Expand Up @@ -203,7 +203,7 @@ struct RbacConfig {
ValidationErrors* errors);
};

int action;
int action = static_cast<int>(Rbac::Action::kDeny);
std::map<std::string, Policy> policies;
// Defaults to kNone since its json field is optional.
Rbac::AuditCondition audit_condition = Rbac::AuditCondition::kNone;
Expand Down Expand Up @@ -801,7 +801,7 @@ void RbacConfig::RbacPolicy::Rules::JsonPostLoad(const Json& json,
if (rbac_action != Rbac::Action::kAllow &&
rbac_action != Rbac::Action::kDeny) {
ValidationErrors::ScopedField field(errors, ".action");
errors->AddError("unknown action");
errors->AddError(absl::StrCat("unknown action ", rbac_action));
}
// Parse and validate audit_condition field.
auto condition = LoadJsonObjectField<int>(json.object(), args,
Expand Down

0 comments on commit 74176f5

Please sign in to comment.