// checkPrivilege implements the DescriptorAccessor interface. func (p *planner) checkPrivilege(descriptor sqlbase.DescriptorProto, privilege privilege.Kind) error { if descriptor.GetPrivileges().CheckPrivilege(p.session.User, privilege) { return nil } return fmt.Errorf("user %s does not have %s privilege on %s %s", p.session.User, privilege, descriptor.TypeName(), descriptor.GetName()) }
// anyPrivilege implements the DescriptorAccessor interface. func (p *planner) anyPrivilege(descriptor sqlbase.DescriptorProto) error { if descriptor.GetPrivileges().AnyPrivilege(p.session.User) || isVirtualDescriptor(descriptor) { return nil } return fmt.Errorf("user %s has no privileges on %s %s", p.session.User, descriptor.TypeName(), descriptor.GetName()) }