/* See LICENSE for licensing and NOTICE for copyright. */ package org.ldaptive.cli; import java.io.FileReader; import java.util.Map; import org.apache.commons.cli.CommandLine; import org.apache.commons.cli.Option; import org.ldaptive.AddOperation; import org.ldaptive.AddRequest; import org.ldaptive.Connection; import org.ldaptive.ConnectionConfig; import org.ldaptive.ConnectionFactory; import org.ldaptive.LdapEntry; import org.ldaptive.SearchResult; import org.ldaptive.io.LdifReader; import org.ldaptive.props.BindConnectionInitializerPropertySource; import org.ldaptive.props.ConnectionConfigPropertySource; import org.ldaptive.props.SslConfigPropertySource; import org.ldaptive.ssl.SslConfig; /** * Command line interface for {@link AddOperation}. * * @author Middleware Services */ public class AddOperationCli extends AbstractCli { /** option for LDIF file. */ private static final String OPT_FILE = "file"; /** name of operation provided by this class. */ private static final String COMMAND_NAME = "ldapadd"; /** * CLI entry point method. * * @param args command line arguments. */ public static void main(final String[] args) { final AddOperationCli cli = new AddOperationCli(); final int status = cli.performAction(args); System.exit(status); } @Override protected void initOptions() { options.addOption(new Option(OPT_FILE, true, "LDIF file")); final Map<String, String> desc = getArgDesc(ConnectionConfig.class, SslConfig.class); for (String s : ConnectionConfigPropertySource.getProperties()) { options.addOption(new Option(s, true, desc.get(s))); } for (String s : SslConfigPropertySource.getProperties()) { options.addOption(new Option(s, true, desc.get(s))); } for (String s : BindConnectionInitializerPropertySource.getProperties()) { options.addOption(new Option(s, true, desc.get(s))); } super.initOptions(); } @Override protected int dispatch(final CommandLine line) throws Exception { if (line.hasOption(OPT_HELP)) { printHelp(); } else { return add(initConnectionFactory(line), line.getOptionValue(OPT_FILE)); } return -1; } /** * Executes the ldap add operation. * * @param cf connection factory * @param file to read ldif from * * @return status code * * @throws Exception on any LDAP search error */ protected int add(final ConnectionFactory cf, final String file) throws Exception { final Connection conn = cf.getConnection(); conn.open(); final LdifReader reader = new LdifReader(new FileReader(file)); final SearchResult sr = reader.read(); for (LdapEntry le : sr.getEntries()) { final AddOperation op = new AddOperation(conn); op.execute(new AddRequest(le.getDn(), le.getAttributes())); System.out.println(String.format("Added entry: %s", le)); } conn.close(); return 0; } @Override protected String getCommandName() { return COMMAND_NAME; } }