Merge branch 'slack_integration' into 'master'
Slack integration See merge request !1151
This commit is contained in:
commit
70004f4ef6
7 changed files with 57 additions and 28 deletions
|
@ -12,6 +12,7 @@ v 7.4.0
|
||||||
- API: Add support for forking a project via the API (Bernhard Kaindl)
|
- API: Add support for forking a project via the API (Bernhard Kaindl)
|
||||||
- API: filter project issues by milestone (Julien Bianchi)
|
- API: filter project issues by milestone (Julien Bianchi)
|
||||||
- Fail harder in the backup script
|
- Fail harder in the backup script
|
||||||
|
- Changes to Slack service structure, only webhook url needed
|
||||||
- Zen mode for wiki and milestones (Robert Schilling)
|
- Zen mode for wiki and milestones (Robert Schilling)
|
||||||
- Move Emoji parsing to html-pipeline-gitlab (Robert Schilling)
|
- Move Emoji parsing to html-pipeline-gitlab (Robert Schilling)
|
||||||
- Font Awesome 4.2 integration (Sullivan Senechal)
|
- Font Awesome 4.2 integration (Sullivan Senechal)
|
||||||
|
|
|
@ -40,7 +40,7 @@ class Projects::ServicesController < Projects::ApplicationController
|
||||||
def service_params
|
def service_params
|
||||||
params.require(:service).permit(
|
params.require(:service).permit(
|
||||||
:title, :token, :type, :active, :api_key, :subdomain,
|
:title, :token, :type, :active, :api_key, :subdomain,
|
||||||
:room, :recipients, :project_url,
|
:room, :recipients, :project_url, :webhook,
|
||||||
:user_key, :device, :priority, :sound
|
:user_key, :device, :priority, :sound
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
|
@ -13,10 +13,8 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
class SlackService < Service
|
class SlackService < Service
|
||||||
prop_accessor :room, :subdomain, :token
|
prop_accessor :webhook
|
||||||
validates :room, presence: true, if: :activated?
|
validates :webhook, presence: true, if: :activated?
|
||||||
validates :subdomain, presence: true, if: :activated?
|
|
||||||
validates :token, presence: true, if: :activated?
|
|
||||||
|
|
||||||
def title
|
def title
|
||||||
'Slack'
|
'Slack'
|
||||||
|
@ -32,9 +30,7 @@ class SlackService < Service
|
||||||
|
|
||||||
def fields
|
def fields
|
||||||
[
|
[
|
||||||
{ type: 'text', name: 'subdomain', placeholder: '' },
|
{ type: 'text', name: 'webhook', placeholder: '' }
|
||||||
{ type: 'text', name: 'token', placeholder: '' },
|
|
||||||
{ type: 'text', name: 'room', placeholder: 'Ex. #general' },
|
|
||||||
]
|
]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -44,10 +40,13 @@ class SlackService < Service
|
||||||
project_name: project_name
|
project_name: project_name
|
||||||
))
|
))
|
||||||
|
|
||||||
notifier = Slack::Notifier.new(subdomain, token)
|
credentials = webhook.match(/(\w*).slack.com.*services\/(.*)/)
|
||||||
notifier.channel = room
|
if credentials.present?
|
||||||
notifier.username = 'GitLab'
|
subdomain = credentials[1]
|
||||||
notifier.ping(message.pretext, attachments: message.attachments)
|
token = credentials[2].split("token=").last
|
||||||
|
notifier = Slack::Notifier.new(subdomain, token)
|
||||||
|
notifier.ping(message.pretext, attachments: message.attachments)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
17
db/migrate/20141006143943_move_slack_service_to_webhook.rb
Normal file
17
db/migrate/20141006143943_move_slack_service_to_webhook.rb
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
class MoveSlackServiceToWebhook < ActiveRecord::Migration
|
||||||
|
def change
|
||||||
|
SlackService.all.each do |slack_service|
|
||||||
|
if ["token", "subdomain"].all? { |property| slack_service.properties.key? property }
|
||||||
|
token = slack_service.properties['token']
|
||||||
|
subdomain = slack_service.properties['subdomain']
|
||||||
|
webhook = "https://#{subdomain}.slack.com/services/hooks/incoming-webhook?token=#{token}"
|
||||||
|
slack_service.properties['webhook'] = webhook
|
||||||
|
slack_service.properties.delete('token')
|
||||||
|
slack_service.properties.delete('subdomain')
|
||||||
|
# Room is configured on the Slack side
|
||||||
|
slack_service.properties.delete('room')
|
||||||
|
slack_service.save!
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -11,7 +11,7 @@
|
||||||
#
|
#
|
||||||
# It's strongly recommended that you check this file into your version control system.
|
# It's strongly recommended that you check this file into your version control system.
|
||||||
|
|
||||||
ActiveRecord::Schema.define(version: 20140914173417) do
|
ActiveRecord::Schema.define(version: 20141006143943) do
|
||||||
|
|
||||||
# These are extensions that must be enabled in order to support this database
|
# These are extensions that must be enabled in order to support this database
|
||||||
enable_extension "plpgsql"
|
enable_extension "plpgsql"
|
||||||
|
|
|
@ -108,16 +108,12 @@ class Spinach::Features::ProjectServices < Spinach::FeatureSteps
|
||||||
|
|
||||||
step 'I fill Slack settings' do
|
step 'I fill Slack settings' do
|
||||||
check 'Active'
|
check 'Active'
|
||||||
fill_in 'Subdomain', with: 'gitlab'
|
fill_in 'Webhook', with: 'https://gitlabhq.slack.com/services/hooks?token=cdIj4r4LfXUOySDUjp0tk3OI'
|
||||||
fill_in 'Room', with: '#gitlab'
|
|
||||||
fill_in 'Token', with: 'verySecret'
|
|
||||||
click_button 'Save'
|
click_button 'Save'
|
||||||
end
|
end
|
||||||
|
|
||||||
step 'I should see Slack service settings saved' do
|
step 'I should see Slack service settings saved' do
|
||||||
find_field('Subdomain').value.should == 'gitlab'
|
find_field('Webhook').value.should == 'https://gitlabhq.slack.com/services/hooks?token=cdIj4r4LfXUOySDUjp0tk3OI'
|
||||||
find_field('Room').value.should == '#gitlab'
|
|
||||||
find_field('Token').value.should == 'verySecret'
|
|
||||||
end
|
end
|
||||||
|
|
||||||
step 'I click Pushover service link' do
|
step 'I click Pushover service link' do
|
||||||
|
|
|
@ -26,31 +26,28 @@ describe SlackService do
|
||||||
subject.active = true
|
subject.active = true
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should validate_presence_of :room }
|
it { should validate_presence_of :webhook }
|
||||||
it { should validate_presence_of :subdomain }
|
|
||||||
it { should validate_presence_of :token }
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "Execute" do
|
describe "Execute" do
|
||||||
let(:slack) { SlackService.new }
|
let(:slack) { SlackService.new }
|
||||||
|
let(:slack_service) { SlackService.new }
|
||||||
let(:user) { create(:user) }
|
let(:user) { create(:user) }
|
||||||
let(:project) { create(:project) }
|
let(:project) { create(:project) }
|
||||||
let(:sample_data) { GitPushService.new.sample_data(project, user) }
|
let(:sample_data) { GitPushService.new.sample_data(project, user) }
|
||||||
let(:subdomain) { 'gitlab' }
|
let(:webhook) { 'https://gitlabhq.slack.com/services/hooks?token=cdIj4r4LfXUOySDUjp0tk3OI' }
|
||||||
let(:token) { 'verySecret' }
|
let(:new_webhook) { 'https://hooks.gitlabhq.slack.com/services/cdIj4r4LfXUOySDUjp0tk3OI' }
|
||||||
let(:api_url) {
|
let(:api_url) {
|
||||||
"https://#{subdomain}.slack.com/services/hooks/incoming-webhook?token=#{token}"
|
'https://gitlabhq.slack.com/services/hooks/incoming-webhook?token=cdIj4r4LfXUOySDUjp0tk3OI'
|
||||||
}
|
}
|
||||||
|
|
||||||
before do
|
before do
|
||||||
slack.stub(
|
slack.stub(
|
||||||
project: project,
|
project: project,
|
||||||
project_id: project.id,
|
project_id: project.id,
|
||||||
room: '#gitlab',
|
|
||||||
service_hook: true,
|
service_hook: true,
|
||||||
subdomain: subdomain,
|
webhook: webhook
|
||||||
token: token
|
|
||||||
)
|
)
|
||||||
|
|
||||||
WebMock.stub_request(:post, api_url)
|
WebMock.stub_request(:post, api_url)
|
||||||
|
@ -61,5 +58,24 @@ describe SlackService do
|
||||||
|
|
||||||
WebMock.should have_requested(:post, api_url).once
|
WebMock.should have_requested(:post, api_url).once
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'with new webhook syntax' do
|
||||||
|
before do
|
||||||
|
slack_service.stub(
|
||||||
|
project: project,
|
||||||
|
project_id: project.id,
|
||||||
|
service_hook: true,
|
||||||
|
webhook: new_webhook
|
||||||
|
)
|
||||||
|
|
||||||
|
WebMock.stub_request(:post, api_url)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should call Slack API" do
|
||||||
|
slack_service.execute(sample_data)
|
||||||
|
|
||||||
|
WebMock.should have_requested(:post, api_url).once
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue