from __future__ import annotations

import logging
import os
import time

import click
import gitlab
import requests

PROJECT_ID = int(os.getenv("CI_PROJECT_ID", 19378))
GITLAB_ENDPOINT = os.getenv("GITLAB_ENDPOINT")
RO_API_TOKEN = os.getenv("RO_API_TOKEN")
NUM_CONCURRENT_JOBS = int(os.getenv("NUM_CONCURRENT_JOBS", 2))

logging.basicConfig()
logger = logging.getLogger(__name__)
logger.setLevel(logging.INFO)


def get_gitlab_handle():
    return gitlab.Gitlab(f"https://{GITLAB_ENDPOINT}", private_token=os.getenv("RO_API_TOKEN"))


def ci_is_busy(pipeline):
    """List all merge request pipelines created before the given pipeline that are still pending or running."""
    mr_pipelines = (
        get_gitlab_handle()
        .projects.get(PROJECT_ID)
        .pipelines.list(source="merge_request_event", get_all=True)
    )

    pipeline_time = pipeline.attributes["created_at"]
    in_queue = len(
        [
            p
            for p in mr_pipelines
            if p.attributes["created_at"] < pipeline_time
            and p.attributes["status"] in ("pending", "running")
        ]
    )
    logger.info(f"In queue: {in_queue}. Waiting for resources...")
    return in_queue > NUM_CONCURRENT_JOBS


@click.command()
@click.option("--pipeline-id", required=True, type=int, help="CI pipeline ID to check")
def main(pipeline_id):
    pipeline = get_gitlab_handle().projects.get(PROJECT_ID).pipelines.get(pipeline_id)
    logger.info(f"Job concurrency: {NUM_CONCURRENT_JOBS}")

    while True:
        try:
            is_busy = ci_is_busy(pipeline)
            if not is_busy:
                break
            time.sleep(60)

        except (requests.exceptions.ConnectionError, gitlab.exceptions.GitlabListError) as e:
            logger.info(f"Network error. Retrying... {e}")
            time.sleep(15)
            continue


if __name__ == "__main__":
    main()
