All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.connid.bundles.cmd.methods.CmdExec Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (C) 2011 ConnId ([email protected])
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.connid.bundles.cmd.methods;

import java.util.ArrayList;
import java.util.List;
import java.util.Set;
import org.connid.bundles.cmd.CmdConfiguration;
import org.connid.bundles.cmd.CmdConnection;
import org.identityconnectors.common.Pair;
import org.identityconnectors.common.logging.Log;
import org.identityconnectors.common.security.GuardedString;
import org.identityconnectors.framework.common.exceptions.ConnectorException;
import org.identityconnectors.framework.common.objects.Attribute;
import org.identityconnectors.framework.common.objects.AttributeUtil;
import org.identityconnectors.framework.common.objects.ObjectClass;
import org.identityconnectors.framework.common.objects.OperationalAttributes;
import org.identityconnectors.framework.common.objects.Uid;

public abstract class CmdExec {

    private static final Log LOG = Log.getLog(CmdExec.class);

    protected final ObjectClass oc;

    public CmdExec(final ObjectClass oc) {
        this.oc = oc;
    }

    protected Process exec(final String path, final List> env) {
        try {
            return CmdConnection.openConnection().execute(path, env);
        } catch (Exception e) {
            LOG.error(e, "Error executing script: " + path);
            throw new ConnectorException(e);
        }
    }

    protected List> createEnv(final Set attrs) {
        return createEnv(attrs, null);
    }

    protected List> createEnv(final Set attrs, final Uid uid) {
        final List> env = new ArrayList>();

        LOG.ok("Creating environment with:");
        if (oc != null) {
            LOG.ok(CmdConfiguration.OBJECT_CLASS + ": {0}", oc.getObjectClassValue());
            env.add(new Pair(CmdConfiguration.OBJECT_CLASS, oc.getObjectClassValue()));
        }

        for (Attribute attr : attrs) {
            if (attr.getValue() != null && !attr.getValue().isEmpty()) {
                LOG.ok("Environment variable {0}: {1}", attr.getName(), attr.getValue().get(0));

                if (OperationalAttributes.PASSWORD_NAME.equals(attr.getName())) {
                    final GuardedString gpasswd = AttributeUtil.getPasswordValue(attrs);
                    if (gpasswd != null) {
                        gpasswd.access(new GuardedString.Accessor() {

                            @Override
                            public void access(char[] clearChars) {
                                env.add(new Pair(
                                        OperationalAttributes.PASSWORD_NAME, new String(clearChars)));
                            }
                        });
                    }
                } else {
                    env.add(new Pair(
                            attr.getName(), join(attr.getValue().toArray(), ',')));
                }
            }
        }

        if (uid != null && AttributeUtil.find(Uid.NAME, attrs) == null) {
            LOG.ok("Environment variable {0}: {1}", Uid.NAME, uid.getUidValue());
            env.add(new Pair(Uid.NAME, uid.getUidValue()));
        }

        return env;
    }

    // backport from 1.3.3.1
    private String join(final Object[] array, final char separator) {
        if (array == null) {
            return null;
        }
        int startIndex = 0;
        int endIndex = array.length;

        final int noOfItems = endIndex - startIndex;
        if (noOfItems <= 0) {
            return "";
        }

        final StringBuilder buf = new StringBuilder(noOfItems * 16);

        for (int i = startIndex; i < endIndex; i++) {
            if (i > startIndex) {
                buf.append(separator);
            }
            if (array[i] != null) {
                buf.append(array[i]);
            }
        }
        return buf.toString();
    }

    protected void waitFor(final Process proc) {
        try {
            proc.waitFor();
            LOG.info("Process ended");
        } catch (InterruptedException e) {
            LOG.error(e, "Error waiting for termination");
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy