/** --- BEGIN COPYRIGHT BLOCK --- * This Program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation; version 2 of the License. * * This Program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with * this Program; if not, write to the Free Software Foundation, Inc., 59 Temple * Place, Suite 330, Boston, MA 02111-1307 USA. * * In addition, as a special exception, Red Hat, Inc. gives You the additional * right to link the code of this Program with code not covered under the GNU * General Public License ("Non-GPL Code") and to distribute linked combinations * including the two, subject to the limitations in this paragraph. Non-GPL Code * permitted under this exception must only link to the code of this Program * through those well defined interfaces identified in the file named EXCEPTION * found in the source code files (the "Approved Interfaces"). The files of * Non-GPL Code may instantiate templates or use macros or inline functions from * the Approved Interfaces without causing the resulting work to be covered by * the GNU General Public License. Only Red Hat, Inc. may make changes or * additions to the list of Approved Interfaces. You must obey the GNU General * Public License in all respects for all of the Program code and other code used * in conjunction with the Program except the Non-GPL Code covered by this * exception. If you modify this file, you may extend this exception to your * version of the file, but you are not obligated to do so. If you do not wish to * provide this exception without modification, you must delete this exception * statement from your version and license this file solely under the GPL without * exception. * * * Copyright (C) 2001 Sun Microsystems, Inc. Used by permission. * Copyright (C) 2005 Red Hat, Inc. * All rights reserved. --- END COPYRIGHT BLOCK --- */ /* * dsconfig.c -- CGI configuration update handler -- directory gateway */ #include "dsgw.h" static void handle_request( int reqmethod ); static void handle_post(); main( argc, argv, env ) int argc; char *argv[]; #ifdef DSGW_DEBUG char *env[]; #endif { int reqmethod; context= dsgw_ch_strdup("pb"); /*CHANGE THIS*/ reqmethod = dsgw_init( argc, argv, DSGW_METHOD_POST | DSGW_METHOD_GET ); dsgw_send_header(); #ifdef DSGW_DEBUG dsgw_logstringarray( "env", env ); #endif handle_request( reqmethod ); exit( 0 ); } #define DSGWCONFIG_EMPTY_IF_NULL( s ) ( (s) == NULL ? "" : (s) ) static void handle_request( int reqmethod ) { FILE *fp; char **argv, *buf, line[ BIG_LINE ]; char *checked = " CHECKED ", *qs = NULL; char *str_valuefmt = " VALUE=\"%s\" "; char *int_valuefmt = " VALUE=\"%d\" "; int did_post, argc, switch_mode = 0, is_localdb = 0; buf = dsgw_ch_malloc( strlen( progname ) + 6 ); /* room for ".html\0" */ sprintf( buf, "%s.html", progname ); fp = dsgw_open_html_file( buf, DSGW_ERROPT_EXIT ); free( buf ); did_post = 0; qs = getenv( "QUERY_STRING" ); if (( reqmethod == DSGW_METHOD_GET ) && ( qs != NULL ) && !strcasecmp( qs, "CHANGE" )) { switch_mode = 1; } is_localdb = gc->gc_localdbconf != NULL; while ( dsgw_next_html_line( fp, line )) { if ( dsgw_parse_line( line, &argc, &argv, 0, dsgw_simple_cond_is_true, NULL )) { if ( dsgw_directive_is( line, DRCT_DS_INLINE_POST_RESULTS )) { if ( !did_post && reqmethod == DSGW_METHOD_POST ) { handle_post(); did_post = 1; /* We re-read the config file, so re-calculate is_localdb */ is_localdb = ( gc->gc_localdbconf != NULL ); } } else if ( dsgw_directive_is( line, DRCT_DS_CHECKED_IF_LOCAL )) { if (( is_localdb && !switch_mode ) || ( !is_localdb && switch_mode )) { dsgw_emits( checked ); } } else if ( dsgw_directive_is( line, DRCT_DS_CONFIG_INFO )) { dsgw_emits( "" ); if (( is_localdb && !switch_mode ) || ( !is_localdb && switch_mode )) { dsgw_emits( "Local Directory Configuration" ); } else { dsgw_emits( "LDAP Directory Server Configuration" ); } dsgw_emits( "\n" ); } else if ( dsgw_directive_is( line, DRCT_DS_CHECKED_IF_REMOTE )) { if (( !is_localdb && !switch_mode ) || ( is_localdb && switch_mode )) { dsgw_emits( checked ); } } else if ( dsgw_directive_is( line, DRCT_DS_HOSTNAME_VALUE ) && (( !is_localdb && !switch_mode ) || ( is_localdb && switch_mode ))) { dsgw_emits( "\nHost Name:" "gc_ldapserver )); dsgw_emits( "SIZE=40>\n\n\n" ); } else if ( dsgw_directive_is( line, DRCT_DS_PORT_VALUE ) && (( !is_localdb && !switch_mode ) || ( is_localdb && switch_mode ))) { dsgw_emits( "\nPort:\n" "gc_ldapport ); } dsgw_emits( "SIZE=5>\n\n\n" ); #ifndef DSGW_NO_SSL } else if ( dsgw_directive_is( line, DRCT_DS_SSL_CONFIG_VALUE ) && (( !is_localdb && !switch_mode ) || ( is_localdb && switch_mode ))) { dsgw_emits( "\n\n" "Use Secure
Sockets Layer (SSL)
for " "connections?:
\n" "gc_ldapssl ) { dsgw_emits( checked ); } dsgw_HTML_emits( ">Yes" DSGW_UTF8_NBSP "\ngc_ldapssl ) { dsgw_emits( checked ); } dsgw_emits( ">No\n\n\n\n" ); #endif } else if ( dsgw_directive_is( line, DRCT_DS_BASEDN_VALUE )) { dsgw_emits( "\nBase DN" ); if (( is_localdb && !switch_mode ) || ( !is_localdb && switch_mode )) { dsgw_emits( " (optional)" ); } dsgw_emits( ":\ngc_ldapsearchbase )); dsgw_emits( "SIZE=50>\n\n\n" ); } else if ( dsgw_directive_is( line, DRCT_DS_BINDDN_VALUE ) && (( !is_localdb && !switch_mode ) || ( is_localdb && switch_mode ))) { dsgw_emits( "\n" "Bind DN (optional):\n" "gc_binddn == NULL || strlen( gc->gc_binddn ) == 0 ) { dsgw_emits( "VALUE=\"\"" ); } else { dsgw_emitf( "VALUE=\"%s\" ", gc->gc_binddn ); } dsgw_emits( " SIZE=50>\n\n\n" ); } else if ( dsgw_directive_is( line, DRCT_DS_BINDPASSWD_VALUE ) && (( !is_localdb && !switch_mode ) || ( is_localdb && switch_mode ))) { dsgw_emits( "\n" "Bind Password (optional):\n" "gc_bindpw != NULL && ( strlen( gc->gc_bindpw ) > 0 )) { dsgw_emitf( str_valuefmt, gc->gc_bindpw ); } dsgw_emits( "SIZE=20>\n\n\n" ); } else if ( dsgw_directive_is( line, DRCT_DS_NOCERTFILE_WARNING ) && ( gc->gc_securitypath == NULL ) && !is_localdb && gc->gc_ldapssl && argc > 0 ) { /* * using LDAP over SSL but no CertFile in ns-admin.conf: * show a warning message */ dsgw_emits( argv[ 0 ] ); } } } fclose( fp ); } static void handle_post() { char *dirsvctype, *dbhandle; dsgwconfig cfg; memset( &cfg, 0, sizeof( cfg )); dirsvctype = dsgw_get_cgi_var( "dirsvctype", DSGW_CGIVAR_REQUIRED ); dbhandle = dsgw_get_cgi_var( "dbhandle", DSGW_CGIVAR_OPTIONAL ); cfg.gc_ldapsearchbase = dsgw_get_cgi_var( "basedn", DSGW_CGIVAR_OPTIONAL ); if ( strcasecmp( dirsvctype, "local" ) == 0 ) { char *userdb_path; if (( userdb_path = get_userdb_dir()) == NULL ) { dsgw_error( DSGW_ERR_USERDB_PATH, NULL, DSGW_ERROPT_INLINE, 0, NULL ); return; } cfg.gc_localdbconf = dsgw_ch_malloc( strlen( userdb_path ) + strlen( DSGW_LCACHECONF_PPATH ) + strlen( DSGW_LCACHECONF_FILE ) + 2 ); sprintf( cfg.gc_localdbconf, "%s/%s%s", userdb_path, DSGW_LCACHECONF_PPATH, DSGW_LCACHECONF_FILE ); } else if ( strcasecmp( dirsvctype, "remote" ) == 0 ) { cfg.gc_ldapserver = dsgw_get_cgi_var( "host", DSGW_CGIVAR_REQUIRED ); cfg.gc_ldapport = atoi( dsgw_get_cgi_var( "port", DSGW_CGIVAR_REQUIRED )); #ifndef DSGW_NO_SSL cfg.gc_ldapssl = dsgw_get_boolean_var( "ssl", DSGW_CGIVAR_OPTIONAL, 0 ); #endif cfg.gc_binddn = dsgw_get_escaped_cgi_var( "escapedbinddn", "binddn", DSGW_CGIVAR_OPTIONAL ); cfg.gc_bindpw = dsgw_get_cgi_var( "bindpw", DSGW_CGIVAR_OPTIONAL ); } else { dsgw_error( DSGW_ERR_SERVICETYPE, dirsvctype, DSGW_ERROPT_INLINE, 0, NULL ); return; } if ( cfg.gc_ldapsearchbase == NULL ) { cfg.gc_ldapsearchbase = ""; } if ( dsgw_update_dbswitch( &cfg, dbhandle, DSGW_ERROPT_INLINE ) == 0 ) { /* * success: display status message and then re-read config. file */ dsgw_emits( "\n

The Directory Service configuration" ); if ( dbhandle != NULL ) { dsgw_emitf( " for %s", dbhandle ); } dsgw_emits( " has been updated.\n\n" ); (void)dsgw_read_config(NULL); } dsgw_emits( "


\n" ); }