Jakub Josef | 3de91af | 2016-12-08 17:03:33 +0100 | [diff] [blame] | 1 | import logging |
| 2 | logger = logging.getLogger(__name__) |
| 3 | |
| 4 | create_admin_groovy = u"""\ |
| 5 | import jenkins.model.* |
| 6 | import hudson.security.* |
| 7 | def instance = Jenkins.getInstance() |
| 8 | def hudsonRealm = new HudsonPrivateSecurityRealm(false) |
| 9 | def result=hudsonRealm.createAccount("{username}","{password}") |
| 10 | instance.setSecurityRealm(hudsonRealm) |
| 11 | def strategy = new hudson.security.FullControlOnceLoggedInAuthorizationStrategy() |
| 12 | strategy.setAllowAnonymousRead(false) |
| 13 | instance.setAuthorizationStrategy(strategy) |
| 14 | instance.save() |
| 15 | print(result) |
| 16 | """ #noqa |
| 17 | |
| 18 | |
| 19 | create_user_groovy = u"""\ |
| 20 | def result=jenkins.model.Jenkins.instance.securityRealm.createAccount("{username}", "{password}") |
| 21 | print(result) |
| 22 | """ # noqa |
| 23 | |
| 24 | |
| 25 | def present(name, username, password, admin=False): |
| 26 | """ |
| 27 | Main jenkins users state method |
| 28 | |
| 29 | :param username: user name |
| 30 | :param password: user password |
| 31 | :param admin: is admin user flag (username will be always admin) |
| 32 | :returns: salt-specified state dict |
| 33 | """ |
| 34 | test = __opts__['test'] # noqa |
| 35 | ret = { |
| 36 | 'name': username, |
| 37 | 'changes': {}, |
| 38 | 'result': False, |
| 39 | 'comment': '', |
| 40 | } |
| 41 | |
| 42 | result = False |
| 43 | if test: |
| 44 | status = 'CREATED' |
| 45 | ret['changes'][username] = status |
| 46 | ret['comment'] = 'User %s %s' % (username, status.lower()) |
| 47 | else: |
| 48 | call_result = __salt__['jenkins_common.call_groovy_script'](create_admin_groovy if admin else create_user_groovy, {"username": username, "password":password}) |
| 49 | if call_result["code"] == 200 and call_result["msg"].count(username) == 1: |
| 50 | status = "CREATED" if not admin else "ADMIN CREATED" |
| 51 | ret['changes'][username] = status |
| 52 | ret['comment'] = 'User %s %s' % (username, status.lower()) |
| 53 | result = True |
| 54 | else: |
| 55 | status = 'FAILED' |
| 56 | logger.error("Jenkins user API call failure: %s", call_result["msg"]) |
| 57 | ret['comment'] = 'Jenkins user API call failure: %s' % (call_result["msg"]) |
| 58 | ret['result'] = None if test else result |
| 59 | return ret |