Інтеграція GitLab API з сайтом

Наша компанія займається розробкою, підтримкою та обслуговуванням сайтів будь-якої складності. Від простих односторінкових сайтів до масштабних кластерних систем, побудованих на мікро сервісах. Досвід розробників підтверджено сертифікатами від вендорів.
Розробка та обслуговування будь-яких видів сайтів:
Інформаційні сайти або веб-програми
Сайти візитки, landing page, корпоративні сайти, онлайн каталоги, квіз, промо-сайти, блоги, ресурси новин, інформаційні портали, форуми, агрегатори
Сайти або веб-програми електронної комерції
Інтернет-магазини, B2B-портали, маркетплейси, онлайн-обмінники, кешбек-сайти, біржі, дропшиппінг-платформи, парсери товарів
Веб-програми для управління бізнес-процесами
CRM-системи, ERP-системи, корпоративні портали, системи управління виробництвом, парсери інформації
Сайти або веб-програми електронних послуг
Дошки оголошень, онлайн-школи, онлайн-кінотеатри, конструктори сайтів, портали надання електронних послуг, відеохостинги, тематичні портали

Це лише деякі з технічних типів сайтів, з якими ми працюємо, і кожен із них може мати свої специфічні особливості та функціональність, а також бути адаптованим під конкретні потреби та цілі клієнта.

Пропоновані послуги
Показано 1 з 1 послугУсі 2065 послуг
Інтеграція GitLab API з сайтом
Середня
від 1 робочого дня до 3 робочих днів
Часті питання
Наші компетенції:
Етапи розробки
Останні роботи
  • image_website-b2b-advance_0.png
    Розробка сайту компанії B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Розробка веб-додатків для компанії FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Розробка веб-сайту для компанії БЕЛФІНГРУП
    874
  • image_ecommerce_furnoro_435_0.webp
    Розробка інтернет магазину для компанії FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Розробка веб-додатків для компанії Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Розробка веб-сайту для компанії ФІКСПЕР
    851

Інтеграція GitLab API з веб-сайтом

GitLab API використовується для CI/CD інтеграцій, відображення статусу пайплайнів, управління завданнями з зовнішніх систем та авторизації через GitLab OAuth. Особливо актуально для DevOps-інструментів та корпоративних порталів.

Аутентифікація

import gitlab

# Personal Access Token
gl = gitlab.Gitlab('https://gitlab.com', private_token=GITLAB_TOKEN)

# OAuth2 для користувальницьких додатків
gl = gitlab.Gitlab('https://gitlab.com', oauth_token=oauth_token)

Типові сценарії

Статус CI/CD пайплайна на сайті:

def get_pipeline_status(project_id: int, ref: str = 'main') -> dict:
    project   = gl.projects.get(project_id)
    pipelines = project.pipelines.list(ref=ref, per_page=1)

    if not pipelines:
        return {'status': 'unknown'}

    pipeline = pipelines[0]
    return {
        'status':     pipeline.status,      # success/failed/running/pending
        'ref':        pipeline.ref,
        'sha':        pipeline.sha[:8],
        'started_at': pipeline.started_at,
        'duration':   pipeline.duration,
        'url':        pipeline.web_url,
    }

Спусти пайплайна з адміністративної панелі:

public function triggerDeploy(Request $request): JsonResponse
{
    $resp = Http::withToken(config('services.gitlab.token'))
        ->post("https://gitlab.com/api/v4/projects/{$projectId}/pipeline", [
            'ref'       => 'main',
            'variables' => [
                ['key' => 'DEPLOY_ENV', 'value' => $request->environment],
            ],
        ]);

    return response()->json(['pipeline_id' => $resp->json('id')]);
}

GitLab OAuth2

Route::get('/auth/gitlab/redirect', function () {
    return redirect('https://gitlab.com/oauth/authorize?' . http_build_query([
        'client_id'     => config('services.gitlab.client_id'),
        'redirect_uri'  => route('auth.gitlab.callback'),
        'response_type' => 'code',
        'scope'         => 'read_user read_api',
    ]));
});

Webhooks

GitLab підтримує Push Events, Pipeline Events, Merge Request Events. Верифікація через заголовок X-Gitlab-Token (секретний токен, заданий під час створення webhook).

Графік

Відображення статусу пайплайна + OAuth: 2–3 робочих дні. Повна інтеграція з управлінням: 4–5 днів.