blob: d0d5636000c5eb00cc73fd5063e1c0e4bc10e2c6 [file] [log] [blame]
import logging
logger = logging.getLogger(__name__)
config_slack_groovy = """\
jenkins = jenkins.model.Jenkins.getInstance()
try{
slack = jenkins.getDescriptorByType(jenkins.plugins.slack.SlackNotifier.DescriptorImpl)
if(slack.teamDomain.equals("${team_domain}") &&
slack.token.equals("${token}") &&
slack.tokenCredentialId.equals("${token_credential_id}") &&
slack.room.equals("${room}") &&
slack.sendAs.equals("${send_as}")){
print("EXISTS")
}else{
slack.teamDomain = "${team_domain}"
slack.token = "${token}"
slack.tokenCredentialId = "${token_credential_id}"
slack.room = "${room}"
slack.sendAs = "${send_as}"
slack.save()
print("SUCCESS")
}
}catch(all){
print("Cannot instantiate Jenkins Slack plugin, maybe plugin is not installed")
}
""" # noqa
def __virtual__():
'''
Only load if jenkins_common module exist.
'''
if 'jenkins_common.call_groovy_script' not in __salt__:
return (
False,
'The jenkins_slack state module cannot be loaded: '
'jenkins_common not found')
return True
def config(name, team_domain, token,
token_credential_id="", room="", send_as=None):
"""
Jenkins Slack config state method
:param name: configuration name
:param team_domain: slack team domain
:param token: slack token
:param token_credential_id: slack token credential id
:param room: slack room
:param send_as: slack send as param
:returns: salt-specified state dict
"""
test = __opts__['test'] # noqa
ret = {
'name': name,
'changes': {},
'result': False,
'comment': '',
}
result = False
if test:
status = "SUCCESS"
ret['changes'][name] = status
ret['comment'] = 'Jenkins Slack config %s %s' % (name, status.lower())
else:
call_result = __salt__['jenkins_common.call_groovy_script'](
config_slack_groovy, {"team_domain": team_domain,
"token": token,
"token_credential_id": token_credential_id if token_credential_id else "",
"room": room if room else "",
"send_as": send_as if send_as else ""})
if call_result["code"] == 200 and call_result["msg"] in [
"SUCCESS", "EXISTS"]:
status = call_result["msg"]
if status == "SUCCESS":
ret['changes'][name] = status
ret['comment'] = 'Jenkins Slack config %s %s' % (
name, status.lower())
result = True
else:
status = 'FAILED'
logger.error(
"Jenkins slack API call failure: %s", call_result["msg"])
ret['comment'] = 'Jenkins slack API call failure: %s' % (call_result[
"msg"])
ret['result'] = None if test else result
return ret