Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

googlecloudpubsubreceiver: google.cloud.audit.Auth orizationInfo has no known field with JSON name permissionType #33400

Closed
rafaeljesus opened this issue Jun 5, 2024 · 11 comments

Comments

@rafaeljesus
Copy link

Component(s)

receiver/googlecloudpubsub

What happened?

Description

I have a logging sink exporting writing logs to a pubsub topic that the pubsub receiver is consuming from,

the logging sink inclusion filter is as follows:

NOT (
  (resource.type="k8s_container" OR resource.type="k8s_pod") AND
  NOT resource.labels.namespace_name=~"kube-*"
) AND
NOT resource.type="cloud_run_revision"

below is the screenshot of the data in Cloud Logging, as you can see there is a permissionType: "ADMIN_READ"

Screenshot 2024-06-05 at 17 13 25

Expected Result

data to be exported to the internal logging system

Actual Result

data is not being exported to the internal logging system, and instead, I am having the following error in logs "google.cloud.audit.AuthorizationInfo has no known field with JSON name permissionType"

Collector version

0.95.0

Environment information

Environment

GKE

OpenTelemetry Collector configuration

config:
  exporters:
    otelarrow/logs:
      endpoint: 'ingest.lightstep.com:443'
      headers:
        lightstep-access-token: '${LS_TOKEN}'
  receivers:
    googlecloudpubsub:
      encoding: cloud_logging
      project: org-eu1-staging
      subscription: projects/org-eu1-staging/subscriptions/org-logs-forwarder
  service:
    pipelines:
      logs:
        receivers:
          - googlecloudpubsub
        exporters:
          - otelarrow/logs

Log output

github.com/open-telemetry/opentelemetry-collector-contrib/receiver/googlecloudpubsubreceiver.(*pubsubReceiver).handleCloudLoggingLogEntry
        github.com/open-telemetry/opentelemetry-collector-contrib/receiver/googlecloudpubsubreceiver@v0.99.0/receiver.go:150
github.com/open-telemetry/opentelemetry-collector-contrib/receiver/googlecloudpubsubreceiver.(*pubsubReceiver).createReceiverHandler.func1
        github.com/open-telemetry/opentelemetry-collector-contrib/receiver/googlecloudpubsubreceiver@v0.99.0/receiver.go:299
github.com/open-telemetry/opentelemetry-collector-contrib/receiver/googlecloudpubsubreceiver/internal.(*StreamHandler).responseStream
        github.com/open-telemetry/opentelemetry-collector-contrib/receiver/googlecloudpubsubreceiver@v0.99.0/internal/handler.go:193
2024-06-05T17:05:08.890Z        error   googlecloudpubsubreceiver@v0.99.0/receiver.go:150       got an error    {"kind": "receiver", "name": "googlecloudpubsub", "data_type": "logs", "error": "google.cloud.audit.AuthorizationInfo has no known field with JSON name permissionType"}

Additional context

No response

@rafaeljesus rafaeljesus added bug Something isn't working needs triage New item requiring triage labels Jun 5, 2024
Copy link
Contributor

github-actions bot commented Jun 5, 2024

Pinging code owners:

See Adding Labels via Comments if you do not have permissions to add labels yourself.

@alexvanboxel
Copy link
Contributor

alexvanboxel commented Jun 5, 2024

This is indeed an issue I've saw as well, I have the fix, but first this one needs to go through: #33247 (because I have a fix ontop of the this PR, as it will make the parsing configurable).

The solution will be to disable the Protobuf based parsing (I want to get rid of that, it's not a good idea). The fix will be braking through, as the default will be just JSON based parsing.

@rafaeljesus
Copy link
Author

@alexvanboxel thanks for the quick response! I will keep an eye on the other issues then

@alexvanboxel
Copy link
Contributor

Thank you for the issue, now I have something to link the fix to.

Copy link
Contributor

github-actions bot commented Aug 5, 2024

This issue has been inactive for 60 days. It will be closed in 60 days if there is no activity. To ping code owners by adding a component label, see Adding Labels via Comments, or if you are unsure of which component this issue relates to, please ping @open-telemetry/collector-contrib-triagers. If this issue is still relevant, please ping the code owners or leave a comment explaining why it is still relevant. Otherwise, please close it.

Pinging code owners:

See Adding Labels via Comments if you do not have permissions to add labels yourself.

@github-actions github-actions bot added the Stale label Aug 5, 2024
Copy link
Contributor

github-actions bot commented Oct 4, 2024

This issue has been closed as inactive because it has been stale for 120 days with no activity.

@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Oct 4, 2024
@azat
Copy link

azat commented Nov 23, 2024

Looks like it has not been fixed

@mdgregor
Copy link

This is still an issue, does anyone have a work around?

@ingodwerust
Copy link

@mdgregor the only workaround is to build collector from alexvanboxel's fork from PR mentioned earlier

@alexvanboxel
Copy link
Contributor

There is a PR for the receiver that adds support for extensions: #37137

This allows for the Cloud Logging support to be extracted. We don't use this internally at all. I will try to push for the extracted part, but probably will need a co-owner of that component.

@mdgregor
Copy link

okay thanks so much!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

6 participants