Commit 0dd33808 authored by Andy Soiron's avatar Andy Soiron Committed by Ash McKenzie

Handle Jira app update webhook

parent 9bcd2fd0
# frozen_string_literal: true # frozen_string_literal: true
class JiraConnect::EventsController < JiraConnect::ApplicationController class JiraConnect::EventsController < JiraConnect::ApplicationController
# See https://developer.atlassian.com/cloud/jira/software/app-descriptor/#lifecycle
skip_before_action :verify_atlassian_jwt!, only: :installed skip_before_action :verify_atlassian_jwt!, only: :installed
before_action :verify_qsh_claim!, only: :uninstalled before_action :verify_qsh_claim!, only: :uninstalled
def installed def installed
return head :ok if atlassian_jwt_valid?
installation = JiraConnectInstallation.new(install_params) installation = JiraConnectInstallation.new(install_params)
if installation.save if installation.save
......
---
title: Fix Jira Connect App update webhooks
merge_request: 45151
author:
type: fixed
...@@ -4,14 +4,20 @@ require 'spec_helper' ...@@ -4,14 +4,20 @@ require 'spec_helper'
RSpec.describe JiraConnect::EventsController do RSpec.describe JiraConnect::EventsController do
describe '#installed' do describe '#installed' do
subject do let(:client_key) { '1234' }
post :installed, params: { let(:shared_secret) { 'secret' }
clientKey: '1234', let(:params) do
sharedSecret: 'secret', {
clientKey: client_key,
sharedSecret: shared_secret,
baseUrl: 'https://test.atlassian.net' baseUrl: 'https://test.atlassian.net'
} }
end end
subject do
post :installed, params: params
end
it 'saves the jira installation data' do it 'saves the jira installation data' do
expect { subject }.to change { JiraConnectInstallation.count }.by(1) expect { subject }.to change { JiraConnectInstallation.count }.by(1)
end end
...@@ -19,15 +25,15 @@ RSpec.describe JiraConnect::EventsController do ...@@ -19,15 +25,15 @@ RSpec.describe JiraConnect::EventsController do
it 'saves the correct values' do it 'saves the correct values' do
subject subject
installation = JiraConnectInstallation.find_by_client_key('1234') installation = JiraConnectInstallation.find_by_client_key(client_key)
expect(installation.shared_secret).to eq('secret') expect(installation.shared_secret).to eq(shared_secret)
expect(installation.base_url).to eq('https://test.atlassian.net') expect(installation.base_url).to eq('https://test.atlassian.net')
end end
context 'client key already exists' do context 'client key already exists' do
it 'returns 422' do it 'returns 422' do
create(:jira_connect_installation, client_key: '1234') create(:jira_connect_installation, client_key: client_key)
subject subject
...@@ -35,6 +41,23 @@ RSpec.describe JiraConnect::EventsController do ...@@ -35,6 +41,23 @@ RSpec.describe JiraConnect::EventsController do
end end
end end
context 'when it is a version update and shared_secret is not sent' do
let(:params) do
{
clientKey: client_key,
baseUrl: 'https://test.atlassian.net'
}
end
it 'validates the JWT token in authorization header and returns 200 without creating a new installation' do
create(:jira_connect_installation, client_key: client_key, shared_secret: shared_secret)
request.headers["Authorization"] = "Bearer #{Atlassian::Jwt.encode({ iss: client_key }, shared_secret)}"
expect { subject }.not_to change { JiraConnectInstallation.count }
expect(response).to have_gitlab_http_status(:ok)
end
end
describe '#uninstalled' do describe '#uninstalled' do
let!(:installation) { create(:jira_connect_installation) } let!(:installation) { create(:jira_connect_installation) }
let(:qsh) { Atlassian::Jwt.create_query_string_hash('https://gitlab.test/events/uninstalled', 'POST', 'https://gitlab.test') } let(:qsh) { Atlassian::Jwt.create_query_string_hash('https://gitlab.test/events/uninstalled', 'POST', 'https://gitlab.test') }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment