oncall-engine/engine/apps/slack/chatops_proxy_routing.py
Innokentii Konstantinov 17f448c506
Prepare OnCall for Unified Slack App (#4232)
This PR does a bunch of changes to prepare OnCall for Unified Slack App:
1. Install Slack via Chatops-Proxy. This change contains two parts:
getting a Slack install link from chatops-proxy
([code](https://github.com/grafana/oncall/pull/4232/files#diff-437a77d49fc04b92d315651b3df5991000b1ab74cf60aabb21aa77cb2823bf52R46))
and receiving a "slack installed" event from chatops-proxy
([code](https://github.com/grafana/oncall/pull/4232/files#diff-976d106f0962be5c1de5e35582193f68435ed0c17f2defd6bd2857bf6e27f65d)).
Also it means that OnCall doesn't need to register slack_links anymore
when slack is connected/disconnected. These changes are behind
UNIFIED_SLACK_APP_ENABLED flag and should be no-op if flag is not
enabled.
2. Get rid of Multiregionatily restrictions - instrument all slack
interactions with a ProxyMeta - json data telling chatops-proxy where to
route the interaction. Note, that it doesn't apply for "Add to
resolution notes" message action - it will be handled differently in
following PR.
3. Move all chatops-proxy related stuff from common/oncall-gateway to
apps/chatops-proxy

Minor changes:
1. Remove usage of **CHATOPS_V3** flag. Chatops v3 is already released
(It's a refactoring from previous quarter)

---------

Co-authored-by: Vadim Stepanov <vadimkerr@gmail.com>
Co-authored-by: Rares Mardare <rares.mardare@grafana.com>
2024-06-03 09:07:10 +00:00

18 lines
663 B
Python

import json
import typing
# ProxyMeta is a data injected into various Slack payloads to route them to the correct cluster via Chatops-Proxy
# Short keys are used to satisfy slack limit for 155 chars in values
class ProxyMeta(typing.TypedDict):
s: str # s is a service name
tid: str # tid is a tenant_id
def make_value(data: dict, organization) -> str:
# Slack block elements allow to pass value as string only (max 2000 chars)
return json.dumps({**data, "s": "oncall", "tid": str(organization.uuid)})
def make_private_metadata(data: dict, organization) -> str:
return json.dumps({**data, "s": "oncall", "tid": str(organization.uuid)})