mirror of
https://github.com/open-metadata/OpenMetadata.git
synced 2025-10-24 15:25:10 +00:00
85 lines
3.0 KiB
Python
85 lines
3.0 KiB
Python
# Copyright 2021 Collate
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
import logging
|
|
import requests
|
|
from slack_sdk.webhook import WebhookClient
|
|
import os
|
|
from typing import Optional
|
|
|
|
|
|
# Configure logging
|
|
logging.basicConfig(
|
|
level=logging.INFO,
|
|
format="%(asctime)s - %(name)s - %(levelname)s - %(message)s",
|
|
)
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
def get_required_env_var(var_name: str) -> str:
|
|
"""
|
|
Retrieves an environment variable by name, raising RuntimeError if it's not set.
|
|
"""
|
|
value: Optional[str] = os.getenv(var_name)
|
|
if value is None:
|
|
raise RuntimeError(f"Required environment variable '{var_name}' is not set.")
|
|
return value
|
|
|
|
|
|
# Get the variables using the helper function
|
|
slack_webhook_url: str = get_required_env_var("SLACK_WEBHOOK_URL")
|
|
slack_webhook_type: str = get_required_env_var("SLACK_WEBHOOK_TYPE")
|
|
github_server_url: str = get_required_env_var("GITHUB_SERVER_URL")
|
|
github_repository: str = get_required_env_var("GITHUB_REPOSITORY")
|
|
github_run_id: str = get_required_env_var("GITHUB_RUN_ID")
|
|
|
|
# Now you can use the variables
|
|
logger.info("Successfully loaded all required environment variables.")
|
|
logger.info(f"Repo: {github_repository}, Run ID: {github_run_id}")
|
|
|
|
|
|
def main():
|
|
slack_url_map = {
|
|
"open-metadata": "https://slack.open-metadata.org",
|
|
"free-tier-support": "https://free-tier-support.getcollate.io/",
|
|
}
|
|
|
|
for product_type, slack_url in slack_url_map.items():
|
|
res = None
|
|
try:
|
|
res = requests.post(
|
|
"https://linkmonitor.onrender.com/api/v1/validate",
|
|
headers={"Content-Type": "application/json"},
|
|
json={"url": slack_url},
|
|
)
|
|
logger.info(f"Status: {res.status_code} {res.text}")
|
|
|
|
if res.json().get("status") != "active":
|
|
raise RuntimeError("Expired status!")
|
|
except RuntimeError as err:
|
|
error_msg = f"{product_type} slack link is expired"
|
|
logger.error(error_msg)
|
|
slack_client = WebhookClient(
|
|
url=slack_webhook_url,
|
|
)
|
|
error_msg = f"🔥 {product_type} slack link is expired 🔥 \n Workflow run: {github_server_url}/{github_repository}/actions/runs/{github_run_id}"
|
|
slack_client.send(text=error_msg)
|
|
except Exception as err:
|
|
error_msg = f"Something went wrong fetching the data - [{err}]"
|
|
if res is not None:
|
|
error_msg += f" [{res.text}]"
|
|
logger.error(error_msg)
|
|
raise err
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|