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

v1.9.30 Permission issues when using org_id!=1 in Grafana OSS #5096

Closed
dinfdsooff opened this issue Sep 30, 2024 · 5 comments
Closed

v1.9.30 Permission issues when using org_id!=1 in Grafana OSS #5096

dinfdsooff opened this issue Sep 30, 2024 · 5 comments
Labels
bug Something isn't working part:API part:auth/teams

Comments

@dinfdsooff
Copy link

dinfdsooff commented Sep 30, 2024

What went wrong?

What happened:

  • Plugin is not connected Unauthorized/Forbidden while accessing OnCall engine: /api/internal/v1/plugin/v2/status, status code: 403, check token
    Image
    Image

  • We use multiple organisations in Grafana OSS, and we want to connect org_id=2 with the engine, we managed to configure it for default org_id=1 but if we specify other organisation it breaks with permissions issues, the service account is created only in org_id=1.

  • Service account id sa-1-extsvc-grafana-oncall-app is created only in org_id=1 and not in the specified organization, for example org_id=2, so it works only for org_id=1

  • Tried to find any documentation or info how to configure the oncall plugin to work with other organisation other than the default and did not find any information

  • grafanaToken and onCallApiToken are not generated in the table public.plugin_setting for org_id!=1

What did you expect to happen:

  • I would expect plugin service account sa-2-extsvc-grafana-oncall-app to be generated for org_id=2 and authentication to work with the engine, or at least provide a way to create that manually.

  • I would expect to have Documentation:

    • a ReadMe or some info on how to setup OnCall plugin and Engine for organisation with org_id!=1 for Grafana OSS. It would be nice to include all the relevant info regarding this topic, such as current status and feature plans, env variables to configure, manual API calls that we need to trigger, if we need multiple Engines , DB, Redis, RabbitMQ, or one, how to do separation between organization data?
    • I would expect to have also some documentation or readme to explain the authentication flow between grafana <-> plugin <-> engine, for example if we need to create grafana token manually and configure them on the engine so it can access the API, and how to specify the org_id

How do we reproduce it?

  1. Install Grafana Oncall Plugin
  2. Enable the Grafana Plugin for both orgs
  3. curl -X POST -H "X-Grafana-Org-Id: 1" "https://grafana.xxxx.xxx/api/plugins/grafana-oncall-app/settings" \ -H "Content-Type: application/json" -H "Authorization: Basic xxxxxxxx" \ -d '{ "enabled": true, "jsonData": { "stackId": 5, "orgId": 100, "license":"OpenSource", "onCallApiUrl": "http://oncall-engine:8080/", "grafanaUrl": "http://grafana:80/" } }'
  4. curl -X POST -H "X-Grafana-Org-Id: 2" "https://grafana.xxxx.xxx/api/plugins/grafana-oncall-app/settings" \ -H "Content-Type: application/json" -H "Authorization: Basic xxxxxxxx" \ -d '{ "enabled": true, "jsonData": { "stackId": 5, "orgId": 2, "license":"OpenSource", "onCallApiUrl": "http://oncall-engine-second:8080/", "grafanaUrl": "http://grafana:80/" } }'
  5. curl -X POST -H "X-Grafana-Org-Id: 1" -H "Authorization: Basic xxxxxxx" 'https://grafana.xxxx.xxxx/api/plugins/grafana-oncall-app/resources/plugin/install'
  6. curl -X POST -H "X-Grafana-Org-Id: 2" -H "Authorization: Basic xxxxxxx" 'https://grafana.xxxx.xxxx/api/plugins/grafana-oncall-app/resources/plugin/install'
  7. Connect to the engine succesfully for org_id=1

Grafana OnCall Version

v1.9.30

Product Area

Auth, API

Grafana OnCall Platform?

Kubernetes

User's Browser?

No response

Anything else to add?

Grafana version 11.2.0

@dinfdsooff dinfdsooff added the bug Something isn't working label Sep 30, 2024
@dinfdsooff dinfdsooff changed the title v1.9.30 Permission issues when using multiple Organisations in Grafana OSS v1.9.30 Permission issues when using org_id!=1 in Grafana OSS Sep 30, 2024
@dinfdsooff
Copy link
Author

Hello @joeyorlando, could you add your input on this topic with a comment it would be much appreciated! :)

@sdwerwed
Copy link

sdwerwed commented Oct 1, 2024

Same issue we can't make it work for other grafana organisations, we receive 403 error during setup

@joeyorlando
Copy link
Contributor

oncall oss does not support multiple orgs (#598 (comment); OnCall on Grafana Cloud does however 🙂)

@joeyorlando joeyorlando closed this as not planned Won't fix, can't repro, duplicate, stale Oct 1, 2024
@sdwerwed
Copy link

sdwerwed commented Oct 1, 2024

Hello @joeyorlando does not support even when using different engines and databases per org? Here there is a comment that it works #598 (comment) however not for us.

Unfortunately, we can use only Grafana Self Hosted in our company so this is a major blocker for us, probably will find a paid solution.

@joelbarkley
Copy link

joelbarkley commented Oct 23, 2024

From what my company has done, we can manually create a new service account in the right organization, and then try to connect to oncall. This has worked for us. We use the same naming scheme as the one created automatically by oncall, and just increment it each time. the service account needs admin permissions. (We also assigned each manually created service account all oncall permissions)

First org service account:
Image

Second org service account:
Image

Third org service account:
Image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working part:API part:auth/teams
Projects
None yet
Development

No branches or pull requests

4 participants