Search in sources :

Example 1 with AutoProvAccountRequest

use of com.zimbra.soap.admin.message.AutoProvAccountRequest in project zm-mailbox by Zimbra.

the class AutoProvAccount method handle.

@Override
public Element handle(Element request, Map<String, Object> context) throws ServiceException {
    ZimbraSoapContext zsc = getZimbraSoapContext(context);
    Provisioning prov = Provisioning.getInstance();
    AutoProvAccountRequest req = JaxbUtil.elementToJaxb(request);
    DomainBy domainBy = req.getDomain().getBy().toKeyDomainBy();
    String domainKey = req.getDomain().getKey();
    Domain domain = prov.get(domainBy, domainKey);
    if (domain == null) {
        throw AccountServiceException.NO_SUCH_DOMAIN(domainKey);
    }
    checkRight(zsc, context, domain, Admin.R_autoProvisionAccount);
    AutoProvPrincipalBy by = req.getPrincipal().getBy();
    String principal = req.getPrincipal().getKey();
    String password = req.getPassword();
    Account acct = prov.autoProvAccountManual(domain, by, principal, password);
    if (acct == null) {
        throw ServiceException.FAILURE("unable to auto provision account: " + principal, null);
    }
    Element response = zsc.createElement(AdminConstants.AUTO_PROV_ACCOUNT_RESPONSE);
    ToXML.encodeAccount(response, acct);
    return response;
}
Also used : Account(com.zimbra.cs.account.Account) ZimbraSoapContext(com.zimbra.soap.ZimbraSoapContext) DomainBy(com.zimbra.common.account.Key.DomainBy) AutoProvPrincipalBy(com.zimbra.soap.type.AutoProvPrincipalBy) Element(com.zimbra.common.soap.Element) AutoProvAccountRequest(com.zimbra.soap.admin.message.AutoProvAccountRequest) Domain(com.zimbra.cs.account.Domain) Provisioning(com.zimbra.cs.account.Provisioning)

Example 2 with AutoProvAccountRequest

use of com.zimbra.soap.admin.message.AutoProvAccountRequest in project zm-mailbox by Zimbra.

the class TestAutoProvision method errorHandling.

@Test
@Bug(bug = 70720)
public void errorHandling() throws Exception {
    /*
         * create and setup zimbra domain
         */
    Map<String, Object> domainAttrs = Maps.newHashMap();
    domainAttrs.put(Provisioning.A_zimbraAutoProvLdapURL, "ldap://localhost:389");
    domainAttrs.put(Provisioning.A_zimbraAutoProvLdapAdminBindDn, extDomainAdminBindDn);
    domainAttrs.put(Provisioning.A_zimbraAutoProvLdapAdminBindPassword, extDomainAdminBindPassword);
    StringUtil.addToMultiMap(domainAttrs, Provisioning.A_zimbraAutoProvMode, AutoProvMode.LAZY.name());
    StringUtil.addToMultiMap(domainAttrs, Provisioning.A_zimbraAutoProvMode, AutoProvMode.MANUAL.name());
    domainAttrs.put(Provisioning.A_zimbraAutoProvLdapSearchFilter, "(cn=auth*)");
    // domainAttrs.put(Provisioning.A_zimbraAutoProvLdapSearchFilter, "(cn=%n)");
    domainAttrs.put(Provisioning.A_zimbraAutoProvLdapSearchBase, extDomainDn);
    domainAttrs.put(Provisioning.A_zimbraAutoProvAccountNameMap, "cn");
    domainAttrs.put(Provisioning.A_zimbraAutoProvAttrMap, "userPassword=userPassword");
    Domain domain = createZimbraDomain(genDomainSegmentName(), domainAttrs);
    /*
         * create external accounts
         */
    Map<String, Object> extAcct1Attrs = Maps.newHashMap();
    extAcct1Attrs.put("cn", "authaccount01");
    createExternalAcctEntry("acct1", "test123", extAcct1Attrs);
    Map<String, Object> extAcct2Attrs = Maps.newHashMap();
    extAcct2Attrs.put("cn", "authaccount02");
    createExternalAcctEntry("acct2", "test123", extAcct2Attrs);
    Map<String, Object> extAcct3Attrs = Maps.newHashMap();
    extAcct3Attrs.put("cn", "authaccount03");
    createExternalAcctEntry("acct3", "test123", extAcct3Attrs);
    Map<String, Object> extAcct4Attrs = Maps.newHashMap();
    extAcct4Attrs.put("cn", "authaccount04");
    createExternalAcctEntry("acct4", "test123", extAcct4Attrs);
    /*
         * do a manual auto provision
         */
    SoapTransport transport = authZimbraAdmin();
    DomainSelector domainSel = new DomainSelector(DomainSelector.DomainBy.name, domain.getName());
    PrincipalSelector principalSel = PrincipalSelector.create(AutoProvPrincipalBy.name, "authaccount04");
    AutoProvAccountRequest req = AutoProvAccountRequest.create(domainSel, principalSel);
    boolean caughtException = false;
    try {
        invokeJaxb(transport, req);
    } catch (ServiceException e) {
        String msg = e.getMessage();
        if (e.getCode().equals(LdapException.MULTIPLE_ENTRIES_MATCHED) && msg.contains(String.format("uid=acct1,ou=people,%s", extDomainDn)) && msg.contains(String.format("uid=acct2,ou=people,%s", extDomainDn)) && msg.contains(String.format("uid=acct3,ou=people,%s", extDomainDn)) && msg.contains(String.format("uid=acct4,ou=people,%s", extDomainDn))) {
            caughtException = true;
        }
    }
    assertTrue(caughtException);
    /*
         * modify domain to have the correct search filter
         */
    domain.setAutoProvLdapSearchFilter("(cn=%n)");
    /*
         * do the manual provision, should succeed this time
         */
    AutoProvAccountResponse resp = invokeJaxb(transport, req);
    AccountInfo acctInfo = resp.getAccount();
    assertEquals(TestUtil.getAddress("authaccount04", domain.getName()), acctInfo.getName());
    /*
         * do the same manual provision again, should fail with 
         */
    caughtException = false;
    try {
        invokeJaxb(transport, req);
    } catch (ServiceException e) {
        String msg = e.getMessage();
        if (e.getCode().equals(AccountServiceException.ACCOUNT_EXISTS)) {
            caughtException = true;
        }
    }
    assertTrue(caughtException);
/*
        <CreateDomainRequest xmlns="urn:zimbraAdmin">
            <name>autoprov44.1330496906457.com</name>
            <a n="zimbraAutoProvLdapURL">ldap://zqa-003.eng.vmware.com:389/</a>
            <a n="zimbraAutoProvLdapAdminBindDn">administrator@zimbraqa.com</a>
            <a n="zimbraAutoProvLdapAdminBindPassword">liquidsys</a>
            <a n="zimbraAutoProvMode">LAZY</a>
            <a n="zimbraAutoProvMode">MANUAL</a>
            <a n="zimbraAutoProvLdapSearchFilter">(cn=auth*)</a>
            <a n="zimbraAutoProvLdapSearchBase">OU=CommonUsers,DC=zimbraqa,DC=com</a>
            <a n="zimbraAutoProvAccountNameMap">cn</a>
            <a n="zimbraAutoProvAttrMap">userPassword=userPassword</a>
        </CreateDomainRequest>
        
        zmsoap  -z AutoProvAccountRequest domain=bug70720.com.zimbra.qa.unittest.prov.soap.testautoprovision.soaptest.unittest @by=name ../principal=authaccount04 @by=name          
        
        this zmsoap yields the following soap:
        
        <AutoProvAccountRequest xmlns="urn:zimbraAdmin">
            <domain by="name">bug70720.com.zimbra.qa.unittest.prov.soap.testautoprovision.soaptest.unittest</domain>
            <principal by="name">authaccount04</principal>
        </AutoProvAccountRequest>
        */
}
Also used : PrincipalSelector(com.zimbra.soap.admin.type.PrincipalSelector) AccountServiceException(com.zimbra.cs.account.AccountServiceException) ServiceException(com.zimbra.common.service.ServiceException) DomainSelector(com.zimbra.soap.admin.type.DomainSelector) AutoProvAccountResponse(com.zimbra.soap.admin.message.AutoProvAccountResponse) AutoProvAccountRequest(com.zimbra.soap.admin.message.AutoProvAccountRequest) Domain(com.zimbra.cs.account.Domain) SoapTransport(com.zimbra.common.soap.SoapTransport) AccountInfo(com.zimbra.soap.admin.type.AccountInfo) Test(org.junit.Test) Bug(com.zimbra.qa.QA.Bug)

Aggregations

Domain (com.zimbra.cs.account.Domain)2 AutoProvAccountRequest (com.zimbra.soap.admin.message.AutoProvAccountRequest)2 DomainBy (com.zimbra.common.account.Key.DomainBy)1 ServiceException (com.zimbra.common.service.ServiceException)1 Element (com.zimbra.common.soap.Element)1 SoapTransport (com.zimbra.common.soap.SoapTransport)1 Account (com.zimbra.cs.account.Account)1 AccountServiceException (com.zimbra.cs.account.AccountServiceException)1 Provisioning (com.zimbra.cs.account.Provisioning)1 Bug (com.zimbra.qa.QA.Bug)1 ZimbraSoapContext (com.zimbra.soap.ZimbraSoapContext)1 AutoProvAccountResponse (com.zimbra.soap.admin.message.AutoProvAccountResponse)1 AccountInfo (com.zimbra.soap.admin.type.AccountInfo)1 DomainSelector (com.zimbra.soap.admin.type.DomainSelector)1 PrincipalSelector (com.zimbra.soap.admin.type.PrincipalSelector)1 AutoProvPrincipalBy (com.zimbra.soap.type.AutoProvPrincipalBy)1 Test (org.junit.Test)1