Logo Search packages:      
Sourcecode: nagios2 version File versions  Download package

xodtemplate.c

 /*****************************************************************************
 *
 * XODTEMPLATE.C - Template-based object configuration data input routines
 *
 * Copyright (c) 2001-2008 Ethan Galstad (nagios@nagios.org)
 * Last Modified: 01-23-2007
 *
 * Description:
 *
 * Routines for parsing and resolving template-based object definitions.
 * Basic steps involved in this in the daemon are as follows:
 *
 *    1) Read
 *    2) Resolve
 *    3) Duplicate
 *    4) Recombobulate
 *    5) Cache
 *    7) Register
 *    8) Cleanup
 *
 * The steps involved for the CGIs differ a bit, since they read the cached
 * definitions which are already resolved, recombobulated and duplicated.  In
 * otherwords, they've already been "flattened"...
 *
 *    1) Read
 *    2) Register
 *    3) Cleanup
 *
 *
 * License:
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 * 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., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 *****************************************************************************/


/*********** COMMON HEADER FILES ***********/

#include "../include/config.h"
#include "../include/common.h"
#include "../include/objects.h"
#include "../include/locations.h"

/**** CORE OR CGI SPECIFIC HEADER FILES ****/

#ifdef NSCORE
#include "../include/nagios.h"
#endif

#ifdef NSCGI
#include "../include/cgiutils.h"
#endif

/**** DATA INPUT-SPECIFIC HEADER FILES ****/

#include "xodtemplate.h"


#ifdef NSCORE
extern int use_regexp_matches;
extern int use_true_regexp_matching;
extern char *macro_x[MACRO_X_COUNT];
#endif

xodtemplate_timeperiod *xodtemplate_timeperiod_list=NULL;
xodtemplate_command *xodtemplate_command_list=NULL;
xodtemplate_contactgroup *xodtemplate_contactgroup_list=NULL;
xodtemplate_hostgroup *xodtemplate_hostgroup_list=NULL;
xodtemplate_servicegroup *xodtemplate_servicegroup_list=NULL;
xodtemplate_servicedependency *xodtemplate_servicedependency_list=NULL;
xodtemplate_serviceescalation *xodtemplate_serviceescalation_list=NULL;
xodtemplate_contact *xodtemplate_contact_list=NULL;
xodtemplate_host *xodtemplate_host_list=NULL;
xodtemplate_service *xodtemplate_service_list=NULL;
xodtemplate_hostdependency *xodtemplate_hostdependency_list=NULL;
xodtemplate_hostescalation *xodtemplate_hostescalation_list=NULL;
xodtemplate_hostextinfo *xodtemplate_hostextinfo_list=NULL;
xodtemplate_serviceextinfo *xodtemplate_serviceextinfo_list=NULL;

void *xodtemplate_current_object=NULL;
int xodtemplate_current_object_type=XODTEMPLATE_NONE;

int xodtemplate_current_config_file=0;
char **xodtemplate_config_files;

char xodtemplate_cache_file[MAX_FILENAME_LENGTH];



/******************************************************************/
/************* TOP-LEVEL CONFIG DATA INPUT FUNCTION ***************/
/******************************************************************/

/* process all config files - both core and CGIs pass in name of main config file */
int xodtemplate_read_config_data(char *main_config_file,int options,int cache){
#ifdef NSCORE
      char config_file[MAX_FILENAME_LENGTH];
      char *input=NULL;
      char *temp_ptr;
#endif
      mmapfile *thefile;
      int result=OK;

#ifdef DEBUG0
      printf("xodtemplate_read_config_data() start\n");
#endif

      /* get variables from main config file */
      xodtemplate_grab_config_info(main_config_file);

      /* open the main config file for reading (we need to find all the config files to read) */
      if((thefile=mmap_fopen(main_config_file))==NULL){
#ifdef DEBUG1
            printf("Error: Cannot open main configuration file '%s' for reading!\n",main_config_file);
#endif
            return ERROR;
              }

      /* initialize variables */
      xodtemplate_timeperiod_list=NULL;
      xodtemplate_command_list=NULL;
      xodtemplate_contactgroup_list=NULL;
      xodtemplate_hostgroup_list=NULL;
      xodtemplate_servicegroup_list=NULL;
      xodtemplate_servicedependency_list=NULL;
      xodtemplate_serviceescalation_list=NULL;
      xodtemplate_contact_list=NULL;
      xodtemplate_host_list=NULL;
      xodtemplate_service_list=NULL;
      xodtemplate_hostdependency_list=NULL;
      xodtemplate_hostescalation_list=NULL;
      xodtemplate_hostextinfo_list=NULL;
      xodtemplate_serviceextinfo_list=NULL;

      xodtemplate_current_object=NULL;
      xodtemplate_current_object_type=XODTEMPLATE_NONE;

      /* allocate memory for 256 config files (increased dynamically) */
      xodtemplate_current_config_file=0;
      xodtemplate_config_files=(char **)malloc(256*sizeof(char **));
      if(xodtemplate_config_files==NULL){
#ifdef DEBUG1
            printf("Error: Cannot allocate memory for config file names!\n");
#endif
            return ERROR;
              }

#ifdef NSCORE

      /* daemon reads all config files/dirs specified in the main config file */
      /* read in all lines from the main config file */
      while(1){

            /* free memory */
            free(input);

            /* get the next line */
            if((input=mmap_fgets(thefile))==NULL)
                  break;

            /* strip input */
            strip(input);

            /* skip blank lines and comments */
            if(input[0]=='#' || input[0]==';' || input[0]=='\x0')
                  continue;

            temp_ptr=strtok(input,"=");
            if(temp_ptr==NULL)
                  continue;

            /* process a single config file */
            if(strstr(temp_ptr,"xodtemplate_config_file")==temp_ptr || strstr(temp_ptr,"cfg_file")==temp_ptr){

                  /* get the config file name */
                  temp_ptr=strtok(NULL,"\n");
                  if(temp_ptr==NULL)
                        continue;

                  strncpy(config_file,temp_ptr,sizeof(config_file)-1);
                  config_file[sizeof(config_file)-1]='\x0';

                  /* process the config file... */
                  result=xodtemplate_process_config_file(config_file,options);

                  /* if there was an error processing the config file, break out of loop */
                  if(result==ERROR)
                        break;
                    }

            /* process all files in a config directory */
            else if(strstr(temp_ptr,"xodtemplate_config_dir")==temp_ptr || strstr(temp_ptr,"cfg_dir")==temp_ptr){

                  /* get the config directory name */
                  temp_ptr=strtok(NULL,"\n");
                  if(temp_ptr==NULL)
                        continue;

                  strncpy(config_file,temp_ptr,sizeof(config_file)-1);
                  config_file[sizeof(config_file)-1]='\x0';

                  /* strip trailing / if necessary */
                  if(config_file[strlen(config_file)-1]=='/')
                        config_file[strlen(config_file)-1]='\x0';

                  /* process the config directory... */
                  result=xodtemplate_process_config_dir(config_file,options);

                  /* if there was an error processing the config file, break out of loop */
                  if(result==ERROR)
                        break;
                    }
              }

      /* free memory and close the file */
      free(input);
      mmap_fclose(thefile);
#endif

#ifdef NSCGI
      /* CGIs process only one file - the cached objects file */
      result=xodtemplate_process_config_file(xodtemplate_cache_file,options);
#endif

#ifdef NSCORE

      /* resolve objects definitions */
      if(result==OK)
            result=xodtemplate_resolve_objects();

      /* do the meat and potatoes stuff... */
      if(result==OK)
            result=xodtemplate_recombobulate_contactgroups();
      if(result==OK)
            result=xodtemplate_recombobulate_hostgroups();
      if(result==OK)
            result=xodtemplate_duplicate_services();
      if(result==OK)
            result=xodtemplate_recombobulate_servicegroups();
      if(result==OK)
            result=xodtemplate_duplicate_objects();

      /* sort objects */
      if(result==OK)
            result=xodtemplate_sort_objects();

      /* cache object definitions */
      if(result==OK && cache==TRUE)
            xodtemplate_cache_objects(xodtemplate_cache_file);
#endif

      /* register objects */
      if(result==OK)
            result=xodtemplate_register_objects();

      /* cleanup */
      xodtemplate_free_memory();

#ifdef DEBUG0
      printf("xodtemplate_read_config_data() end\n");
#endif

      return result;
      }



/* grab config variable from main config file */
int xodtemplate_grab_config_info(char *main_config_file){
      char *input=NULL;
      char *temp_ptr;
      mmapfile *thefile;
      
#ifdef DEBUG0
      printf("xodtemplate_grab_config_info() start\n");
#endif

      /* default location of cached object file */
      snprintf(xodtemplate_cache_file,sizeof(xodtemplate_cache_file)-1,"%s",DEFAULT_OBJECT_CACHE_FILE);
      xodtemplate_cache_file[sizeof(xodtemplate_cache_file)-1]='\x0';

      /* open the main config file for reading */
      if((thefile=mmap_fopen(main_config_file))==NULL)
            return ERROR;

      /* read in all lines from the main config file */
      while(1){

            /* free memory */
            free(input);

            /* read the next line */
            if((input=mmap_fgets(thefile))==NULL)
                  break;

            /* strip input */
            strip(input);

            /* skip blank lines and comments */
            if(input[0]=='#' || input[0]==';' || input[0]=='\x0')
                  continue;

            temp_ptr=strtok(input,"=");
            if(temp_ptr==NULL)
                  continue;

            /* cached object file definition (overrides default location) */
            if(strstr(temp_ptr,"object_cache_file")==temp_ptr){

                  /* get the config file name */
                  temp_ptr=strtok(NULL,"\n");
                  if(temp_ptr==NULL)
                        continue;

                  strncpy(xodtemplate_cache_file,temp_ptr,sizeof(xodtemplate_cache_file)-1);
                  xodtemplate_cache_file[sizeof(xodtemplate_cache_file)-1]='\x0';
                    }
              }

      /* close the file */
      mmap_fclose(thefile);

#ifdef NSCORE
      /* save the object cache file macro */
      if(macro_x[MACRO_OBJECTCACHEFILE]!=NULL)
            free(macro_x[MACRO_OBJECTCACHEFILE]);
      macro_x[MACRO_OBJECTCACHEFILE]=(char *)strdup(xodtemplate_cache_file);
      if(macro_x[MACRO_OBJECTCACHEFILE]!=NULL)
            strip(macro_x[MACRO_OBJECTCACHEFILE]);
#endif

#ifdef DEBUG0
      printf("xodtemplate_grab_config_info() end\n");
#endif
      return OK;
        }



/* process all files in a specific config directory */
int xodtemplate_process_config_dir(char *dirname, int options){
      char file[MAX_FILENAME_LENGTH];
      DIR *dirp;
      struct dirent *dirfile;
      int result=OK;
      int x;
      char link_buffer[MAX_FILENAME_LENGTH];
      char linked_to_buffer[MAX_FILENAME_LENGTH];
      struct stat stat_buf;
      ssize_t readlink_count;
#ifdef NSCORE
      char temp_buffer[MAX_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_process_config_dir() start\n");
#endif

      /* open the directory for reading */
      dirp=opendir(dirname);
      if(dirp==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not open config directory '%s' for reading.\n",dirname);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* process all files in the directory... */
      while((dirfile=readdir(dirp))!=NULL){

            /* skip hidden files and directories, and current and parent dir */
            if(dirfile->d_name[0]=='.')
                  continue;

            /* create /path/to/file */
            snprintf(file,sizeof(file),"%s/%s",dirname,dirfile->d_name);
            file[sizeof(file)-1]='\x0';

            /* process this if it's a non-hidden config file... */
            if(stat(file,&stat_buf)==-1){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not open config directory member '%s' for reading.\n",file);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  closedir(dirp);
                  return ERROR;
                  }

            switch(stat_buf.st_mode & S_IFMT){

            case S_IFREG:
                  x=strlen(dirfile->d_name);
                  if(x<=4 || strcmp(dirfile->d_name+(x-4),".cfg"))
                        break;

                  /* process the config file */
                  result=xodtemplate_process_config_file(file,options);

                  if(result==ERROR){
                        closedir(dirp);
                        return ERROR;
                        }

                  break;

            case S_IFDIR:
                  /* recurse into subdirectories... */
                  result=xodtemplate_process_config_dir(file,options);

                  if(result==ERROR){
                        closedir(dirp);
                        return ERROR;
                        }

                  break;

            default:
                  /* everything else we ignore */
                  break;
                  }
            }

      closedir(dirp);

#ifdef DEBUG0
      printf("xodtemplate_process_config_dir() end\n");
#endif

      return result;
      }



/* process data in a specific config file */
int xodtemplate_process_config_file(char *filename, int options){
      mmapfile *thefile;
      char *input=NULL;
      register int in_definition=FALSE;
      register int current_line=0;
      int result=OK;
      register int x;
      register int y;
      char *ptr;
#ifdef NSCORE
      char temp_buffer[MAX_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_process_config_file() start\n");
#endif


      /* save config file name */
      xodtemplate_config_files[xodtemplate_current_config_file++]=strdup(filename);

      /* reallocate memory for config files */
      if(!(xodtemplate_current_config_file%256)){
            xodtemplate_config_files=(char **)realloc(xodtemplate_config_files,(xodtemplate_current_config_file+256)*sizeof(char **));
            if(xodtemplate_config_files==NULL){
#ifdef DEBUG1
                  printf("Error: Cannot re-allocate memory for config file names!\n");
#endif
                  return ERROR;
                    }
              }

      /* open the config file for reading */
      if((thefile=mmap_fopen(filename))==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Cannot open config file '%s' for reading: %s\n",filename,strerror(errno));
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* read in all lines from the config file */
      while(1){

            /* free memory */
            free(input);

            /* read the next line */
            if((input=mmap_fgets(thefile))==NULL)
                  break;

            current_line++;

            /* grab data before comment delimiter - faster than a strtok() and strncpy()... */
            for(x=0;input[x]!='\x0';x++)
                  if(input[x]==';')
                        break;
            input[x]='\x0';

            /* strip input */
            strip(input);

            /* skip empty lines */
            if(input[0]=='\x0' || input[0]=='#')
                  continue;

            /* this is the start of an object definition */
            if(strstr(input,"define")==input){

                  /* get the type of object we're defining... */
                  for(x=6;input[x]!='\x0';x++)
                        if(input[x]!=' ' && input[x]!='\t')
                              break;
                  for(y=0;input[x]!='\x0';x++){
                        if(input[x]==' ' || input[x]=='\t' ||  input[x]=='{')
                              break;
                        else
                              input[y++]=input[x];
                          }
                  input[y]='\x0';

                  /* make sure an object type is specified... */
                  if(input[0]=='\x0'){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: No object type specified in file '%s' on line %d.\n",filename,current_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        result=ERROR;
                        break;
                          }

                  /* check validity of object type */
                  if(strcmp(input,"timeperiod") && strcmp(input,"command") && strcmp(input,"contact") && strcmp(input,"contactgroup") && strcmp(input,"host") && strcmp(input,"hostgroup") && strcmp(input,"servicegroup") && strcmp(input,"service") && strcmp(input,"servicedependency") && strcmp(input,"serviceescalation") && strcmp(input,"hostgroupescalation") && strcmp(input,"hostdependency") && strcmp(input,"hostescalation") && strcmp(input,"hostextinfo") && strcmp(input,"serviceextinfo")){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid object definition type '%s' in file '%s' on line %d.\n",input,filename,current_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        result=ERROR;
                        break;
                          }

                  /* we're already in an object definition... */
                  if(in_definition==TRUE){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Unexpected start of object definition in file '%s' on line %d.  Make sure you close preceding objects before starting a new one.\n",filename,current_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif                        
                        result=ERROR;
                        break;
                          }

                  /* start a new definition */
                  if(xodtemplate_begin_object_definition(input,options,xodtemplate_current_config_file,current_line)==ERROR){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add object definition in file '%s' on line %d.\n",filename,current_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        result=ERROR;
                        break;
                          }

                  in_definition=TRUE;
                    }

            /* this is the close of an object definition */
            else if(!strcmp(input,"}") && in_definition==TRUE){

                  in_definition=FALSE;

                  /* close out current definition */
                  if(xodtemplate_end_object_definition(options)==ERROR){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not complete object definition in file '%s' on line %d.\n",filename,current_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        result=ERROR;
                        break;
                          }
                    }

            /* we're currently inside an object definition */
            else if(in_definition==TRUE){

                  /* this is the close of an object definition */
                  if(!strcmp(input,"}")){

                        in_definition=FALSE;

                        /* close out current definition */
                        if(xodtemplate_end_object_definition(options)==ERROR){
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not complete object definition in file '%s' on line %d.\n",filename,current_line);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              result=ERROR;
                              break;
                                  }
                            }

                  /* this is a directive inside an object definition */
                  else{

                        /* add directive to object definition */
                        if(xodtemplate_add_object_property(input,options)==ERROR){
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add object property in file '%s' on line %d.\n",filename,current_line);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              result=ERROR;
                              break;
                                }
                          }
                    }

            /* include another file */
            else if(strstr(input,"include_file=")==input){

                  ptr=strtok(input,"=");
                  ptr=strtok(NULL,"\n");

                  if(ptr!=NULL){
                        result=xodtemplate_process_config_file(ptr,options);
                        if(result==ERROR)
                              break;
                          }
                    }

            /* include a directory */
            else if(strstr(input,"include_dir")==input){

                  ptr=strtok(input,"=");
                  ptr=strtok(NULL,"\n");

                  if(ptr!=NULL){
                        result=xodtemplate_process_config_dir(ptr,options);
                        if(result==ERROR)
                              break;
                          }
                    }

            /* unexpected token or statement */
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Unexpected token or statement in file '%s' on line %d.\n",filename,current_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  result=ERROR;
                  break;
                    }
              }

      /* free memory and close file */
      free(input);
      mmap_fclose(thefile);

      /* whoops - EOF while we were in the middle of an object definition... */
      if(in_definition==TRUE && result==OK){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Unexpected EOF in file '%s' on line %d - check for a missing closing bracket.\n",filename,current_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            result=ERROR;
              }

#ifdef DEBUG0
      printf("xodtemplate_process_config_file() end\n");
#endif

      return result;
        }





/******************************************************************/
/***************** OBJECT DEFINITION FUNCTIONS ********************/
/******************************************************************/

/* starts a new object definition */
int xodtemplate_begin_object_definition(char *input, int options, int config_file, int start_line){
      int result=OK;
      xodtemplate_timeperiod *new_timeperiod;
      xodtemplate_command *new_command;
      xodtemplate_contactgroup *new_contactgroup;
      xodtemplate_hostgroup *new_hostgroup;
      xodtemplate_servicegroup *new_servicegroup;
      xodtemplate_servicedependency *new_servicedependency;
      xodtemplate_serviceescalation *new_serviceescalation;
      xodtemplate_contact *new_contact;
      xodtemplate_host *new_host;
      xodtemplate_service *new_service;
      xodtemplate_hostdependency *new_hostdependency;
      xodtemplate_hostescalation *new_hostescalation;
      xodtemplate_hostextinfo *new_hostextinfo;
      xodtemplate_serviceextinfo *new_serviceextinfo;
      int x;

#ifdef DEBUG0
      printf("xodtemplate_begin_object_definition() start\n");
#endif

      if(!strcmp(input,"service"))
            xodtemplate_current_object_type=XODTEMPLATE_SERVICE;
      else if(!strcmp(input,"host"))
            xodtemplate_current_object_type=XODTEMPLATE_HOST;
      else if(!strcmp(input,"command"))
            xodtemplate_current_object_type=XODTEMPLATE_COMMAND;
      else if(!strcmp(input,"contact"))
            xodtemplate_current_object_type=XODTEMPLATE_CONTACT;
      else if(!strcmp(input,"contactgroup"))
            xodtemplate_current_object_type=XODTEMPLATE_CONTACTGROUP;
      else if(!strcmp(input,"hostgroup"))
            xodtemplate_current_object_type=XODTEMPLATE_HOSTGROUP;
      else if(!strcmp(input,"servicegroup"))
            xodtemplate_current_object_type=XODTEMPLATE_SERVICEGROUP;
      else if(!strcmp(input,"timeperiod"))
            xodtemplate_current_object_type=XODTEMPLATE_TIMEPERIOD;
      else if(!strcmp(input,"servicedependency"))
            xodtemplate_current_object_type=XODTEMPLATE_SERVICEDEPENDENCY;
      else if(!strcmp(input,"serviceescalation"))
            xodtemplate_current_object_type=XODTEMPLATE_SERVICEESCALATION;
      else if(!strcmp(input,"hostdependency"))
            xodtemplate_current_object_type=XODTEMPLATE_HOSTDEPENDENCY;
      else if(!strcmp(input,"hostescalation"))
            xodtemplate_current_object_type=XODTEMPLATE_HOSTESCALATION;
      else if(!strcmp(input,"hostextinfo"))
            xodtemplate_current_object_type=XODTEMPLATE_HOSTEXTINFO;
      else if(!strcmp(input,"serviceextinfo"))
            xodtemplate_current_object_type=XODTEMPLATE_SERVICEEXTINFO;
      else
            return ERROR;


      /* check to see if we should process this type of object */
      switch(xodtemplate_current_object_type){
      case XODTEMPLATE_TIMEPERIOD:
            if(!(options & READ_TIMEPERIODS))
                  return OK;
            break;
      case XODTEMPLATE_COMMAND:
            if(!(options & READ_COMMANDS))
                  return OK;
            break;
      case XODTEMPLATE_CONTACT:
            if(!(options & READ_CONTACTS))
                  return OK;
            break;
      case XODTEMPLATE_CONTACTGROUP:
            if(!(options & READ_CONTACTGROUPS))
                  return OK;
            break;
      case XODTEMPLATE_HOST:
            if(!(options & READ_HOSTS))
                  return OK;
            break;
      case XODTEMPLATE_HOSTGROUP:
            if(!(options & READ_HOSTGROUPS))
                  return OK;
            break;
      case XODTEMPLATE_SERVICEGROUP:
            if(!(options & READ_SERVICEGROUPS))
                  return OK;
            break;
      case XODTEMPLATE_SERVICE:
            if(!(options & READ_SERVICES))
                  return OK;
            break;
      case XODTEMPLATE_SERVICEDEPENDENCY:
            if(!(options & READ_SERVICEDEPENDENCIES))
                  return OK;
            break;
      case XODTEMPLATE_SERVICEESCALATION:
            if(!(options & READ_SERVICEESCALATIONS))
                  return OK;
            break;
      case XODTEMPLATE_HOSTDEPENDENCY:
            if(!(options & READ_HOSTDEPENDENCIES))
                  return OK;
            break;
      case XODTEMPLATE_HOSTESCALATION:
            if(!(options & READ_HOSTESCALATIONS))
                  return OK;
            break;
      case XODTEMPLATE_HOSTEXTINFO:
            if(!(options & READ_HOSTEXTINFO))
                  return OK;
            break;
      case XODTEMPLATE_SERVICEEXTINFO:
            if(!(options & READ_SERVICEEXTINFO))
                  return OK;
            break;
      default:
            return ERROR;
            break;
              }



      /* add a new (blank) object */
      switch(xodtemplate_current_object_type){

      case XODTEMPLATE_TIMEPERIOD:

            /* allocate memory */
            new_timeperiod=(xodtemplate_timeperiod *)malloc(sizeof(xodtemplate_timeperiod));
            if(new_timeperiod==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for timeperiod definition\n");
#endif
                  return ERROR;
                    }

            new_timeperiod->template=NULL;
            new_timeperiod->name=NULL;
            new_timeperiod->timeperiod_name=NULL;
            new_timeperiod->alias=NULL;
            for(x=0;x<7;x++)
                  new_timeperiod->timeranges[x]=NULL;
            new_timeperiod->has_been_resolved=FALSE;
            new_timeperiod->register_object=TRUE;
            new_timeperiod->_config_file=config_file;
            new_timeperiod->_start_line=start_line;

            /* add new timeperiod to head of list in memory */
            new_timeperiod->next=xodtemplate_timeperiod_list;
            xodtemplate_timeperiod_list=new_timeperiod;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_timeperiod_list;

            break;

      case XODTEMPLATE_COMMAND:

            /* allocate memory */
            new_command=(xodtemplate_command *)malloc(sizeof(xodtemplate_command));
            if(new_command==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for command definition\n");
#endif
                  return ERROR;
                    }
            
            new_command->template=NULL;
            new_command->name=NULL;
            new_command->command_name=NULL;
            new_command->command_line=NULL;
            new_command->has_been_resolved=FALSE;
            new_command->register_object=TRUE;
            new_command->_config_file=config_file;
            new_command->_start_line=start_line;

            /* add new command to head of list in memory */
            new_command->next=xodtemplate_command_list;
            xodtemplate_command_list=new_command;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_command_list;

            break;

      case XODTEMPLATE_CONTACTGROUP:

            /* allocate memory */
            new_contactgroup=(xodtemplate_contactgroup *)malloc(sizeof(xodtemplate_contactgroup));
            if(new_contactgroup==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for contactgroup definition\n");
#endif
                  return ERROR;
                    }
            
            new_contactgroup->template=NULL;
            new_contactgroup->name=NULL;
            new_contactgroup->contactgroup_name=NULL;
            new_contactgroup->alias=NULL;
            new_contactgroup->members=NULL;
            new_contactgroup->has_been_resolved=FALSE;
            new_contactgroup->register_object=TRUE;
            new_contactgroup->_config_file=config_file;
            new_contactgroup->_start_line=start_line;

            /* add new contactgroup to head of list in memory */
            new_contactgroup->next=xodtemplate_contactgroup_list;
            xodtemplate_contactgroup_list=new_contactgroup;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_contactgroup_list;
            break;


      case XODTEMPLATE_HOSTGROUP:

            /* allocate memory */
            new_hostgroup=(xodtemplate_hostgroup *)malloc(sizeof(xodtemplate_hostgroup));
            if(new_hostgroup==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for hostgroup definition\n");
#endif
                  return ERROR;
                    }
            
            new_hostgroup->template=NULL;
            new_hostgroup->name=NULL;
            new_hostgroup->hostgroup_name=NULL;
            new_hostgroup->alias=NULL;
            new_hostgroup->members=NULL;
            new_hostgroup->has_been_resolved=FALSE;
            new_hostgroup->register_object=TRUE;
            new_hostgroup->_config_file=config_file;
            new_hostgroup->_start_line=start_line;

            /* add new hostgroup to head of list in memory */
            new_hostgroup->next=xodtemplate_hostgroup_list;
            xodtemplate_hostgroup_list=new_hostgroup;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_hostgroup_list;
            break;

      case XODTEMPLATE_SERVICEGROUP:

            /* allocate memory */
            new_servicegroup=(xodtemplate_servicegroup *)malloc(sizeof(xodtemplate_servicegroup));
            if(new_servicegroup==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for servicegroup definition\n");
#endif
                  return ERROR;
                    }
            
            new_servicegroup->template=NULL;
            new_servicegroup->name=NULL;
            new_servicegroup->servicegroup_name=NULL;
            new_servicegroup->alias=NULL;
            new_servicegroup->members=NULL;
            new_servicegroup->has_been_resolved=FALSE;
            new_servicegroup->register_object=TRUE;
            new_servicegroup->_config_file=config_file;
            new_servicegroup->_start_line=start_line;

            /* add new servicegroup to head of list in memory */
            new_servicegroup->next=xodtemplate_servicegroup_list;
            xodtemplate_servicegroup_list=new_servicegroup;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_servicegroup_list;

            break;

      case XODTEMPLATE_SERVICEDEPENDENCY:

            /* allocate memory */
            new_servicedependency=(xodtemplate_servicedependency *)malloc(sizeof(xodtemplate_servicedependency));
            if(new_servicedependency==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for servicedependency definition\n");
#endif
                  return ERROR;
                    }
            
            new_servicedependency->template=NULL;
            new_servicedependency->name=NULL;
            new_servicedependency->servicegroup_name=NULL;
            new_servicedependency->hostgroup_name=NULL;
            new_servicedependency->host_name=NULL;
            new_servicedependency->service_description=NULL;
            new_servicedependency->dependent_servicegroup_name=NULL;
            new_servicedependency->dependent_hostgroup_name=NULL;
            new_servicedependency->dependent_host_name=NULL;
            new_servicedependency->dependent_service_description=NULL;
            new_servicedependency->inherits_parent=FALSE;
            new_servicedependency->fail_execute_on_ok=FALSE;
            new_servicedependency->fail_execute_on_unknown=FALSE;
            new_servicedependency->fail_execute_on_warning=FALSE;
            new_servicedependency->fail_execute_on_critical=FALSE;
            new_servicedependency->fail_execute_on_pending=FALSE;
            new_servicedependency->fail_notify_on_ok=FALSE;
            new_servicedependency->fail_notify_on_unknown=FALSE;
            new_servicedependency->fail_notify_on_warning=FALSE;
            new_servicedependency->fail_notify_on_critical=FALSE;
            new_servicedependency->fail_notify_on_pending=FALSE;
            new_servicedependency->have_inherits_parent=FALSE;
            new_servicedependency->have_execution_dependency_options=FALSE;
            new_servicedependency->have_notification_dependency_options=FALSE;
            new_servicedependency->has_been_resolved=FALSE;
            new_servicedependency->register_object=TRUE;
            new_servicedependency->_config_file=config_file;
            new_servicedependency->_start_line=start_line;

            /* add new servicedependency to head of list in memory */
            new_servicedependency->next=xodtemplate_servicedependency_list;
            xodtemplate_servicedependency_list=new_servicedependency;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_servicedependency_list;
            break;

      case XODTEMPLATE_SERVICEESCALATION:

            /* allocate memory */
            new_serviceescalation=(xodtemplate_serviceescalation *)malloc(sizeof(xodtemplate_serviceescalation));
            if(new_serviceescalation==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for serviceescalation definition\n");
#endif
                  return ERROR;
                    }
            
            new_serviceescalation->template=NULL;
            new_serviceescalation->name=NULL;
            new_serviceescalation->servicegroup_name=NULL;
            new_serviceescalation->hostgroup_name=NULL;
            new_serviceescalation->host_name=NULL;
            new_serviceescalation->service_description=NULL;
            new_serviceescalation->escalation_period=NULL;
            new_serviceescalation->contact_groups=NULL;
            new_serviceescalation->first_notification=-2;
            new_serviceescalation->last_notification=-2;
            new_serviceescalation->notification_interval=-2;
            new_serviceescalation->escalate_on_warning=FALSE;
            new_serviceescalation->escalate_on_unknown=FALSE;
            new_serviceescalation->escalate_on_critical=FALSE;
            new_serviceescalation->escalate_on_recovery=FALSE;
            new_serviceescalation->have_first_notification=FALSE;
            new_serviceescalation->have_last_notification=FALSE;
            new_serviceescalation->have_notification_interval=FALSE;
            new_serviceescalation->have_escalation_options=FALSE;
            new_serviceescalation->has_been_resolved=FALSE;
            new_serviceescalation->register_object=TRUE;
            new_serviceescalation->_config_file=config_file;
            new_serviceescalation->_start_line=start_line;

            /* add new serviceescalation to head of list in memory */
            new_serviceescalation->next=xodtemplate_serviceescalation_list;
            xodtemplate_serviceescalation_list=new_serviceescalation;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_serviceescalation_list;
            break;

      case XODTEMPLATE_CONTACT:

            /* allocate memory */
            new_contact=(xodtemplate_contact *)malloc(sizeof(xodtemplate_contact));
            if(new_contact==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for contact definition\n");
#endif
                  return ERROR;
                    }
            
            new_contact->template=NULL;
            new_contact->name=NULL;
            new_contact->contact_name=NULL;
            new_contact->alias=NULL;
            new_contact->contactgroups=NULL;
            new_contact->email=NULL;
            new_contact->pager=NULL;
            for(x=0;x<MAX_XODTEMPLATE_CONTACT_ADDRESSES;x++)
                  new_contact->address[x]=NULL;
            new_contact->host_notification_period=NULL;
            new_contact->host_notification_commands=NULL;
            new_contact->service_notification_period=NULL;
            new_contact->service_notification_commands=NULL;
            new_contact->notify_on_host_down=FALSE;
            new_contact->notify_on_host_unreachable=FALSE;
            new_contact->notify_on_host_recovery=FALSE;
            new_contact->notify_on_host_flapping=FALSE;
            new_contact->notify_on_service_unknown=FALSE;
            new_contact->notify_on_service_warning=FALSE;
            new_contact->notify_on_service_critical=FALSE;
            new_contact->notify_on_service_recovery=FALSE;
            new_contact->notify_on_service_flapping=FALSE;
            new_contact->have_host_notification_options=FALSE;
            new_contact->have_service_notification_options=FALSE;
            new_contact->has_been_resolved=FALSE;
            new_contact->register_object=TRUE;
            new_contact->_config_file=config_file;
            new_contact->_start_line=start_line;

            /* add new contact to head of list in memory */
            new_contact->next=xodtemplate_contact_list;
            xodtemplate_contact_list=new_contact;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_contact_list;
            break;

      case XODTEMPLATE_HOST:

            /* allocate memory */
            new_host=(xodtemplate_host *)malloc(sizeof(xodtemplate_host));
            if(new_host==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for host definition\n");
#endif
                  return ERROR;
                    }
            
            new_host->template=NULL;
            new_host->name=NULL;
            new_host->host_name=NULL;
            new_host->alias=NULL;
            new_host->address=NULL;
            new_host->parents=NULL;
            new_host->hostgroups=NULL;
            new_host->check_command=NULL;
            new_host->check_period=NULL;
            new_host->event_handler=NULL;
            new_host->contact_groups=NULL;
            new_host->notification_period=NULL;

            new_host->check_interval=0;
            new_host->have_check_interval=FALSE;
            new_host->active_checks_enabled=TRUE;
            new_host->have_active_checks_enabled=FALSE;
            new_host->passive_checks_enabled=TRUE;
            new_host->have_passive_checks_enabled=FALSE;
            new_host->obsess_over_host=TRUE;
            new_host->have_obsess_over_host=FALSE;
            new_host->max_check_attempts=-2;
            new_host->have_max_check_attempts=FALSE;
            new_host->event_handler_enabled=TRUE;
            new_host->have_event_handler_enabled=FALSE;
            new_host->check_freshness=FALSE;
            new_host->have_check_freshness=FALSE;
            new_host->freshness_threshold=0;
            new_host->have_freshness_threshold=0;
            new_host->flap_detection_enabled=TRUE;
            new_host->have_flap_detection_enabled=FALSE;
            new_host->low_flap_threshold=0.0;
            new_host->have_low_flap_threshold=FALSE;
            new_host->high_flap_threshold=0.0;
            new_host->have_high_flap_threshold=FALSE;
            new_host->notify_on_down=FALSE;
            new_host->notify_on_unreachable=FALSE;
            new_host->notify_on_recovery=FALSE;
            new_host->notify_on_flapping=FALSE;
            new_host->have_notification_options=FALSE;
            new_host->notifications_enabled=TRUE;
            new_host->have_notifications_enabled=FALSE;
            new_host->notification_interval=-2;
            new_host->have_notification_interval=FALSE;
            new_host->stalk_on_up=FALSE;
            new_host->stalk_on_down=FALSE;
            new_host->stalk_on_unreachable=FALSE;
            new_host->have_stalking_options=FALSE;
            new_host->process_perf_data=TRUE;
            new_host->have_process_perf_data=FALSE;
            new_host->failure_prediction_enabled=TRUE;
            new_host->have_failure_prediction_enabled=FALSE;
            new_host->failure_prediction_options=NULL;
            new_host->retain_status_information=TRUE;
            new_host->have_retain_status_information=FALSE;
            new_host->retain_nonstatus_information=TRUE;
            new_host->have_retain_nonstatus_information=FALSE;
            new_host->has_been_resolved=FALSE;
            new_host->register_object=TRUE;
            new_host->_config_file=config_file;
            new_host->_start_line=start_line;

            /* add new host to head of list in memory */
            new_host->next=xodtemplate_host_list;
            xodtemplate_host_list=new_host;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_host_list;
            break;

      case XODTEMPLATE_SERVICE:

            /* allocate memory */
            new_service=(xodtemplate_service *)malloc(sizeof(xodtemplate_service));
            if(new_service==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for service definition\n");
#endif
                  return ERROR;
                    }
            
            new_service->template=NULL;
            new_service->name=NULL;
            new_service->hostgroup_name=NULL;
            new_service->host_name=NULL;
            new_service->service_description=NULL;
            new_service->servicegroups=NULL;
            new_service->check_command=NULL;
            new_service->check_period=NULL;
            new_service->event_handler=NULL;
            new_service->notification_period=NULL;
            new_service->contact_groups=NULL;

            new_service->max_check_attempts=-2;
            new_service->have_max_check_attempts=FALSE;
            new_service->normal_check_interval=-2;
            new_service->have_normal_check_interval=FALSE;
            new_service->retry_check_interval=-2;
            new_service->have_retry_check_interval=FALSE;
            new_service->active_checks_enabled=TRUE;
            new_service->have_active_checks_enabled=FALSE;
            new_service->passive_checks_enabled=TRUE;
            new_service->have_passive_checks_enabled=FALSE;
            new_service->parallelize_check=TRUE;
            new_service->have_parallelize_check=FALSE;
            new_service->is_volatile=FALSE;
            new_service->have_is_volatile=FALSE;
            new_service->obsess_over_service=TRUE;
            new_service->have_obsess_over_service=FALSE;
            new_service->event_handler_enabled=TRUE;
            new_service->have_event_handler_enabled=FALSE;
            new_service->check_freshness=FALSE;
            new_service->have_check_freshness=FALSE;
            new_service->freshness_threshold=0;
            new_service->have_freshness_threshold=FALSE;
            new_service->flap_detection_enabled=TRUE;
            new_service->have_flap_detection_enabled=FALSE;
            new_service->low_flap_threshold=0.0;
            new_service->have_low_flap_threshold=FALSE;
            new_service->high_flap_threshold=0.0;
            new_service->have_high_flap_threshold=FALSE;
            new_service->notify_on_unknown=FALSE;
            new_service->notify_on_warning=FALSE;
            new_service->notify_on_critical=FALSE;
            new_service->notify_on_recovery=FALSE;
            new_service->notify_on_flapping=FALSE;
            new_service->have_notification_options=FALSE;
            new_service->notifications_enabled=TRUE;
            new_service->have_notifications_enabled=FALSE;
            new_service->notification_interval=-2;
            new_service->have_notification_interval=FALSE;
            new_service->stalk_on_ok=FALSE;
            new_service->stalk_on_unknown=FALSE;
            new_service->stalk_on_warning=FALSE;
            new_service->stalk_on_critical=FALSE;
            new_service->have_stalking_options=FALSE;
            new_service->process_perf_data=TRUE;
            new_service->have_process_perf_data=FALSE;
            new_service->failure_prediction_enabled=TRUE;
            new_service->have_failure_prediction_enabled=FALSE;
            new_service->failure_prediction_options=NULL;
            new_service->retain_status_information=TRUE;
            new_service->have_retain_status_information=FALSE;
            new_service->retain_nonstatus_information=TRUE;
            new_service->have_retain_nonstatus_information=FALSE;
            new_service->has_been_resolved=FALSE;
            new_service->register_object=TRUE;
            new_service->_config_file=config_file;
            new_service->_start_line=start_line;

            /* add new service to head of list in memory */
            new_service->next=xodtemplate_service_list;
            xodtemplate_service_list=new_service;

            /* update current object pointer */
            xodtemplate_current_object=new_service;
            break;

      case XODTEMPLATE_HOSTDEPENDENCY:

            /* allocate memory */
            new_hostdependency=(xodtemplate_hostdependency *)malloc(sizeof(xodtemplate_hostdependency));
            if(new_hostdependency==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for hostdependency definition\n");
#endif
                  return ERROR;
                    }
            
            new_hostdependency->template=NULL;
            new_hostdependency->name=NULL;
            new_hostdependency->hostgroup_name=NULL;
            new_hostdependency->dependent_hostgroup_name=NULL;
            new_hostdependency->host_name=NULL;
            new_hostdependency->dependent_host_name=NULL;
            new_hostdependency->inherits_parent=FALSE;
            new_hostdependency->fail_notify_on_up=FALSE;
            new_hostdependency->fail_notify_on_down=FALSE;
            new_hostdependency->fail_notify_on_unreachable=FALSE;
            new_hostdependency->fail_notify_on_pending=FALSE;
            new_hostdependency->fail_execute_on_up=FALSE;
            new_hostdependency->fail_execute_on_down=FALSE;
            new_hostdependency->fail_execute_on_unreachable=FALSE;
            new_hostdependency->fail_execute_on_pending=FALSE;
            new_hostdependency->have_inherits_parent=FALSE;
            new_hostdependency->have_notification_dependency_options=FALSE;
            new_hostdependency->have_execution_dependency_options=FALSE;
            new_hostdependency->has_been_resolved=FALSE;
            new_hostdependency->register_object=TRUE;
            new_hostdependency->_config_file=config_file;
            new_hostdependency->_start_line=start_line;

            /* add new hostdependency to head of list in memory */
            new_hostdependency->next=xodtemplate_hostdependency_list;
            xodtemplate_hostdependency_list=new_hostdependency;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_hostdependency_list;
            break;

      case XODTEMPLATE_HOSTESCALATION:

            /* allocate memory */
            new_hostescalation=(xodtemplate_hostescalation *)malloc(sizeof(xodtemplate_hostescalation));
            if(new_hostescalation==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for hostescalation definition\n");
#endif
                  return ERROR;
                    }
            
            new_hostescalation->template=NULL;
            new_hostescalation->name=NULL;
            new_hostescalation->hostgroup_name=NULL;
            new_hostescalation->host_name=NULL;
            new_hostescalation->escalation_period=NULL;
            new_hostescalation->contact_groups=NULL;
            new_hostescalation->first_notification=-2;
            new_hostescalation->last_notification=-2;
            new_hostescalation->notification_interval=-2;
            new_hostescalation->escalate_on_down=FALSE;
            new_hostescalation->escalate_on_unreachable=FALSE;
            new_hostescalation->escalate_on_recovery=FALSE;
            new_hostescalation->have_first_notification=FALSE;
            new_hostescalation->have_last_notification=FALSE;
            new_hostescalation->have_notification_interval=FALSE;
            new_hostescalation->have_escalation_options=FALSE;
            new_hostescalation->has_been_resolved=FALSE;
            new_hostescalation->register_object=TRUE;
            new_hostescalation->_config_file=config_file;
            new_hostescalation->_start_line=start_line;

            /* add new hostescalation to head of list in memory */
            new_hostescalation->next=xodtemplate_hostescalation_list;
            xodtemplate_hostescalation_list=new_hostescalation;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_hostescalation_list;
            break;

      case XODTEMPLATE_HOSTEXTINFO:

            /* allocate memory */
            new_hostextinfo=(xodtemplate_hostextinfo *)malloc(sizeof(xodtemplate_hostextinfo));
            if(new_hostextinfo==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for extended host info\n");
#endif
                  return ERROR;
                    }

            new_hostextinfo->template=NULL;
            new_hostextinfo->name=NULL;
            new_hostextinfo->host_name=NULL;
            new_hostextinfo->hostgroup_name=NULL;
            new_hostextinfo->notes=NULL;
            new_hostextinfo->notes_url=NULL;
            new_hostextinfo->action_url=NULL;
            new_hostextinfo->icon_image=NULL;
            new_hostextinfo->icon_image_alt=NULL;
            new_hostextinfo->vrml_image=NULL;
            new_hostextinfo->statusmap_image=NULL;
            new_hostextinfo->x_2d=-1;
            new_hostextinfo->y_2d=-1;
            new_hostextinfo->x_3d=0.0;
            new_hostextinfo->y_3d=0.0;
            new_hostextinfo->z_3d=0.0;
            new_hostextinfo->have_2d_coords=FALSE;
            new_hostextinfo->have_3d_coords=FALSE;
            new_hostextinfo->has_been_resolved=FALSE;
            new_hostextinfo->register_object=TRUE;
            new_hostextinfo->_config_file=config_file;
            new_hostextinfo->_start_line=start_line;

            /* add new extended host info to head of list in memory */
            new_hostextinfo->next=xodtemplate_hostextinfo_list;
            xodtemplate_hostextinfo_list=new_hostextinfo;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_hostextinfo_list;
            break;

      case XODTEMPLATE_SERVICEEXTINFO:

            /* allocate memory */
            new_serviceextinfo=(xodtemplate_serviceextinfo *)malloc(sizeof(xodtemplate_serviceextinfo));
            if(new_serviceextinfo==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for extended service info\n");
#endif
                  return ERROR;
                    }

            new_serviceextinfo->template=NULL;
            new_serviceextinfo->name=NULL;
            new_serviceextinfo->host_name=NULL;
            new_serviceextinfo->hostgroup_name=NULL;
            new_serviceextinfo->service_description=NULL;
            new_serviceextinfo->notes=NULL;
            new_serviceextinfo->notes_url=NULL;
            new_serviceextinfo->action_url=NULL;
            new_serviceextinfo->icon_image=NULL;
            new_serviceextinfo->icon_image_alt=NULL;
            new_serviceextinfo->has_been_resolved=FALSE;
            new_serviceextinfo->register_object=TRUE;
            new_serviceextinfo->_config_file=config_file;
            new_serviceextinfo->_start_line=start_line;

            /* add new extended service info to head of list in memory */
            new_serviceextinfo->next=xodtemplate_serviceextinfo_list;
            xodtemplate_serviceextinfo_list=new_serviceextinfo;

            /* update current object pointer */
            xodtemplate_current_object=xodtemplate_serviceextinfo_list;
            break;

      default:
            return ERROR;
            break;
              }

#ifdef DEBUG0
      printf("xodtemplate_begin_object_definition() end\n");
#endif

      return result;
        }



/* adds a property to an object definition */
int xodtemplate_add_object_property(char *input, int options){
      int result=OK;
      char *variable=NULL;
      char *value=NULL;
      char *temp_ptr;
      xodtemplate_timeperiod *temp_timeperiod;
      xodtemplate_command *temp_command;
      xodtemplate_contactgroup *temp_contactgroup;
      xodtemplate_hostgroup *temp_hostgroup;
      xodtemplate_servicegroup *temp_servicegroup;
      xodtemplate_servicedependency *temp_servicedependency;
      xodtemplate_serviceescalation *temp_serviceescalation;
      xodtemplate_contact *temp_contact;
      xodtemplate_host *temp_host;
      xodtemplate_service *temp_service;
      xodtemplate_hostdependency *temp_hostdependency;
      xodtemplate_hostescalation *temp_hostescalation;
      xodtemplate_hostextinfo *temp_hostextinfo;
      xodtemplate_serviceextinfo *temp_serviceextinfo;
      register int x;
      register int y;
      register int len;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_add_object_property() start\n");
#endif


      /* check to see if we should process this type of object */
      switch(xodtemplate_current_object_type){
      case XODTEMPLATE_TIMEPERIOD:
            if(!(options & READ_TIMEPERIODS))
                  return OK;
            break;
      case XODTEMPLATE_COMMAND:
            if(!(options & READ_COMMANDS))
                  return OK;
            break;
      case XODTEMPLATE_CONTACT:
            if(!(options & READ_CONTACTS))
                  return OK;
            break;
      case XODTEMPLATE_CONTACTGROUP:
            if(!(options & READ_CONTACTGROUPS))
                  return OK;
            break;
      case XODTEMPLATE_HOST:
            if(!(options & READ_HOSTS))
                  return OK;
            break;
      case XODTEMPLATE_HOSTGROUP:
            if(!(options & READ_HOSTGROUPS))
                  return OK;
            break;
      case XODTEMPLATE_SERVICEGROUP:
            if(!(options & READ_SERVICEGROUPS))
                  return OK;
            break;
      case XODTEMPLATE_SERVICE:
            if(!(options & READ_SERVICES))
                  return OK;
            break;
      case XODTEMPLATE_SERVICEDEPENDENCY:
            if(!(options & READ_SERVICEDEPENDENCIES))
                  return OK;
            break;
      case XODTEMPLATE_SERVICEESCALATION:
            if(!(options & READ_SERVICEESCALATIONS))
                  return OK;
            break;
      case XODTEMPLATE_HOSTDEPENDENCY:
            if(!(options & READ_HOSTDEPENDENCIES))
                  return OK;
            break;
      case XODTEMPLATE_HOSTESCALATION:
            if(!(options & READ_HOSTESCALATIONS))
                  return OK;
            break;
      case XODTEMPLATE_HOSTEXTINFO:
            if(!(options & READ_HOSTEXTINFO))
                  return OK;
            break;
      case XODTEMPLATE_SERVICEEXTINFO:
            if(!(options & READ_SERVICEEXTINFO))
                  return OK;
            break;
      default:
            return ERROR;
            break;
              }

      /* allocate memory */
      len=strlen(input);
      if((variable=(char *)malloc(len+1))==NULL)
            return ERROR;
      if((value=(char *)malloc(len+1))==NULL){
            free(variable);
            return ERROR;
              }

      /* get variable name */
      strcpy(variable,input);
      for(x=0,y=0;input[x]!='\x0';x++){
            if(input[x]==' ' || input[x]=='\t')
                  break;
            y++;
              }
      variable[y]='\x0';
                  
      /* get variable value */
      /* skip leading whitespace */
      for(;input[x]!='\x0';x++){
            if(input[x]!=' ' && input[x]!='\t')
                  break;
              }
      if(x>=len){
#ifdef DEBUG1
            printf("Error: NULL variable value in object definition.\n");
#endif
            return ERROR;
              }
      strcpy(value,input+x);

      /*
      printf("RAW VARIABLE: '%s'\n",variable);
      printf("RAW VALUE: '%s'\n",value);
      */

#ifdef RUN_SLOW_AS_HELL
      strip(variable);
#endif
      strip(value);

      /*
      printf("STRIPPED VARIABLE: '%s'\n",variable);
      printf("STRIPPED VALUE: '%s'\n\n",value);
      */


      switch(xodtemplate_current_object_type){

      case XODTEMPLATE_TIMEPERIOD:
            
            temp_timeperiod=(xodtemplate_timeperiod *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_timeperiod->template=strdup(value);
                  if(temp_timeperiod->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for timeperiod template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_timeperiod(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for timeperiod '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_timeperiod->_config_file),temp_timeperiod->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_timeperiod->name=strdup(value);
                  if(temp_timeperiod->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for timeperiod name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"timeperiod_name")){
                  temp_timeperiod->timeperiod_name=strdup(value);
                  if(temp_timeperiod->timeperiod_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for timeperiod name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"alias")){
                  temp_timeperiod->alias=strdup(value);
                  if(temp_timeperiod->alias==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for timeperiod alias.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"monday") || !strcmp(variable,"tuesday") || !strcmp(variable,"wednesday") || !strcmp(variable,"thursday") || !strcmp(variable,"friday") || !strcmp(variable,"saturday") || !strcmp(variable,"sunday")){
                  if(!strcmp(variable,"monday"))
                        x=1;
                  else if(!strcmp(variable,"tuesday"))
                        x=2;
                  else if(!strcmp(variable,"wednesday"))
                        x=3;
                  else if(!strcmp(variable,"thursday"))
                        x=4;
                  else if(!strcmp(variable,"friday"))
                        x=5;
                  else if(!strcmp(variable,"saturday"))
                        x=6;
                  else
                        x=0;
                  temp_timeperiod->timeranges[x]=strdup(value);
                  if(temp_timeperiod->timeranges[x]==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for timeperiod timerange.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"register"))
                  temp_timeperiod->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid timeperiod object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }
            break;



      case XODTEMPLATE_COMMAND:

            temp_command=(xodtemplate_command *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_command->template=strdup(value);
                  if(temp_command->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for command template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_command(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for command '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_command->_config_file),temp_command->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_command->name=strdup(value);
                  if(temp_command->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for command name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"command_name")){
                  temp_command->command_name=strdup(value);
                  if(temp_command->command_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for command name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"command_line")){
                  temp_command->command_line=strdup(value);
                  if(temp_command->command_line==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for command line.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"register"))
                  temp_command->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid command object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;

      case XODTEMPLATE_CONTACTGROUP:

            temp_contactgroup=(xodtemplate_contactgroup *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_contactgroup->template=strdup(value);
                  if(temp_contactgroup->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contactgroup template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_contactgroup(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for contactgroup '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_contactgroup->_config_file),temp_contactgroup->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_contactgroup->name=strdup(value);
                  if(temp_contactgroup->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contactgroup name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"contactgroup_name")){
                  temp_contactgroup->contactgroup_name=strdup(value);
                  if(temp_contactgroup->contactgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contactgroup name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"alias")){
                  temp_contactgroup->alias=strdup(value);
                  if(temp_contactgroup->alias==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contactgroup alias.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"members")){
                  temp_contactgroup->members=strdup(value);
                  if(temp_contactgroup->members==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contactgroup members.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"register"))
                  temp_contactgroup->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid contactgroup object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;

      case XODTEMPLATE_HOSTGROUP:

            temp_hostgroup=(xodtemplate_hostgroup *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_hostgroup->template=strdup(value);
                  if(temp_hostgroup->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostgroup template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_hostgroup(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for hostgroup '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_hostgroup->_config_file),temp_hostgroup->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_hostgroup->name=strdup(value);
                  if(temp_hostgroup->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostgroup name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"hostgroup_name")){
                  temp_hostgroup->hostgroup_name=strdup(value);
                  if(temp_hostgroup->hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostgroup name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"alias")){
                  temp_hostgroup->alias=strdup(value);
                  if(temp_hostgroup->alias==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostgroup alias.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"members")){
                  if(temp_hostgroup->members==NULL)
                        temp_hostgroup->members=strdup(value);
                  else{
                        temp_hostgroup->members=(char *)realloc(temp_hostgroup->members,strlen(temp_hostgroup->members)+strlen(value)+2);
                        if(temp_hostgroup->members!=NULL){
                              strcat(temp_hostgroup->members,",");
                              strcat(temp_hostgroup->members,value);
                                }
                          }
                  if(temp_hostgroup->members==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostgroup members.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"register"))
                  temp_hostgroup->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid hostgroup object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;

      
      case XODTEMPLATE_SERVICEGROUP:

            temp_servicegroup=(xodtemplate_servicegroup *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_servicegroup->template=strdup(value);
                  if(temp_servicegroup->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicegroup template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_servicegroup(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for servicegroup '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_servicegroup->_config_file),temp_servicegroup->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_servicegroup->name=strdup(value);
                  if(temp_servicegroup->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicegroup name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"servicegroup_name")){
                  temp_servicegroup->servicegroup_name=strdup(value);
                  if(temp_servicegroup->servicegroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicegroup name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"alias")){
                  temp_servicegroup->alias=strdup(value);
                  if(temp_servicegroup->alias==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicegroup alias.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"members")){
                  if(temp_servicegroup->members==NULL)
                        temp_servicegroup->members=strdup(value);
                  else{
                        temp_servicegroup->members=(char *)realloc(temp_servicegroup->members,strlen(temp_servicegroup->members)+strlen(value)+2);
                        if(temp_servicegroup->members!=NULL){
                              strcat(temp_servicegroup->members,",");
                              strcat(temp_servicegroup->members,value);
                                }
                          }
                  if(temp_servicegroup->members==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicegroup members.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"register"))
                  temp_servicegroup->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid servicegroup object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;

      
      case XODTEMPLATE_SERVICEDEPENDENCY:

            temp_servicedependency=(xodtemplate_servicedependency *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_servicedependency->template=strdup(value);
                  if(temp_servicedependency->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_servicedependency(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for service dependency '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_servicedependency->_config_file),temp_servicedependency->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_servicedependency->name=strdup(value);
                  if(temp_servicedependency->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"servicegroup") || !strcmp(variable,"servicegroups") || !strcmp(variable,"servicegroup_name")){
                  temp_servicedependency->servicegroup_name=strdup(value);
                  if(temp_servicedependency->servicegroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency servicegroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"hostgroup") || !strcmp(variable,"hostgroups") || !strcmp(variable,"hostgroup_name")){
                  temp_servicedependency->hostgroup_name=strdup(value);
                  if(temp_servicedependency->hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency hostgroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host") || !strcmp(variable,"host_name") || !strcmp(variable,"master_host") || !strcmp(variable,"master_host_name")){
                  temp_servicedependency->host_name=strdup(value);
                  if(temp_servicedependency->host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency host.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"description") || !strcmp(variable,"service_description") || !strcmp(variable,"master_description") || !strcmp(variable,"master_service_description")){
                  temp_servicedependency->service_description=strdup(value);
                  if(temp_servicedependency->service_description==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency service_description.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"dependent_servicegroup") || !strcmp(variable,"dependent_servicegroups") || !strcmp(variable,"dependent_servicegroup_name")){
                  temp_servicedependency->dependent_servicegroup_name=strdup(value);
                  if(temp_servicedependency->dependent_servicegroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency dependent servicegroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"dependent_hostgroup") || !strcmp(variable,"dependent_hostgroups") || !strcmp(variable,"dependent_hostgroup_name")){
                  temp_servicedependency->dependent_hostgroup_name=strdup(value);
                  if(temp_servicedependency->dependent_hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency dependent hostgroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"dependent_host") || !strcmp(variable,"dependent_host_name")){
                  temp_servicedependency->dependent_host_name=strdup(value);
                  if(temp_servicedependency->dependent_host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency dependent host.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"dependent_description") || !strcmp(variable,"dependent_service_description")){
                  temp_servicedependency->dependent_service_description=strdup(value);
                  if(temp_servicedependency->dependent_service_description==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for servicedependency dependent service_description.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"inherits_parent")){
                  temp_servicedependency->inherits_parent=(atoi(value)>0)?TRUE:FALSE;
                  temp_servicedependency->have_inherits_parent=TRUE;
                    }
            else if(!strcmp(variable,"execution_failure_options") || !strcmp(variable,"execution_failure_criteria")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"o") || !strcmp(temp_ptr,"ok"))
                              temp_servicedependency->fail_execute_on_ok=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unknown"))
                              temp_servicedependency->fail_execute_on_unknown=TRUE;
                        else if(!strcmp(temp_ptr,"w") || !strcmp(temp_ptr,"warning"))
                              temp_servicedependency->fail_execute_on_warning=TRUE;
                        else if(!strcmp(temp_ptr,"c") || !strcmp(temp_ptr,"critical"))
                              temp_servicedependency->fail_execute_on_critical=TRUE;
                        else if(!strcmp(temp_ptr,"p") || !strcmp(temp_ptr,"pending"))
                              temp_servicedependency->fail_execute_on_pending=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_servicedependency->fail_execute_on_ok=FALSE;
                              temp_servicedependency->fail_execute_on_unknown=FALSE;
                              temp_servicedependency->fail_execute_on_warning=FALSE;
                              temp_servicedependency->fail_execute_on_critical=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid execution dependency option '%s' in servicedependency definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_servicedependency->have_execution_dependency_options=TRUE;
                    }
            else if(!strcmp(variable,"notification_failure_options") || !strcmp(variable,"notification_failure_criteria")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"o") || !strcmp(temp_ptr,"ok"))
                              temp_servicedependency->fail_notify_on_ok=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unknown"))
                              temp_servicedependency->fail_notify_on_unknown=TRUE;
                        else if(!strcmp(temp_ptr,"w") || !strcmp(temp_ptr,"warning"))
                              temp_servicedependency->fail_notify_on_warning=TRUE;
                        else if(!strcmp(temp_ptr,"c") || !strcmp(temp_ptr,"critical"))
                              temp_servicedependency->fail_notify_on_critical=TRUE;
                        else if(!strcmp(temp_ptr,"p") || !strcmp(temp_ptr,"pending"))
                              temp_servicedependency->fail_notify_on_pending=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_servicedependency->fail_notify_on_ok=FALSE;
                              temp_servicedependency->fail_notify_on_unknown=FALSE;
                              temp_servicedependency->fail_notify_on_warning=FALSE;
                              temp_servicedependency->fail_notify_on_critical=FALSE;
                              temp_servicedependency->fail_notify_on_pending=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid notification dependency option '%s' in servicedependency definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_servicedependency->have_notification_dependency_options=TRUE;
                    }
            else if(!strcmp(variable,"register"))
                  temp_servicedependency->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid servicedependency object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;

      
      case XODTEMPLATE_SERVICEESCALATION:

            temp_serviceescalation=(xodtemplate_serviceescalation *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_serviceescalation->template=strdup(value);
                  if(temp_serviceescalation->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for serviceescalation template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_serviceescalation(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for service escalation '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_serviceescalation->_config_file),temp_serviceescalation->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_serviceescalation->name=strdup(value);
                  if(temp_serviceescalation->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for serviceescalation name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"servicegroup") || !strcmp(variable,"servicegroups") || !strcmp(variable,"servicegroup_name")){
                  temp_serviceescalation->servicegroup_name=strdup(value);
                  if(temp_serviceescalation->servicegroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for serviceescalation servicegroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"hostgroup") || !strcmp(variable,"hostgroups") || !strcmp(variable,"hostgroup_name")){
                  temp_serviceescalation->hostgroup_name=strdup(value);
                  if(temp_serviceescalation->hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for serviceescalation hostgroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host") || !strcmp(variable,"host_name")){
                  temp_serviceescalation->host_name=strdup(value);
                  if(temp_serviceescalation->host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for serviceescalation host.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"description") || !strcmp(variable,"service_description")){
                  temp_serviceescalation->service_description=strdup(value);
                  if(temp_serviceescalation->service_description==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for serviceescalation service_description.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"contact_groups")){
                  temp_serviceescalation->contact_groups=strdup(value);
                  if(temp_serviceescalation->contact_groups==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for serviceescalation contact_groups.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"first_notification")){
                  temp_serviceescalation->first_notification=atoi(value);
                  temp_serviceescalation->have_first_notification=TRUE;
                    }
            else if(!strcmp(variable,"last_notification")){
                  temp_serviceescalation->last_notification=atoi(value);
                  temp_serviceescalation->have_last_notification=TRUE;
                    }
            else if(!strcmp(variable,"notification_interval")){
                  temp_serviceescalation->notification_interval=atoi(value);
                  temp_serviceescalation->have_notification_interval=TRUE;
                    }
            else if(!strcmp(variable,"escalation_period")){
                  temp_serviceescalation->escalation_period=strdup(value);
                  if(temp_serviceescalation->escalation_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for serviceescalation escalation_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"escalation_options")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"w") || !strcmp(temp_ptr,"warning"))
                              temp_serviceescalation->escalate_on_warning=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unknown"))
                              temp_serviceescalation->escalate_on_unknown=TRUE;
                        else if(!strcmp(temp_ptr,"c") || !strcmp(temp_ptr,"critical"))
                              temp_serviceescalation->escalate_on_critical=TRUE;
                        else if(!strcmp(temp_ptr,"r") || !strcmp(temp_ptr,"recovery"))
                              temp_serviceescalation->escalate_on_recovery=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_serviceescalation->escalate_on_warning=FALSE;
                              temp_serviceescalation->escalate_on_unknown=FALSE;
                              temp_serviceescalation->escalate_on_critical=FALSE;
                              temp_serviceescalation->escalate_on_recovery=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid escalation option '%s' in serviceescalation definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_serviceescalation->have_escalation_options=TRUE;
                    }
            else if(!strcmp(variable,"register"))
                  temp_serviceescalation->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid serviceescalation object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;
      

      case XODTEMPLATE_CONTACT:

            temp_contact=(xodtemplate_contact *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_contact->template=strdup(value);
                  if(temp_contact->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_contact(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for contact '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_contact->_config_file),temp_contact->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_contact->name=strdup(value);
                  if(temp_contact->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"contact_name")){
                  temp_contact->contact_name=strdup(value);
                  if(temp_contact->contact_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"alias")){
                  temp_contact->alias=strdup(value);
                  if(temp_contact->alias==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact alias.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"contactgroups")){
                  temp_contact->contactgroups=strdup(value);
                  if(temp_contact->contactgroups==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact contactgroups.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"email")){
                  temp_contact->email=strdup(value);
                  if(temp_contact->email==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact email.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"pager")){
                  temp_contact->pager=strdup(value);
                  if(temp_contact->pager==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact pager.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(strstr(variable,"address")==variable){
                  x=atoi(variable+7);
                  if(x<1 || x>MAX_XODTEMPLATE_CONTACT_ADDRESSES){
#ifdef DEBUG1
                        printf("Error: Invalid contact address id '%d'.\n",x);
#endif
                        return ERROR;
                          }
                  temp_contact->address[x-1]=strdup(value);
                  if(temp_contact->address[x-1]==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact address #%d.\n",x);
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host_notification_period")){
                  temp_contact->host_notification_period=strdup(value);
                  if(temp_contact->host_notification_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact host_notification_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host_notification_commands")){
                  temp_contact->host_notification_commands=strdup(value);
                  if(temp_contact->host_notification_commands==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact host_notification_commands.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"service_notification_period")){
                  temp_contact->service_notification_period=strdup(value);
                  if(temp_contact->service_notification_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact service_notification_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"service_notification_commands")){
                  temp_contact->service_notification_commands=strdup(value);
                  if(temp_contact->service_notification_commands==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact service_notification_commands.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host_notification_period")){
                  temp_contact->host_notification_period=strdup(value);
                  if(temp_contact->host_notification_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact host_notification_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"service_notification_period")){
                  temp_contact->service_notification_period=strdup(value);
                  if(temp_contact->service_notification_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for contact service_notification_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host_notification_options")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"d") || !strcmp(temp_ptr,"down"))
                              temp_contact->notify_on_host_down=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unreachable"))
                              temp_contact->notify_on_host_unreachable=TRUE;
                        else if(!strcmp(temp_ptr,"r") || !strcmp(temp_ptr,"recovery"))
                              temp_contact->notify_on_host_recovery=TRUE;
                        else if(!strcmp(temp_ptr,"f") || !strcmp(temp_ptr,"flapping"))
                              temp_contact->notify_on_host_flapping=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_contact->notify_on_host_down=FALSE;
                              temp_contact->notify_on_host_unreachable=FALSE;
                              temp_contact->notify_on_host_recovery=FALSE;
                              temp_contact->notify_on_host_flapping=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid host notification option '%s' in contact definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_contact->have_host_notification_options=TRUE;
                    }
            else if(!strcmp(variable,"service_notification_options")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unknown"))
                              temp_contact->notify_on_service_unknown=TRUE;
                        else if(!strcmp(temp_ptr,"w") || !strcmp(temp_ptr,"warning"))
                              temp_contact->notify_on_service_warning=TRUE;
                        else if(!strcmp(temp_ptr,"c") || !strcmp(temp_ptr,"critical"))
                              temp_contact->notify_on_service_critical=TRUE;
                        else if(!strcmp(temp_ptr,"r") || !strcmp(temp_ptr,"recovery"))
                              temp_contact->notify_on_service_recovery=TRUE;
                        else if(!strcmp(temp_ptr,"f") || !strcmp(temp_ptr,"flapping"))
                              temp_contact->notify_on_service_flapping=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_contact->notify_on_service_unknown=FALSE;
                              temp_contact->notify_on_service_warning=FALSE;
                              temp_contact->notify_on_service_critical=FALSE;
                              temp_contact->notify_on_service_recovery=FALSE;
                              temp_contact->notify_on_service_flapping=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid service notification option '%s' in contact definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_contact->have_service_notification_options=TRUE;
                    }
            else if(!strcmp(variable,"register"))
                  temp_contact->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid contact object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;


      case XODTEMPLATE_HOST:

            temp_host=(xodtemplate_host *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_host->template=strdup(value);
                  if(temp_host->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_host(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for host '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_host->_config_file),temp_host->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_host->name=strdup(value);
                  if(temp_host->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host_name")){
                  temp_host->host_name=strdup(value);
                  if(temp_host->host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"alias")){
                  temp_host->alias=strdup(value);
                  if(temp_host->alias==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host alias.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"address")){
                  temp_host->address=strdup(value);
                  if(temp_host->address==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host address.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"parents")){
                  temp_host->parents=strdup(value);
                  if(temp_host->parents==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host parents.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"hostgroups")){
                  temp_host->hostgroups=strdup(value);
                  if(temp_host->hostgroups==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host hostgroups.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"contact_groups")){
                  temp_host->contact_groups=strdup(value);
                  if(temp_host->contact_groups==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host contact_groups.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"notification_period")){
                  temp_host->notification_period=strdup(value);
                  if(temp_host->notification_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host notification_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"check_command")){
                  temp_host->check_command=strdup(value);
                  if(temp_host->check_command==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host check_command.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"check_period")){
                  temp_host->check_period=strdup(value);
                  if(temp_host->check_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host check_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"event_handler")){
                  temp_host->event_handler=strdup(value);
                  if(temp_host->event_handler==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host event_handler.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"failure_prediction_options")){
                  temp_host->failure_prediction_options=strdup(value);
                  if(temp_host->failure_prediction_options==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for host failure_prediction_options.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"check_interval") || !strcmp(variable,"normal_check_interval")){
                  temp_host->check_interval=atoi(value);
                  temp_host->have_check_interval=TRUE;
                    }
            else if(!strcmp(variable,"max_check_attempts")){
                  temp_host->max_check_attempts=atoi(value);
                  temp_host->have_max_check_attempts=TRUE;
                    }
            else if(!strcmp(variable,"checks_enabled") || !strcmp(variable,"active_checks_enabled")){
                  temp_host->active_checks_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_active_checks_enabled=TRUE;
                    }
            else if(!strcmp(variable,"passive_checks_enabled")){
                  temp_host->passive_checks_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_passive_checks_enabled=TRUE;
                    }
            else if(!strcmp(variable,"event_handler_enabled")){
                  temp_host->event_handler_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_event_handler_enabled=TRUE;
                    }
            else if(!strcmp(variable,"check_freshness")){
                  temp_host->check_freshness=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_check_freshness=TRUE;
                    }
            else if(!strcmp(variable,"freshness_threshold")){
                  temp_host->freshness_threshold=atoi(value);
                  temp_host->have_freshness_threshold=TRUE;
                    }
            else if(!strcmp(variable,"low_flap_threshold")){
                  temp_host->low_flap_threshold=strtod(value,NULL);
                  temp_host->have_low_flap_threshold=TRUE;
                    }
            else if(!strcmp(variable,"high_flap_threshold")){
                  temp_host->high_flap_threshold=strtod(value,NULL);
                  temp_host->have_high_flap_threshold=TRUE;
                    }
            else if(!strcmp(variable,"flap_detection_enabled")){
                  temp_host->flap_detection_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_flap_detection_enabled=TRUE;
                    }
            else if(!strcmp(variable,"notification_options")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"d") || !strcmp(temp_ptr,"down"))
                              temp_host->notify_on_down=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unreachable"))
                              temp_host->notify_on_unreachable=TRUE;
                        else if(!strcmp(temp_ptr,"r") || !strcmp(temp_ptr,"recovery"))
                              temp_host->notify_on_recovery=TRUE;
                        else if(!strcmp(temp_ptr,"f") || !strcmp(temp_ptr,"flapping"))
                              temp_host->notify_on_flapping=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_host->notify_on_down=FALSE;
                              temp_host->notify_on_unreachable=FALSE;
                              temp_host->notify_on_recovery=FALSE;
                              temp_host->notify_on_flapping=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid notification option '%s' in host definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_host->have_notification_options=TRUE;
                    }
            else if(!strcmp(variable,"notifications_enabled")){
                  temp_host->notifications_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_notifications_enabled=TRUE;
                    }
            else if(!strcmp(variable,"notification_interval")){
                  temp_host->notification_interval=atoi(value);
                  temp_host->have_notification_interval=TRUE;
                    }
            else if(!strcmp(variable,"stalking_options")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"o") || !strcmp(temp_ptr,"up"))
                              temp_host->stalk_on_up=TRUE;
                        else if(!strcmp(temp_ptr,"d") || !strcmp(temp_ptr,"down"))
                              temp_host->stalk_on_down=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unreachable"))
                              temp_host->stalk_on_unreachable=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_host->stalk_on_up=FALSE;
                              temp_host->stalk_on_down=FALSE;
                              temp_host->stalk_on_unreachable=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid stalking option '%s' in host definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_host->have_stalking_options=TRUE;
                    }
            else if(!strcmp(variable,"process_perf_data")){
                  temp_host->process_perf_data=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_process_perf_data=TRUE;
                    }
            else if(!strcmp(variable,"failure_prediction_enabled")){
                  temp_host->failure_prediction_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_failure_prediction_enabled=TRUE;
                    }
            else if(!strcmp(variable,"obsess_over_host")){
                  temp_host->obsess_over_host=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_obsess_over_host=TRUE;
                    }
            else if(!strcmp(variable,"retain_status_information")){
                  temp_host->retain_status_information=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_retain_status_information=TRUE;
                    }
            else if(!strcmp(variable,"retain_nonstatus_information")){
                  temp_host->retain_nonstatus_information=(atoi(value)>0)?TRUE:FALSE;
                  temp_host->have_retain_nonstatus_information=TRUE;
                    }
            else if(!strcmp(variable,"register"))
                  temp_host->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid host object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;

      case XODTEMPLATE_SERVICE:

            temp_service=(xodtemplate_service *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_service->template=strdup(value);
                  if(temp_service->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_service(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for service '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_service->_config_file),temp_service->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_service->name=strdup(value);
                  if(temp_service->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"hostgroup") || !strcmp(variable,"hostgroups") || !strcmp(variable,"hostgroup_name")){
                  temp_service->hostgroup_name=strdup(value);
                  if(temp_service->hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service hostgroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host") || !strcmp(variable,"hosts") || !strcmp(variable,"host_name")){
                  temp_service->host_name=strdup(value);
                  if(temp_service->host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service host.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"service_description") || !strcmp(variable,"description")){
                  temp_service->service_description=strdup(value);
                  if(temp_service->service_description==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service service_description.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"servicegroups")){
                  temp_service->servicegroups=strdup(value);
                  if(temp_service->servicegroups==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service servicegroups.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"check_command")){
                  temp_service->check_command=strdup(value);
                  if(temp_service->check_command==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service check_command.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"check_period")){
                  temp_service->check_period=strdup(value);
                  if(temp_service->check_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service check_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"event_handler")){
                  temp_service->event_handler=strdup(value);
                  if(temp_service->event_handler==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service event_handler.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"notification_period")){
                  temp_service->notification_period=strdup(value);
                  if(temp_service->notification_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service notification_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"contact_groups")){
                  temp_service->contact_groups=strdup(value);
                  if(temp_service->contact_groups==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service contact_groups.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"failure_prediction_options")){
                  temp_service->failure_prediction_options=strdup(value);
                  if(temp_service->failure_prediction_options==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for service failure_prediction_options.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"max_check_attempts")){
                  temp_service->max_check_attempts=atoi(value);
                  temp_service->have_max_check_attempts=TRUE;
                    }
            else if(!strcmp(variable,"normal_check_interval")){
                  temp_service->normal_check_interval=atoi(value);
                  temp_service->have_normal_check_interval=TRUE;
                    }
            else if(!strcmp(variable,"retry_check_interval")){
                  temp_service->retry_check_interval=atoi(value);
                  temp_service->have_retry_check_interval=TRUE;
                    }
            else if(!strcmp(variable,"active_checks_enabled")){
                  temp_service->active_checks_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_active_checks_enabled=TRUE;
                    }
            else if(!strcmp(variable,"passive_checks_enabled")){
                  temp_service->passive_checks_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_passive_checks_enabled=TRUE;
                    }
            else if(!strcmp(variable,"parallelize_check")){
                  temp_service->parallelize_check=atoi(value);
                  temp_service->have_parallelize_check=TRUE;
                    }
            else if(!strcmp(variable,"is_volatile")){
                  temp_service->is_volatile=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_is_volatile=TRUE;
                    }
            else if(!strcmp(variable,"obsess_over_service")){
                  temp_service->obsess_over_service=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_obsess_over_service=TRUE;
                    }
            else if(!strcmp(variable,"event_handler_enabled")){
                  temp_service->event_handler_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_event_handler_enabled=TRUE;
                    }
            else if(!strcmp(variable,"check_freshness")){
                  temp_service->check_freshness=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_check_freshness=TRUE;
                    }
            else if(!strcmp(variable,"freshness_threshold")){
                  temp_service->freshness_threshold=atoi(value);
                  temp_service->have_freshness_threshold=TRUE;
                    }
            else if(!strcmp(variable,"low_flap_threshold")){
                  temp_service->low_flap_threshold=strtod(value,NULL);
                  temp_service->have_low_flap_threshold=TRUE;
                    }
            else if(!strcmp(variable,"high_flap_threshold")){
                  temp_service->high_flap_threshold=strtod(value,NULL);
                  temp_service->have_high_flap_threshold=TRUE;
                    }
            else if(!strcmp(variable,"flap_detection_enabled")){
                  temp_service->flap_detection_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_flap_detection_enabled=TRUE;
                    }
            else if(!strcmp(variable,"notification_options")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unknown"))
                              temp_service->notify_on_unknown=TRUE;
                        else if(!strcmp(temp_ptr,"w") || !strcmp(temp_ptr,"warning"))
                              temp_service->notify_on_warning=TRUE;
                        else if(!strcmp(temp_ptr,"c") || !strcmp(temp_ptr,"critical"))
                              temp_service->notify_on_critical=TRUE;
                        else if(!strcmp(temp_ptr,"r") || !strcmp(temp_ptr,"recovery"))
                              temp_service->notify_on_recovery=TRUE;
                        else if(!strcmp(temp_ptr,"f") || !strcmp(temp_ptr,"flapping"))
                              temp_service->notify_on_flapping=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_service->notify_on_unknown=FALSE;
                              temp_service->notify_on_warning=FALSE;
                              temp_service->notify_on_critical=FALSE;
                              temp_service->notify_on_recovery=FALSE;
                              temp_service->notify_on_flapping=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid notification option '%s' in service definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_service->have_notification_options=TRUE;
                    }
            else if(!strcmp(variable,"notifications_enabled")){
                  temp_service->notifications_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_notifications_enabled=TRUE;
                    }
            else if(!strcmp(variable,"notification_interval")){
                  temp_service->notification_interval=atoi(value);
                  temp_service->have_notification_interval=TRUE;
                    }
            else if(!strcmp(variable,"stalking_options")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"o") || !strcmp(temp_ptr,"ok"))
                              temp_service->stalk_on_ok=TRUE;
                        else if(!strcmp(temp_ptr,"w") || !strcmp(temp_ptr,"warning"))
                              temp_service->stalk_on_warning=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unknown"))
                              temp_service->stalk_on_unknown=TRUE;
                        else if(!strcmp(temp_ptr,"c") || !strcmp(temp_ptr,"critical"))
                              temp_service->stalk_on_critical=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_service->stalk_on_ok=FALSE;
                              temp_service->stalk_on_warning=FALSE;
                              temp_service->stalk_on_unknown=FALSE;
                              temp_service->stalk_on_critical=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid stalking option '%s' in service definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_service->have_stalking_options=TRUE;
                    }
            else if(!strcmp(variable,"process_perf_data")){
                  temp_service->process_perf_data=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_process_perf_data=TRUE;
                    }
            else if(!strcmp(variable,"failure_prediction_enabled")){
                  temp_service->failure_prediction_enabled=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_failure_prediction_enabled=TRUE;
                    }
            else if(!strcmp(variable,"retain_status_information")){
                  temp_service->retain_status_information=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_retain_status_information=TRUE;
                    }
            else if(!strcmp(variable,"retain_nonstatus_information")){
                  temp_service->retain_nonstatus_information=(atoi(value)>0)?TRUE:FALSE;
                  temp_service->have_retain_nonstatus_information=TRUE;
                    }
            else if(!strcmp(variable,"register"))
                  temp_service->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid service object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;

      case XODTEMPLATE_HOSTDEPENDENCY:

            temp_hostdependency=(xodtemplate_hostdependency *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_hostdependency->template=strdup(value);
                  if(temp_hostdependency->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostdependency template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_hostdependency(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for host dependency '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_hostdependency->_config_file),temp_hostdependency->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_hostdependency->name=strdup(value);
                  if(temp_hostdependency->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostdependency name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"hostgroup") || !strcmp(variable,"hostgroups") || !strcmp(variable,"hostgroup_name")){
                  temp_hostdependency->hostgroup_name=strdup(value);
                  if(temp_hostdependency->hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostdependency hostgroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host") || !strcmp(variable,"host_name") || !strcmp(variable,"master_host") || !strcmp(variable,"master_host_name")){
                  temp_hostdependency->host_name=strdup(value);
                  if(temp_hostdependency->host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostdependency host.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"dependent_hostgroup") || !strcmp(variable,"dependent_hostgroups") || !strcmp(variable,"dependent_hostgroup_name")){
                  temp_hostdependency->dependent_hostgroup_name=strdup(value);
                  if(temp_hostdependency->dependent_hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostdependency dependent hostgroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"dependent_host") || !strcmp(variable,"dependent_host_name")){
                  temp_hostdependency->dependent_host_name=strdup(value);
                  if(temp_hostdependency->dependent_host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostdependency dependent host.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"inherits_parent")){
                  temp_hostdependency->inherits_parent=(atoi(value)>0)?TRUE:FALSE;
                  temp_hostdependency->have_inherits_parent=TRUE;
                    }
            else if(!strcmp(variable,"notification_failure_options") || !strcmp(variable,"notification_failure_criteria")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"o") || !strcmp(temp_ptr,"up"))
                              temp_hostdependency->fail_notify_on_up=TRUE;
                        else if(!strcmp(temp_ptr,"d") || !strcmp(temp_ptr,"down"))
                              temp_hostdependency->fail_notify_on_down=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unreachable"))
                              temp_hostdependency->fail_notify_on_unreachable=TRUE;
                        else if(!strcmp(temp_ptr,"p") || !strcmp(temp_ptr,"pending"))
                              temp_hostdependency->fail_notify_on_pending=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_hostdependency->fail_notify_on_up=FALSE;
                              temp_hostdependency->fail_notify_on_down=FALSE;
                              temp_hostdependency->fail_notify_on_unreachable=FALSE;
                              temp_hostdependency->fail_notify_on_pending=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid notification dependency option '%s' in hostdependency definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_hostdependency->have_notification_dependency_options=TRUE;
                    }
            else if(!strcmp(variable,"execution_failure_options") || !strcmp(variable,"execution_failure_criteria")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"o") || !strcmp(temp_ptr,"up"))
                              temp_hostdependency->fail_execute_on_up=TRUE;
                        else if(!strcmp(temp_ptr,"d") || !strcmp(temp_ptr,"down"))
                              temp_hostdependency->fail_execute_on_down=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unreachable"))
                              temp_hostdependency->fail_execute_on_unreachable=TRUE;
                        else if(!strcmp(temp_ptr,"p") || !strcmp(temp_ptr,"pending"))
                              temp_hostdependency->fail_execute_on_pending=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_hostdependency->fail_execute_on_up=FALSE;
                              temp_hostdependency->fail_execute_on_down=FALSE;
                              temp_hostdependency->fail_execute_on_unreachable=FALSE;
                              temp_hostdependency->fail_execute_on_pending=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid execution dependency option '%s' in hostdependency definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_hostdependency->have_execution_dependency_options=TRUE;
                    }
            else if(!strcmp(variable,"register"))
                  temp_hostdependency->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid hostdependency object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;

      
      case XODTEMPLATE_HOSTESCALATION:

            temp_hostescalation=(xodtemplate_hostescalation *)xodtemplate_current_object;

            if(!strcmp(variable,"use")){
                  temp_hostescalation->template=strdup(value);
                  if(temp_hostescalation->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostescalation template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_hostescalation(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for host escalation '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_hostescalation->_config_file),temp_hostescalation->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_hostescalation->name=strdup(value);
                  if(temp_hostescalation->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostescalation name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"hostgroup") || !strcmp(variable,"hostgroups") || !strcmp(variable,"hostgroup_name")){
                  temp_hostescalation->hostgroup_name=strdup(value);
                  if(temp_hostescalation->hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostescalation hostgroup.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host") || !strcmp(variable,"host_name")){
                  temp_hostescalation->host_name=strdup(value);
                  if(temp_hostescalation->host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostescalation host.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"contact_groups")){
                  temp_hostescalation->contact_groups=strdup(value);
                  if(temp_hostescalation->contact_groups==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostescalation contact_groups.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"first_notification")){
                  temp_hostescalation->first_notification=atoi(value);
                  temp_hostescalation->have_first_notification=TRUE;
                    }
            else if(!strcmp(variable,"last_notification")){
                  temp_hostescalation->last_notification=atoi(value);
                  temp_hostescalation->have_last_notification=TRUE;
                    }
            else if(!strcmp(variable,"notification_interval")){
                  temp_hostescalation->notification_interval=atoi(value);
                  temp_hostescalation->have_notification_interval=TRUE;
                    }
            else if(!strcmp(variable,"escalation_period")){
                  temp_hostescalation->escalation_period=strdup(value);
                  if(temp_hostescalation->escalation_period==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for hostescalation escalation_period.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"escalation_options")){
                  for(temp_ptr=strtok(value,", ");temp_ptr;temp_ptr=strtok(NULL,", ")){
                        if(!strcmp(temp_ptr,"d") || !strcmp(temp_ptr,"down"))
                              temp_hostescalation->escalate_on_down=TRUE;
                        else if(!strcmp(temp_ptr,"u") || !strcmp(temp_ptr,"unreachable"))
                              temp_hostescalation->escalate_on_unreachable=TRUE;
                        else if(!strcmp(temp_ptr,"r") || !strcmp(temp_ptr,"recovery"))
                              temp_hostescalation->escalate_on_recovery=TRUE;
                        else if(!strcmp(temp_ptr,"n") || !strcmp(temp_ptr,"none")){
                              temp_hostescalation->escalate_on_down=FALSE;
                              temp_hostescalation->escalate_on_unreachable=FALSE;
                              temp_hostescalation->escalate_on_recovery=FALSE;
                                }
                        else{
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid escalation option '%s' in hostescalation definition.\n",temp_ptr);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              return ERROR;
                                }
                          }
                  temp_hostescalation->have_escalation_options=TRUE;
                    }
            else if(!strcmp(variable,"register"))
                  temp_hostescalation->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid hostescalation object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;
      
      case XODTEMPLATE_HOSTEXTINFO:
            
            temp_hostextinfo=xodtemplate_hostextinfo_list;

            if(!strcmp(variable,"use")){
                  temp_hostextinfo->template=strdup(value);
                  if(temp_hostextinfo->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_hostextinfo(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for extended host info '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_hostextinfo->_config_file),temp_hostextinfo->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_hostextinfo->name=strdup(value);
                  if(temp_hostextinfo->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host_name")){
                  temp_hostextinfo->host_name=(char *)malloc(strlen(value)+1);
                  if(temp_hostextinfo->host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info host_name.\n");
#endif
                        return ERROR;
                          }
                  strcpy(temp_hostextinfo->host_name,value);
                    }
            else if(!strcmp(variable,"hostgroup") || !strcmp(variable,"hostgroup_name")){
                  temp_hostextinfo->hostgroup_name=strdup(value);
                  if(temp_hostextinfo->hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info hostgroup_name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"notes")){
                  temp_hostextinfo->notes=strdup(value);
                  if(temp_hostextinfo->notes==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info notes.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"notes_url")){
                  temp_hostextinfo->notes_url=strdup(value);
                  if(temp_hostextinfo->notes_url==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info notes_url.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"action_url")){
                  temp_hostextinfo->action_url=strdup(value);
                  if(temp_hostextinfo->action_url==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info action_url.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"icon_image")){
                  temp_hostextinfo->icon_image=strdup(value);
                  if(temp_hostextinfo->icon_image==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info icon_image.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"icon_image_alt")){
                  temp_hostextinfo->icon_image_alt=strdup(value);
                  if(temp_hostextinfo->icon_image_alt==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info icon_image_alt.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"vrml_image")){
                  temp_hostextinfo->vrml_image=strdup(value);
                  if(temp_hostextinfo->vrml_image==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info vrml_image.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"gd2_image")|| !strcmp(variable,"statusmap_image")){
                  temp_hostextinfo->statusmap_image=strdup(value);
                  if(temp_hostextinfo->statusmap_image==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended host info statusmap_image.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"2d_coords")){
                  temp_ptr=strtok(value,", ");
                  if(temp_ptr==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid 2d_coords value '%s' in extended host info definition.\n",temp_ptr);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                  temp_hostextinfo->x_2d=atoi(temp_ptr);
                  temp_ptr=strtok(NULL,", ");
                  if(temp_ptr==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid 2d_coords value '%s' in extended host info definition.\n",temp_ptr);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                  temp_hostextinfo->y_2d=atoi(temp_ptr);
                  temp_hostextinfo->have_2d_coords=TRUE;
                    }
            else if(!strcmp(variable,"3d_coords")){
                  temp_ptr=strtok(value,", ");
                  if(temp_ptr==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid 3d_coords value '%s' in extended host info definition.\n",temp_ptr);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                  temp_hostextinfo->x_3d=strtod(temp_ptr,NULL);
                  temp_ptr=strtok(NULL,", ");
                  if(temp_ptr==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid 3d_coords value '%s' in extended host info definition.\n",temp_ptr);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                  temp_hostextinfo->y_3d=strtod(temp_ptr,NULL);
                  temp_ptr=strtok(NULL,", ");
                  if(temp_ptr==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid 3d_coords value '%s' in extended host info definition.\n",temp_ptr);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                  temp_hostextinfo->z_3d=strtod(temp_ptr,NULL);
                  temp_hostextinfo->have_3d_coords=TRUE;
                    }
            else if(!strcmp(variable,"register"))
                  temp_hostextinfo->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid hostextinfo object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;
      
      case XODTEMPLATE_SERVICEEXTINFO:
            
            temp_serviceextinfo=xodtemplate_serviceextinfo_list;

            if(!strcmp(variable,"use")){
                  temp_serviceextinfo->template=strdup(value);
                  if(temp_serviceextinfo->template==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info template.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"name")){

#ifdef NSCORE
                  /* check for duplicates */
                  if(xodtemplate_find_serviceextinfo(value)!=NULL){
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Duplicate definition found for extended service info '%s' (config file '%s', starting on line %d)\n",value,xodtemplate_config_file_name(temp_serviceextinfo->_config_file),temp_serviceextinfo->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
                          }
#endif

                  temp_serviceextinfo->name=strdup(value);
                  if(temp_serviceextinfo->name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"host_name")){
                  temp_serviceextinfo->host_name=strdup(value);
                  if(temp_serviceextinfo->host_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info host_name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"hostgroup") || !strcmp(variable,"hostgroup_name")){
                  temp_serviceextinfo->hostgroup_name=strdup(value);
                  if(temp_serviceextinfo->hostgroup_name==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info hostgroup_name.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"service_description")){
                  temp_serviceextinfo->service_description=strdup(value);
                  if(temp_serviceextinfo->service_description==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info service_description.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"notes")){
                  temp_serviceextinfo->notes=strdup(value);
                  if(temp_serviceextinfo->notes==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info notes.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"notes_url")){
                  temp_serviceextinfo->notes_url=strdup(value);
                  if(temp_serviceextinfo->notes_url==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info notes_url.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"action_url")){
                  temp_serviceextinfo->action_url=strdup(value);
                  if(temp_serviceextinfo->action_url==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info action_url.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"icon_image")){
                  temp_serviceextinfo->icon_image=strdup(value);
                  if(temp_serviceextinfo->icon_image==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info icon_image.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"icon_image_alt")){
                  temp_serviceextinfo->icon_image_alt=strdup(value);
                  if(temp_serviceextinfo->icon_image_alt==NULL){
#ifdef DEBUG1
                        printf("Error: Could not allocate memory for extended service info icon_image_alt.\n");
#endif
                        return ERROR;
                          }
                    }
            else if(!strcmp(variable,"register"))
                  temp_serviceextinfo->register_object=(atoi(value)>0)?TRUE:FALSE;
            else{
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Invalid serviceextinfo object directive '%s'.\n",variable);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            break;

      default:
            return ERROR;
            break;
              }

      /* free memory */
      free(variable);
      free(value);

#ifdef DEBUG0
      printf("xodtemplate_add_object_property() end\n");
#endif

      return result;
        }



/* completes an object definition */
int xodtemplate_end_object_definition(int options){
      int result=OK;

#ifdef DEBUG0
      printf("xodtemplate_end_object_definition() start\n");
#endif

      xodtemplate_current_object=NULL;
      xodtemplate_current_object_type=XODTEMPLATE_NONE;

#ifdef DEBUG0
      printf("xodtemplate_end_object_definition() end\n");
#endif

      return result;
        }



/******************************************************************/
/***************** OBJECT DUPLICATION FUNCTIONS *******************/
/******************************************************************/

#ifdef NSCORE


/* duplicates service definitions */
int xodtemplate_duplicate_services(void){
      int result=OK;
      xodtemplate_service *temp_service;
      xodtemplate_hostlist *temp_hostlist;
      xodtemplate_hostlist *this_hostlist;
      char *host_name="";
      int first_item;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_duplicate_services() start\n");
#endif


      /****** DUPLICATE SERVICE DEFINITIONS WITH ONE OR MORE HOSTGROUP AND/OR HOST NAMES ******/
      for(temp_service=xodtemplate_service_list;temp_service!=NULL;temp_service=temp_service->next){

            /* skip service definitions without enough data */
            if(temp_service->hostgroup_name==NULL && temp_service->host_name==NULL)
                  continue;

            /* skip services that shouldn't be registered */
            if(temp_service->register_object==FALSE)
                  continue;

            /* get list of hosts */
            temp_hostlist=xodtemplate_expand_hostgroups_and_hosts(temp_service->hostgroup_name,temp_service->host_name);
            if(temp_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand hostgroups and/or hosts specified in service (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_service->_config_file),temp_service->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* add a copy of the service for every host in the hostgroup/host name list */
            first_item=TRUE;
            for(this_hostlist=temp_hostlist;this_hostlist!=NULL;this_hostlist=this_hostlist->next){

                  /* if this is the first duplication, use the existing entry */
                  if(first_item==TRUE){

                        free(temp_service->host_name);
                        temp_service->host_name=strdup(this_hostlist->host_name);
                        if(temp_service->host_name==NULL){
                              xodtemplate_free_hostlist(temp_hostlist);
                              return ERROR;
                                }

                        first_item=FALSE;
                        continue;
                          }

                  /* duplicate service definition */
                  result=xodtemplate_duplicate_service(temp_service,this_hostlist->host_name);

                  /* exit on error */
                  if(result==ERROR){
                        free(host_name);
                        return ERROR;
                            }
                    }

            /* free memory we used for host list */
            xodtemplate_free_hostlist(temp_hostlist);
              }

#ifdef DEBUG0
      printf("xodtemplate_duplicate_services() end\n");
#endif

      return OK;
        }



/* duplicates object definitions */
int xodtemplate_duplicate_objects(void){
      int result=OK;
      xodtemplate_hostescalation *temp_hostescalation;
      xodtemplate_serviceescalation *temp_serviceescalation;
      xodtemplate_hostdependency *temp_hostdependency;
      xodtemplate_servicedependency *temp_servicedependency;
      xodtemplate_hostlist *temp_hostlist;
      xodtemplate_hostlist *this_hostlist;
      xodtemplate_servicelist *temp_servicelist;
      xodtemplate_servicelist *this_servicelist;
      xodtemplate_hostlist *master_hostlist;
      xodtemplate_hostlist *dependent_hostlist;
      xodtemplate_hostextinfo *temp_hostextinfo;
      xodtemplate_serviceextinfo *temp_serviceextinfo;
      char *host_name="";
      int first_item;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_duplicate_objects() start\n");
#endif


      /*************************************/
      /* SERVICES ARE DUPLICATED ELSEWHERE */
      /*************************************/


      /****** DUPLICATE HOST ESCALATION DEFINITIONS WITH ONE OR MORE HOSTGROUP AND/OR HOST NAMES ******/
      for(temp_hostescalation=xodtemplate_hostescalation_list;temp_hostescalation!=NULL;temp_hostescalation=temp_hostescalation->next){

            /* skip host escalation definitions without enough data */
            if(temp_hostescalation->hostgroup_name==NULL && temp_hostescalation->host_name==NULL)
                  continue;

            /* get list of hosts */
            temp_hostlist=xodtemplate_expand_hostgroups_and_hosts(temp_hostescalation->hostgroup_name,temp_hostescalation->host_name);
            if(temp_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand hostgroups and/or hosts specified in host escalation (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_hostescalation->_config_file),temp_hostescalation->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* add a copy of the hostescalation for every host in the hostgroup/host name list */
            first_item=TRUE;
            for(this_hostlist=temp_hostlist;this_hostlist!=NULL;this_hostlist=this_hostlist->next){

                  /* if this is the first duplication, use the existing entry */
                  if(first_item==TRUE){

                        free(temp_hostescalation->host_name);
                        temp_hostescalation->host_name=strdup(this_hostlist->host_name);
                        if(temp_hostescalation->host_name==NULL){
                              xodtemplate_free_hostlist(temp_hostlist);
                              return ERROR;
                                }

                        first_item=FALSE;
                        continue;
                          }

                  /* duplicate hostescalation definition */
                  result=xodtemplate_duplicate_hostescalation(temp_hostescalation,this_hostlist->host_name);

                  /* exit on error */
                  if(result==ERROR){
                        free(host_name);
                        return ERROR;
                            }
                    }

            /* free memory we used for host list */
            xodtemplate_free_hostlist(temp_hostlist);
              }

      
      /****** DUPLICATE SERVICE ESCALATION DEFINITIONS WITH ONE OR MORE HOSTGROUP AND/OR HOST NAMES ******/
      for(temp_serviceescalation=xodtemplate_serviceescalation_list;temp_serviceescalation!=NULL;temp_serviceescalation=temp_serviceescalation->next){

            /* skip service escalation definitions without enough data */
            if(temp_serviceescalation->hostgroup_name==NULL && temp_serviceescalation->host_name==NULL)
                  continue;

            /* get list of hosts */
            temp_hostlist=xodtemplate_expand_hostgroups_and_hosts(temp_serviceescalation->hostgroup_name,temp_serviceescalation->host_name);
            if(temp_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand hostgroups and/or hosts specified in service escalation (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_serviceescalation->_config_file),temp_serviceescalation->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* duplicate service escalation entries */
            first_item=TRUE;
            for(this_hostlist=temp_hostlist;this_hostlist!=NULL;this_hostlist=this_hostlist->next){

                  /* if this is the first duplication,use the existing entry */
                  if(first_item==TRUE){

                        free(temp_serviceescalation->host_name);
                        temp_serviceescalation->host_name=strdup(this_hostlist->host_name);
                        if(temp_serviceescalation->host_name==NULL){
                              xodtemplate_free_hostlist(temp_hostlist);
                              return ERROR;
                                }

                        first_item=FALSE;
                        continue;
                          }

                  /* duplicate service escalation definition */
                  result=xodtemplate_duplicate_serviceescalation(temp_serviceescalation,this_hostlist->host_name,NULL);

                  /* exit on error */
                  if(result==ERROR){
                        xodtemplate_free_hostlist(temp_hostlist);
                        return ERROR;
                            }
                    }

            /* free memory we used for host list */
            xodtemplate_free_hostlist(temp_hostlist);
              }


      /****** DUPLICATE SERVICE ESCALATION DEFINITIONS WITH MULTIPLE DESCRIPTIONS ******/
      /* THIS MUST BE DONE AFTER DUPLICATING FOR MULTIPLE HOST NAMES (SEE ABOVE) */
      for(temp_serviceescalation=xodtemplate_serviceescalation_list;temp_serviceescalation!=NULL;temp_serviceescalation=temp_serviceescalation->next){

            /* skip serviceescalations without enough data */
            if(temp_serviceescalation->service_description==NULL || temp_serviceescalation->host_name==NULL)
                  continue;

            /* get list of services */
            temp_servicelist=xodtemplate_expand_servicegroups_and_services(NULL,temp_serviceescalation->host_name,temp_serviceescalation->service_description);
            if(temp_servicelist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand services specified in service escalation (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_serviceescalation->_config_file),temp_serviceescalation->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* duplicate service escalation entries */
            first_item=TRUE;
            for(this_servicelist=temp_servicelist;this_servicelist!=NULL;this_servicelist=this_servicelist->next){

                  /* if this is the first duplication, use the existing entry */
                  if(first_item==TRUE){

                        free(temp_serviceescalation->service_description);
                        temp_serviceescalation->service_description=strdup(this_servicelist->service_description);
                        if(temp_serviceescalation->service_description==NULL){
                              xodtemplate_free_servicelist(temp_servicelist);
                              return ERROR;
                                }

                        first_item=FALSE;
                        continue;
                          }

                  /* duplicate service escalation definition */
                  result=xodtemplate_duplicate_serviceescalation(temp_serviceescalation,temp_serviceescalation->host_name,this_servicelist->service_description);

                  /* exit on error */
                  if(result==ERROR){
                        xodtemplate_free_servicelist(temp_servicelist);
                        return ERROR;
                            }
                    }

            /* free memory we used for service list */
            xodtemplate_free_servicelist(temp_servicelist);
              }



      /****** DUPLICATE SERVICE ESCALATION DEFINITIONS WITH SERVICEGROUPS ******/
      /* THIS MUST BE DONE AFTER DUPLICATING FOR MULTIPLE HOST NAMES (SEE ABOVE) */
      for(temp_serviceescalation=xodtemplate_serviceescalation_list;temp_serviceescalation!=NULL;temp_serviceescalation=temp_serviceescalation->next){

            /* skip serviceescalations without enough data */
            if(temp_serviceescalation->servicegroup_name==NULL)
                  continue;

            /* get list of services */
            temp_servicelist=xodtemplate_expand_servicegroups_and_services(temp_serviceescalation->servicegroup_name,NULL,NULL);
            if(temp_servicelist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand servicegroups specified in service escalation (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_serviceescalation->_config_file),temp_serviceescalation->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* duplicate service escalation entries */
            first_item=TRUE;
            for(this_servicelist=temp_servicelist;this_servicelist!=NULL;this_servicelist=this_servicelist->next){

                  /* if this is the first duplication, use the existing entry if possible */
                  if(first_item==TRUE && temp_serviceescalation->host_name==NULL && temp_serviceescalation->service_description==NULL){

                        free(temp_serviceescalation->host_name);
                        temp_serviceescalation->host_name=strdup(this_servicelist->host_name);
                        free(temp_serviceescalation->service_description);
                        temp_serviceescalation->service_description=strdup(this_servicelist->service_description);
                        if(temp_serviceescalation->service_description==NULL){
                              xodtemplate_free_servicelist(temp_servicelist);
                              return ERROR;
                                }

                        first_item=FALSE;
                        continue;
                          }

                  /* duplicate service escalation definition */
                  result=xodtemplate_duplicate_serviceescalation(temp_serviceescalation,this_servicelist->host_name,this_servicelist->service_description);

                  /* exit on error */
                  if(result==ERROR){
                        xodtemplate_free_servicelist(temp_servicelist);
                        return ERROR;
                            }
                    }

            /* free memory we used for service list */
            xodtemplate_free_servicelist(temp_servicelist);
              }


      /****** DUPLICATE HOST DEPENDENCY DEFINITIONS WITH MULTIPLE HOSTGROUP AND/OR HOST NAMES (MASTER AND DEPENDENT) ******/
      for(temp_hostdependency=xodtemplate_hostdependency_list;temp_hostdependency!=NULL;temp_hostdependency=temp_hostdependency->next){
            
            /* skip host dependencies without enough data */
            if(temp_hostdependency->hostgroup_name==NULL && temp_hostdependency->dependent_hostgroup_name==NULL && temp_hostdependency->host_name==NULL && temp_hostdependency->dependent_host_name==NULL)
                  continue;

            /* get list of master host names */
            master_hostlist=xodtemplate_expand_hostgroups_and_hosts(temp_hostdependency->hostgroup_name,temp_hostdependency->host_name);
            if(master_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand master hostgroups and/or hosts specified in host dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_hostdependency->_config_file),temp_hostdependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* get list of dependent host names */
            dependent_hostlist=xodtemplate_expand_hostgroups_and_hosts(temp_hostdependency->dependent_hostgroup_name,temp_hostdependency->dependent_host_name);
            if(dependent_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand dependent hostgroups and/or hosts specified in host dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_hostdependency->_config_file),temp_hostdependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* duplicate the dependency definitions */
            first_item=TRUE;
            for(temp_hostlist=master_hostlist;temp_hostlist!=NULL;temp_hostlist=temp_hostlist->next){

                  for(this_hostlist=dependent_hostlist;this_hostlist!=NULL;this_hostlist=this_hostlist->next){

                        /* existing definition gets first names */
                        if(first_item==TRUE){
                              free(temp_hostdependency->host_name);
                              free(temp_hostdependency->dependent_host_name);
                              temp_hostdependency->host_name=strdup(temp_hostlist->host_name);
                              temp_hostdependency->dependent_host_name=strdup(this_hostlist->host_name);
                              first_item=FALSE;
                              continue;
                                }
                        else
                              result=xodtemplate_duplicate_hostdependency(temp_hostdependency,temp_hostlist->host_name,this_hostlist->host_name);

                        /* exit on error */
                        if(result==ERROR)
                              return ERROR;
                          }
                    }

            /* free memory used to store host lists */
            xodtemplate_free_hostlist(master_hostlist);
            xodtemplate_free_hostlist(dependent_hostlist);
              }


      /****** DUPLICATE SERVICE DEPENDENCY DEFINITIONS WITH MULTIPLE HOSTGROUP AND/OR HOST NAMES (MASTER AND DEPENDENT) ******/
      for(temp_servicedependency=xodtemplate_servicedependency_list;temp_servicedependency!=NULL;temp_servicedependency=temp_servicedependency->next){

            /* ADDED 11/16/07 */
            /* skip templates */
            if(temp_servicedependency->register_object==0)
                  continue;

            /* skip service dependencies without enough data */
            if(temp_servicedependency->hostgroup_name==NULL && temp_servicedependency->dependent_hostgroup_name==NULL && temp_servicedependency->host_name==NULL && temp_servicedependency->dependent_host_name==NULL)
                  continue;

            /* get list of master host names */
            master_hostlist=xodtemplate_expand_hostgroups_and_hosts(temp_servicedependency->hostgroup_name,temp_servicedependency->host_name);
            if(master_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand master hostgroups and/or hosts specified in service dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_servicedependency->_config_file),temp_servicedependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* get list of dependent host names */
            dependent_hostlist=xodtemplate_expand_hostgroups_and_hosts(temp_servicedependency->dependent_hostgroup_name,temp_servicedependency->dependent_host_name);
            if(dependent_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand dependent hostgroups and/or hosts specified in service dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_servicedependency->_config_file),temp_servicedependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* duplicate the dependency definitions */
            first_item=TRUE;
            for(temp_hostlist=master_hostlist;temp_hostlist!=NULL;temp_hostlist=temp_hostlist->next){

                  for(this_hostlist=dependent_hostlist;this_hostlist!=NULL;this_hostlist=this_hostlist->next){

                        /* existing definition gets first names */
                        if(first_item==TRUE){
                              free(temp_servicedependency->host_name);
                              free(temp_servicedependency->dependent_host_name);
                              temp_servicedependency->host_name=strdup(temp_hostlist->host_name);
                              temp_servicedependency->dependent_host_name=strdup(this_hostlist->host_name);
                              first_item=FALSE;
                              continue;
                                }
                        else
                              result=xodtemplate_duplicate_servicedependency(temp_servicedependency,temp_hostlist->host_name,temp_servicedependency->service_description,this_hostlist->host_name,temp_servicedependency->dependent_service_description);

                        /* exit on error */
                        if(result==ERROR)
                              return ERROR;
                          }
                    }

            /* free memory used to store host lists */
            xodtemplate_free_hostlist(master_hostlist);
            xodtemplate_free_hostlist(dependent_hostlist);
              }


      /****** DUPLICATE SERVICE DEPENDENCY DEFINITIONS WITH MULTIPLE MASTER DESCRIPTIONS ******/
      /* THIS MUST BE DONE AFTER DUPLICATING FOR MULTIPLE HOST NAMES (SEE ABOVE) */
      for(temp_servicedependency=xodtemplate_servicedependency_list;temp_servicedependency!=NULL;temp_servicedependency=temp_servicedependency->next){

            /* skip servicedependencies without enough data */
            if(temp_servicedependency->service_description==NULL || temp_servicedependency->host_name==NULL)
                  continue;

            /* get list of services */
            temp_servicelist=xodtemplate_expand_servicegroups_and_services(temp_servicedependency->servicegroup_name,temp_servicedependency->host_name,temp_servicedependency->service_description);
            if(temp_servicelist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand services specified in service dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_servicedependency->_config_file),temp_servicedependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* duplicate service escalation entries */
            first_item=TRUE;
            for(this_servicelist=temp_servicelist;this_servicelist!=NULL;this_servicelist=this_servicelist->next){

                  /* if this is the first duplication, use the existing entry */
                  if(first_item==TRUE){

                        free(temp_servicedependency->service_description);
                        temp_servicedependency->service_description=strdup(this_servicelist->service_description);
                        if(temp_servicedependency->service_description==NULL){
                              xodtemplate_free_servicelist(temp_servicelist);
                              return ERROR;
                                }

                        first_item=FALSE;
                        continue;
                          }

                  /* duplicate service escalation definition */
                  result=xodtemplate_duplicate_servicedependency(temp_servicedependency,temp_servicedependency->host_name,this_servicelist->service_description,temp_servicedependency->dependent_host_name,temp_servicedependency->dependent_service_description);

                  /* exit on error */
                  if(result==ERROR){
                        xodtemplate_free_servicelist(temp_servicelist);
                        return ERROR;
                            }
                    }

            /* free memory we used for service list */
            xodtemplate_free_servicelist(temp_servicelist);
              }


      /****** DUPLICATE SERVICE DEPENDENCY DEFINITIONS WITH MULTIPLE DEPENDENCY DESCRIPTIONS ******/
      /* THIS MUST BE DONE AFTER DUPLICATING FOR MULTIPLE HOST NAMES (SEE ABOVE) */
      for(temp_servicedependency=xodtemplate_servicedependency_list;temp_servicedependency!=NULL;temp_servicedependency=temp_servicedependency->next){

            /* skip servicedependencies without enough data */
            if(temp_servicedependency->dependent_service_description==NULL || temp_servicedependency->dependent_host_name==NULL)
                  continue;

            /* get list of services */
            temp_servicelist=xodtemplate_expand_servicegroups_and_services(temp_servicedependency->dependent_servicegroup_name,temp_servicedependency->dependent_host_name,temp_servicedependency->dependent_service_description);
            if(temp_servicelist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand services specified in service dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_servicedependency->_config_file),temp_servicedependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* duplicate service escalation entries */
            first_item=TRUE;
            for(this_servicelist=temp_servicelist;this_servicelist!=NULL;this_servicelist=this_servicelist->next){

                  /* if this is the first duplication, use the existing entry */
                  if(first_item==TRUE){

                        free(temp_servicedependency->dependent_service_description);
                        temp_servicedependency->dependent_service_description=strdup(this_servicelist->service_description);
                        if(temp_servicedependency->dependent_service_description==NULL){
                              xodtemplate_free_servicelist(temp_servicelist);
                              return ERROR;
                                }

                        first_item=FALSE;
                        continue;
                          }

                  /* duplicate service escalation definition */
                  result=xodtemplate_duplicate_servicedependency(temp_servicedependency,temp_servicedependency->host_name,temp_servicedependency->service_description,temp_servicedependency->dependent_host_name,this_servicelist->service_description);

                  /* exit on error */
                  if(result==ERROR){
                        xodtemplate_free_servicelist(temp_servicelist);
                        return ERROR;
                            }
                    }

            /* free memory we used for service list */
            xodtemplate_free_servicelist(temp_servicelist);
              }


      /****** DUPLICATE HOSTEXTINFO DEFINITIONS WITH ONE OR MORE HOSTGROUP AND/OR HOST NAMES ******/
      for(temp_hostextinfo=xodtemplate_hostextinfo_list;temp_hostextinfo!=NULL;temp_hostextinfo=temp_hostextinfo->next){

            /* skip definitions without enough data */
            if(temp_hostextinfo->hostgroup_name==NULL && temp_hostextinfo->host_name==NULL)
                  continue;

            /* get list of hosts */
            temp_hostlist=xodtemplate_expand_hostgroups_and_hosts(temp_hostextinfo->hostgroup_name,temp_hostextinfo->host_name);
            if(temp_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand hostgroups and/or hosts specified in extended host info (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_hostextinfo->_config_file),temp_hostextinfo->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* add a copy of the definition for every host in the hostgroup/host name list */
            first_item=TRUE;
            for(this_hostlist=temp_hostlist;this_hostlist!=NULL;this_hostlist=this_hostlist->next){

                  /* if this is the first duplication, use the existing entry */
                  if(first_item==TRUE){

                        free(temp_hostextinfo->host_name);
                        temp_hostextinfo->host_name=strdup(this_hostlist->host_name);
                        if(temp_hostextinfo->host_name==NULL){
                              xodtemplate_free_hostlist(temp_hostlist);
                              return ERROR;
                                }
                        first_item=FALSE;
                        continue;
                          }

                  /* duplicate hostextinfo definition */
                  result=xodtemplate_duplicate_hostextinfo(temp_hostextinfo,this_hostlist->host_name);

                  /* exit on error */
                  if(result==ERROR){
                        xodtemplate_free_hostlist(temp_hostlist);
                        return ERROR;
                          }
                    }

            /* free memory we used for host list */
            xodtemplate_free_hostlist(temp_hostlist);
              }


      /****** DUPLICATE SERVICEEXTINFO DEFINITIONS WITH ONE OR MORE HOSTGROUP AND/OR HOST NAMES ******/
      for(temp_serviceextinfo=xodtemplate_serviceextinfo_list;temp_serviceextinfo!=NULL;temp_serviceextinfo=temp_serviceextinfo->next){

            /* skip definitions without enough data */
            if(temp_serviceextinfo->hostgroup_name==NULL && temp_serviceextinfo->host_name==NULL)
                  continue;

            /* get list of hosts */
            temp_hostlist=xodtemplate_expand_hostgroups_and_hosts(temp_serviceextinfo->hostgroup_name,temp_serviceextinfo->host_name);
            if(temp_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand hostgroups and/or hosts specified in extended service info (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_serviceextinfo->_config_file),temp_serviceextinfo->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }

            /* add a copy of the definition for every host in the hostgroup/host name list */
            first_item=TRUE;
            for(this_hostlist=temp_hostlist;this_hostlist!=NULL;this_hostlist=this_hostlist->next){

                  /* existing definition gets first host name */
                  if(first_item==TRUE){
                        free(temp_serviceextinfo->host_name);
                        temp_serviceextinfo->host_name=strdup(this_hostlist->host_name);
                        if(temp_serviceextinfo->host_name==NULL){
                              xodtemplate_free_hostlist(temp_hostlist);
                              return ERROR;
                                }
                        first_item=FALSE;
                        continue;
                          }

                  /* duplicate serviceextinfo definition */
                  result=xodtemplate_duplicate_serviceextinfo(temp_serviceextinfo,this_hostlist->host_name);

                  /* exit on error */
                  if(result==ERROR){
                        xodtemplate_free_hostlist(temp_hostlist);
                        return ERROR;
                          }
                    }

            /* free memory we used for host list */
            xodtemplate_free_hostlist(temp_hostlist);
              }

#ifdef DEBUG0
      printf("xodtemplate_duplicate_objects() end\n");
#endif

      return OK;
        }



/* duplicates a service definition (with a new host name) */
int xodtemplate_duplicate_service(xodtemplate_service *temp_service, char *host_name){
      xodtemplate_service *new_service;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_service() start\n");
#endif

      /* allocate memory for a new service definition */
      new_service=(xodtemplate_service *)malloc(sizeof(xodtemplate_service));
      if(new_service==NULL){
#ifdef DEBUG1
            printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
            return ERROR;
              }

      /* defaults */
      new_service->template=NULL;
      new_service->name=NULL;
      new_service->hostgroup_name=NULL;
      new_service->host_name=NULL;
      new_service->service_description=NULL;
      new_service->servicegroups=NULL;
      new_service->check_command=NULL;
      new_service->check_period=NULL;
      new_service->event_handler=NULL;
      new_service->notification_period=NULL;
      new_service->contact_groups=NULL;
      new_service->failure_prediction_options=NULL;

      /* make sure hostgroup member in new service definition is NULL */
      new_service->hostgroup_name=NULL;

      new_service->max_check_attempts=temp_service->max_check_attempts;
      new_service->have_max_check_attempts=temp_service->have_max_check_attempts;
      new_service->normal_check_interval=temp_service->normal_check_interval;
      new_service->have_normal_check_interval=temp_service->have_normal_check_interval;
      new_service->retry_check_interval=temp_service->retry_check_interval;
      new_service->have_retry_check_interval=temp_service->have_retry_check_interval;
      new_service->active_checks_enabled=temp_service->active_checks_enabled;
      new_service->have_active_checks_enabled=temp_service->have_active_checks_enabled;
      new_service->passive_checks_enabled=temp_service->passive_checks_enabled;
      new_service->have_passive_checks_enabled=temp_service->have_passive_checks_enabled;
      new_service->parallelize_check=temp_service->parallelize_check;
      new_service->have_parallelize_check=temp_service->have_parallelize_check;
      new_service->is_volatile=temp_service->is_volatile;
      new_service->have_is_volatile=temp_service->have_is_volatile;
      new_service->obsess_over_service=temp_service->obsess_over_service;
      new_service->have_obsess_over_service=temp_service->have_obsess_over_service;
      new_service->event_handler_enabled=temp_service->event_handler_enabled;
      new_service->have_event_handler_enabled=temp_service->have_event_handler_enabled;
      new_service->check_freshness=temp_service->check_freshness;
      new_service->have_check_freshness=temp_service->have_check_freshness;
      new_service->freshness_threshold=temp_service->freshness_threshold;
      new_service->have_freshness_threshold=temp_service->have_freshness_threshold;
      new_service->flap_detection_enabled=temp_service->flap_detection_enabled;
      new_service->have_flap_detection_enabled=temp_service->have_flap_detection_enabled;
      new_service->low_flap_threshold=temp_service->low_flap_threshold;
      new_service->have_low_flap_threshold=temp_service->have_low_flap_threshold;
      new_service->high_flap_threshold=temp_service->high_flap_threshold;
      new_service->have_high_flap_threshold=temp_service->have_high_flap_threshold;
      new_service->notify_on_unknown=temp_service->notify_on_unknown;
      new_service->notify_on_warning=temp_service->notify_on_warning;
      new_service->notify_on_critical=temp_service->notify_on_critical;
      new_service->notify_on_recovery=temp_service->notify_on_recovery;
      new_service->notify_on_flapping=temp_service->notify_on_flapping;
      new_service->have_notification_options=temp_service->have_notification_options;
      new_service->notifications_enabled=temp_service->notifications_enabled;
      new_service->have_notifications_enabled=temp_service->have_notifications_enabled;
      new_service->notification_interval=temp_service->notification_interval;
      new_service->have_notification_interval=temp_service->have_notification_interval;
      new_service->stalk_on_ok=temp_service->stalk_on_ok;
      new_service->stalk_on_unknown=temp_service->stalk_on_unknown;
      new_service->stalk_on_warning=temp_service->stalk_on_warning;
      new_service->stalk_on_critical=temp_service->stalk_on_critical;
      new_service->have_stalking_options=temp_service->have_stalking_options;
      new_service->process_perf_data=temp_service->process_perf_data;
      new_service->have_process_perf_data=temp_service->have_process_perf_data;
      new_service->failure_prediction_enabled=temp_service->failure_prediction_enabled;
      new_service->have_failure_prediction_enabled=temp_service->have_failure_prediction_enabled;
      new_service->retain_status_information=temp_service->retain_status_information;
      new_service->have_retain_status_information=temp_service->have_retain_status_information;
      new_service->retain_nonstatus_information=temp_service->retain_nonstatus_information;
      new_service->have_retain_nonstatus_information=temp_service->have_retain_nonstatus_information;

      new_service->has_been_resolved=temp_service->has_been_resolved;
      new_service->register_object=temp_service->register_object;
      new_service->_config_file=temp_service->_config_file;
      new_service->_start_line=temp_service->_start_line;

      /* allocate memory for and copy string members of service definition (host name provided, DO NOT duplicate hostgroup member!)*/
      if(temp_service->host_name!=NULL){
            new_service->host_name=strdup(host_name);
            if(new_service->host_name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->template!=NULL){
            new_service->template=strdup(temp_service->template);
            if(new_service->template==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->name!=NULL){
            new_service->name=strdup(temp_service->name);
            if(new_service->name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service->template);
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->service_description!=NULL){
            new_service->service_description=strdup(temp_service->service_description);
            if(new_service->service_description==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service->template);
                  free(new_service->name);
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->servicegroups!=NULL){
            new_service->servicegroups=strdup(temp_service->servicegroups);
            if(new_service->servicegroups==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service->template);
                  free(new_service->name);
                  free(new_service->service_description);
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->check_command!=NULL){
            new_service->check_command=strdup(temp_service->check_command);
            if(new_service->check_command==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service->template);
                  free(new_service->name);
                  free(new_service->service_description);
                  free(new_service->servicegroups);
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->check_period!=NULL){
            new_service->check_period=strdup(temp_service->check_period);
            if(new_service->check_period==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service->template);
                  free(new_service->name);
                  free(new_service->service_description);
                  free(new_service->check_command);
                  free(new_service->servicegroups);
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->event_handler!=NULL){
            new_service->event_handler=strdup(temp_service->event_handler);
            if(new_service->event_handler==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service->template);
                  free(new_service->name);
                  free(new_service->service_description);
                  free(new_service->servicegroups);
                  free(new_service->check_command);
                  free(new_service->check_period);
                  free(new_service->servicegroups);
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->notification_period!=NULL){
            new_service->notification_period=strdup(temp_service->notification_period);
            if(new_service->notification_period==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service->template);
                  free(new_service->name);
                  free(new_service->service_description);
                  free(new_service->servicegroups);
                  free(new_service->check_command);
                  free(new_service->check_period);
                  free(new_service->event_handler);
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->contact_groups!=NULL){
            new_service->contact_groups=strdup(temp_service->contact_groups);
            if(new_service->contact_groups==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service->template);
                  free(new_service->name);
                  free(new_service->service_description);
                  free(new_service->servicegroups);
                  free(new_service->check_command);
                  free(new_service->check_period);
                  free(new_service->event_handler);
                  free(new_service->notification_period);
                  free(new_service);
                  return ERROR;
                    }
              } 
      if(temp_service->failure_prediction_options!=NULL){
            new_service->failure_prediction_options=strdup(temp_service->failure_prediction_options);
            if(new_service->failure_prediction_options==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service.\n");
#endif
                  free(new_service->host_name);
                  free(new_service->template);
                  free(new_service->name);
                  free(new_service->service_description);
                  free(new_service->servicegroups);
                  free(new_service->check_command);
                  free(new_service->check_period);
                  free(new_service->event_handler);
                  free(new_service->notification_period);
                  free(new_service->contact_groups);
                  free(new_service);
                  return ERROR;
                    }
              } 

      /* add new service to head of list in memory */
      new_service->next=xodtemplate_service_list;
      xodtemplate_service_list=new_service;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_service() end\n");
#endif

      return OK;
        }




/* duplicates a host escalation definition (with a new host name) */
int xodtemplate_duplicate_hostescalation(xodtemplate_hostescalation *temp_hostescalation, char *host_name){
      xodtemplate_hostescalation *new_hostescalation;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_hostescalation() start\n");
#endif

      /* allocate memory for a new host escalation definition */
      new_hostescalation=(xodtemplate_hostescalation *)malloc(sizeof(xodtemplate_hostescalation));
      if(new_hostescalation==NULL){
#ifdef DEBUG1
            printf("Error: Could not allocate memory for duplicate definition of host escalation.\n");
#endif
            return ERROR;
              }

      /* defaults */
      new_hostescalation->template=NULL;
      new_hostescalation->name=NULL;
      new_hostescalation->hostgroup_name=NULL;
      new_hostescalation->host_name=NULL;
      new_hostescalation->contact_groups=NULL;
      new_hostescalation->escalation_period=NULL;

      new_hostescalation->has_been_resolved=temp_hostescalation->has_been_resolved;
      new_hostescalation->register_object=temp_hostescalation->register_object;
      new_hostescalation->_config_file=temp_hostescalation->_config_file;
      new_hostescalation->_start_line=temp_hostescalation->_start_line;

      new_hostescalation->first_notification=temp_hostescalation->first_notification;
      new_hostescalation->last_notification=temp_hostescalation->last_notification;
      new_hostescalation->have_first_notification=temp_hostescalation->have_first_notification;
      new_hostescalation->have_last_notification=temp_hostescalation->have_last_notification;
      new_hostescalation->notification_interval=temp_hostescalation->notification_interval;
      new_hostescalation->have_notification_interval=temp_hostescalation->have_notification_interval;
      new_hostescalation->escalate_on_down=temp_hostescalation->escalate_on_down;
      new_hostescalation->escalate_on_unreachable=temp_hostescalation->escalate_on_unreachable;
      new_hostescalation->escalate_on_recovery=temp_hostescalation->escalate_on_recovery;
      new_hostescalation->have_escalation_options=temp_hostescalation->have_escalation_options;
      

      /* allocate memory for and copy string members of hostescalation definition */
      if(temp_hostescalation->host_name!=NULL){
            new_hostescalation->host_name=strdup(host_name);
            if(new_hostescalation->host_name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of host escalation.\n");
#endif
                  free(new_hostescalation);
                  return ERROR;
                    }
              } 
      if(temp_hostescalation->template!=NULL){
            new_hostescalation->template=strdup(temp_hostescalation->template);
            if(new_hostescalation->template==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of host escalation.\n");
#endif
                  free(new_hostescalation->host_name);
                  free(new_hostescalation);
                  return ERROR;
                    }
              } 
      if(temp_hostescalation->name!=NULL){
            new_hostescalation->name=strdup(temp_hostescalation->name);
            if(new_hostescalation->name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of host escalation.\n");
#endif
                  free(new_hostescalation->host_name);
                  free(new_hostescalation->template);
                  free(new_hostescalation);
                  return ERROR;
                    }
              } 
      if(temp_hostescalation->contact_groups!=NULL){
            new_hostescalation->contact_groups=strdup(temp_hostescalation->contact_groups);
            if(new_hostescalation->contact_groups==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of host escalation.\n");
#endif
                  free(new_hostescalation->host_name);
                  free(new_hostescalation->template);
                  free(new_hostescalation->name);
                  free(new_hostescalation);
                  return ERROR;
                    }
              } 

      if(temp_hostescalation->escalation_period!=NULL){
            new_hostescalation->escalation_period=strdup(temp_hostescalation->escalation_period);
            if(new_hostescalation->escalation_period==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of host escalation.\n");
#endif
                  free(new_hostescalation->contact_groups);
                  free(new_hostescalation->host_name);
                  free(new_hostescalation->template);
                  free(new_hostescalation->name);
                  free(new_hostescalation);
                  return ERROR;
                    }
              } 

      /* add new hostescalation to head of list in memory */
      new_hostescalation->next=xodtemplate_hostescalation_list;
      xodtemplate_hostescalation_list=new_hostescalation;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_hostescalation() end\n");
#endif

      return OK;
        }



/* duplicates a service escalation definition (with a new host name and/or service description) */
int xodtemplate_duplicate_serviceescalation(xodtemplate_serviceescalation *temp_serviceescalation, char *host_name, char *svc_description){
      xodtemplate_serviceescalation *new_serviceescalation;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_serviceescalation() start\n");
#endif

      /* allocate memory for a new service escalation definition */
      new_serviceescalation=(xodtemplate_serviceescalation *)malloc(sizeof(xodtemplate_serviceescalation));
      if(new_serviceescalation==NULL){
#ifdef DEBUG1
            printf("Error: Could not allocate memory for duplicate definition of service escalation.\n");
#endif
            return ERROR;
              }

      /* defaults */
      new_serviceescalation->template=NULL;
      new_serviceescalation->name=NULL;
      new_serviceescalation->servicegroup_name=NULL;
      new_serviceescalation->hostgroup_name=NULL;
      new_serviceescalation->host_name=NULL;
      new_serviceescalation->service_description=NULL;
      new_serviceescalation->contact_groups=NULL;
      new_serviceescalation->escalation_period=NULL;

      new_serviceescalation->has_been_resolved=temp_serviceescalation->has_been_resolved;
      new_serviceescalation->register_object=temp_serviceescalation->register_object;
      new_serviceescalation->_config_file=temp_serviceescalation->_config_file;
      new_serviceescalation->_start_line=temp_serviceescalation->_start_line;

      new_serviceescalation->first_notification=temp_serviceescalation->first_notification;
      new_serviceescalation->last_notification=temp_serviceescalation->last_notification;
      new_serviceescalation->have_first_notification=temp_serviceescalation->have_first_notification;
      new_serviceescalation->have_last_notification=temp_serviceescalation->have_last_notification;
      new_serviceescalation->notification_interval=temp_serviceescalation->notification_interval;
      new_serviceescalation->have_notification_interval=temp_serviceescalation->have_notification_interval;
      new_serviceescalation->escalate_on_warning=temp_serviceescalation->escalate_on_warning;
      new_serviceescalation->escalate_on_unknown=temp_serviceescalation->escalate_on_unknown;
      new_serviceescalation->escalate_on_critical=temp_serviceescalation->escalate_on_critical;
      new_serviceescalation->escalate_on_recovery=temp_serviceescalation->escalate_on_recovery;
      new_serviceescalation->have_escalation_options=temp_serviceescalation->have_escalation_options;
      

      /* allocate memory for and copy string members of serviceescalation definition */
      if(host_name!=NULL){
            new_serviceescalation->host_name=strdup(host_name);
            if(new_serviceescalation->host_name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service escalation.\n");
#endif
                  free(new_serviceescalation);
                  return ERROR;
                    }
              } 
      else if(temp_serviceescalation->host_name!=NULL){
            new_serviceescalation->host_name=strdup(temp_serviceescalation->host_name);
            if(new_serviceescalation->host_name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service escalation.\n");
#endif
                  free(new_serviceescalation);
                  return ERROR;
                    }
              } 
      if(temp_serviceescalation->template!=NULL){
            new_serviceescalation->template=strdup(temp_serviceescalation->template);
            if(new_serviceescalation->template==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service escalation.\n");
#endif
                  free(new_serviceescalation->host_name);
                  free(new_serviceescalation);
                  return ERROR;
                    }
              } 
      if(temp_serviceescalation->name!=NULL){
            new_serviceescalation->name=strdup(temp_serviceescalation->name);
            if(new_serviceescalation->name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service escalation.\n");
#endif
                  free(new_serviceescalation->host_name);
                  free(new_serviceescalation->template);
                  free(new_serviceescalation);
                  return ERROR;
                    }
              } 
      if(svc_description!=NULL){
            new_serviceescalation->service_description=strdup(svc_description);
            if(new_serviceescalation->service_description==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service escalation.\n");
#endif
                  free(new_serviceescalation->host_name);
                  free(new_serviceescalation->template);
                  free(new_serviceescalation->name);
                  free(new_serviceescalation);
                  return ERROR;
                    }
              } 
      else if(temp_serviceescalation->service_description!=NULL){
            new_serviceescalation->service_description=strdup(temp_serviceescalation->service_description);
            if(new_serviceescalation->service_description==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service escalation.\n");
#endif
                  free(new_serviceescalation->host_name);
                  free(new_serviceescalation->template);
                  free(new_serviceescalation->name);
                  free(new_serviceescalation);
                  return ERROR;
                    }
              } 
      if(temp_serviceescalation->contact_groups!=NULL){
            new_serviceescalation->contact_groups=strdup(temp_serviceescalation->contact_groups);
            if(new_serviceescalation->contact_groups==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service escalation.\n");
#endif
                  free(new_serviceescalation->service_description);
                  free(new_serviceescalation->host_name);
                  free(new_serviceescalation->template);
                  free(new_serviceescalation->name);
                  free(new_serviceescalation);
                  return ERROR;
                    }
              } 

      if(temp_serviceescalation->escalation_period!=NULL){
            new_serviceescalation->escalation_period=strdup(temp_serviceescalation->escalation_period);
            if(new_serviceescalation->escalation_period==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service escalation.\n");
#endif
                  free(new_serviceescalation->contact_groups);
                  free(new_serviceescalation->service_description);
                  free(new_serviceescalation->host_name);
                  free(new_serviceescalation->template);
                  free(new_serviceescalation->name);
                  free(new_serviceescalation);
                  return ERROR;
                    }
              } 

      /* add new serviceescalation to head of list in memory */
      new_serviceescalation->next=xodtemplate_serviceescalation_list;
      xodtemplate_serviceescalation_list=new_serviceescalation;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_serviceescalation() end\n");
#endif

      return OK;
        }



/* duplicates a host dependency definition (with master and dependent host names) */
int xodtemplate_duplicate_hostdependency(xodtemplate_hostdependency *temp_hostdependency, char *master_host_name, char *dependent_host_name){
      xodtemplate_hostdependency *new_hostdependency;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_hostdependency() start\n");
#endif

      /* allocate memory for a new host dependency definition */
      new_hostdependency=(xodtemplate_hostdependency *)malloc(sizeof(xodtemplate_hostdependency));
      if(new_hostdependency==NULL){
#ifdef DEBUG1
            printf("Error: Could not allocate memory for duplicate definition of host dependency.\n");
#endif
            return ERROR;
              }

      /* defaults */
      new_hostdependency->template=NULL;
      new_hostdependency->name=NULL;
      new_hostdependency->hostgroup_name=NULL;
      new_hostdependency->dependent_hostgroup_name=NULL;
      new_hostdependency->host_name=NULL;
      new_hostdependency->dependent_host_name=NULL;

      new_hostdependency->has_been_resolved=temp_hostdependency->has_been_resolved;
      new_hostdependency->register_object=temp_hostdependency->register_object;
      new_hostdependency->_config_file=temp_hostdependency->_config_file;
      new_hostdependency->_start_line=temp_hostdependency->_start_line;

      new_hostdependency->fail_notify_on_up=temp_hostdependency->fail_notify_on_up;
      new_hostdependency->fail_notify_on_down=temp_hostdependency->fail_notify_on_down;
      new_hostdependency->fail_notify_on_unreachable=temp_hostdependency->fail_notify_on_unreachable;
      new_hostdependency->fail_notify_on_pending=temp_hostdependency->fail_notify_on_pending;
      new_hostdependency->have_notification_dependency_options=temp_hostdependency->have_notification_dependency_options;
      new_hostdependency->fail_execute_on_up=temp_hostdependency->fail_execute_on_up;
      new_hostdependency->fail_execute_on_down=temp_hostdependency->fail_execute_on_down;
      new_hostdependency->fail_execute_on_unreachable=temp_hostdependency->fail_execute_on_unreachable;
      new_hostdependency->fail_execute_on_pending=temp_hostdependency->fail_execute_on_pending;
      new_hostdependency->have_execution_dependency_options=temp_hostdependency->have_execution_dependency_options;
      new_hostdependency->inherits_parent=temp_hostdependency->inherits_parent;
      new_hostdependency->have_inherits_parent=temp_hostdependency->have_inherits_parent;

      /* allocate memory for and copy string members of hostdependency definition */
      if(temp_hostdependency->host_name!=NULL){
            new_hostdependency->host_name=strdup(master_host_name);
            if(new_hostdependency->host_name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of host dependency.\n");
#endif
                  free(new_hostdependency);
                  return ERROR;
                    }
              } 
            if(temp_hostdependency->dependent_host_name!=NULL){
            new_hostdependency->dependent_host_name=strdup(dependent_host_name);
            if(new_hostdependency->dependent_host_name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of host dependency.\n");
#endif
                  free(new_hostdependency);
                  return ERROR;
                    }
              } 
      if(temp_hostdependency->template!=NULL){
            new_hostdependency->template=strdup(temp_hostdependency->template);
            if(new_hostdependency->template==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of host dependency.\n");
#endif
                  free(new_hostdependency->host_name);
                  free(new_hostdependency);
                  return ERROR;
                    }
              } 
      if(temp_hostdependency->name!=NULL){
            new_hostdependency->name=strdup(temp_hostdependency->name);
            if(new_hostdependency->name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of host dependency.\n");
#endif
                  free(new_hostdependency->host_name);
                  free(new_hostdependency->template);
                  free(new_hostdependency);
                  return ERROR;
                    }
              } 

      /* add new hostdependency to head of list in memory */
      new_hostdependency->next=xodtemplate_hostdependency_list;
      xodtemplate_hostdependency_list=new_hostdependency;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_hostdependency() end\n");
#endif

      return OK;
        }



/* duplicates a service dependency definition */
int xodtemplate_duplicate_servicedependency(xodtemplate_servicedependency *temp_servicedependency, char *master_host_name, char *master_service_description, char *dependent_host_name, char *dependent_service_description){
      xodtemplate_servicedependency *new_servicedependency;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_servicedependency() start\n");
#endif

      /* allocate memory for a new service dependency definition */
      new_servicedependency=(xodtemplate_servicedependency *)malloc(sizeof(xodtemplate_servicedependency));
      if(new_servicedependency==NULL){
#ifdef DEBUG1
            printf("Error: Could not allocate memory for duplicate definition of service dependency.\n");
#endif
            return ERROR;
              }

      /* defaults */
      new_servicedependency->template=NULL;
      new_servicedependency->name=NULL;
      new_servicedependency->servicegroup_name=NULL;
      new_servicedependency->hostgroup_name=NULL;
      new_servicedependency->dependent_servicegroup_name=NULL;
      new_servicedependency->dependent_hostgroup_name=NULL;
      new_servicedependency->host_name=NULL;
      new_servicedependency->dependent_host_name=NULL;
      new_servicedependency->service_description=NULL;
      new_servicedependency->dependent_service_description=NULL;

      new_servicedependency->has_been_resolved=temp_servicedependency->has_been_resolved;
      new_servicedependency->register_object=temp_servicedependency->register_object;
      new_servicedependency->_config_file=temp_servicedependency->_config_file;
      new_servicedependency->_start_line=temp_servicedependency->_start_line;

      new_servicedependency->fail_notify_on_ok=temp_servicedependency->fail_notify_on_ok;
      new_servicedependency->fail_notify_on_unknown=temp_servicedependency->fail_notify_on_unknown;
      new_servicedependency->fail_notify_on_warning=temp_servicedependency->fail_notify_on_warning;
      new_servicedependency->fail_notify_on_critical=temp_servicedependency->fail_notify_on_critical;
      new_servicedependency->fail_notify_on_pending=temp_servicedependency->fail_notify_on_pending;
      new_servicedependency->have_notification_dependency_options=temp_servicedependency->have_notification_dependency_options;
      new_servicedependency->fail_execute_on_ok=temp_servicedependency->fail_execute_on_ok;
      new_servicedependency->fail_execute_on_unknown=temp_servicedependency->fail_execute_on_unknown;
      new_servicedependency->fail_execute_on_warning=temp_servicedependency->fail_execute_on_warning;
      new_servicedependency->fail_execute_on_critical=temp_servicedependency->fail_execute_on_critical;
      new_servicedependency->fail_execute_on_pending=temp_servicedependency->fail_execute_on_pending;
      new_servicedependency->have_execution_dependency_options=temp_servicedependency->have_execution_dependency_options;
      new_servicedependency->inherits_parent=temp_servicedependency->inherits_parent;
      new_servicedependency->have_inherits_parent=temp_servicedependency->have_inherits_parent;
      

      /* allocate memory for and copy string members of hostdependency definition */
      if(temp_servicedependency->host_name!=NULL){
            new_servicedependency->host_name=strdup(master_host_name);
            if(new_servicedependency->host_name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service dependency.\n");
#endif
                  free(new_servicedependency);
                  return ERROR;
                    }
              } 
      if(temp_servicedependency->service_description!=NULL){
            new_servicedependency->service_description=strdup(master_service_description);
            if(new_servicedependency->service_description==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service dependency.\n");
#endif
                  free(new_servicedependency);
                  return ERROR;
                    }
              } 
            if(temp_servicedependency->dependent_host_name!=NULL){
            new_servicedependency->dependent_host_name=strdup(dependent_host_name);
            if(new_servicedependency->dependent_host_name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service dependency.\n");
#endif
                  free(new_servicedependency);
                  return ERROR;
                    }
              } 
      if(temp_servicedependency->dependent_service_description!=NULL){
            new_servicedependency->dependent_service_description=strdup(dependent_service_description);
            if(new_servicedependency->dependent_service_description==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service dependency.\n");
#endif
                  free(new_servicedependency);
                  return ERROR;
                    }
              } 
      if(temp_servicedependency->template!=NULL){
            new_servicedependency->template=strdup(temp_servicedependency->template);
            if(new_servicedependency->template==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service dependency.\n");
#endif
                  free(new_servicedependency->host_name);
                  free(new_servicedependency);
                  return ERROR;
                    }
              } 
      if(temp_servicedependency->name!=NULL){
            new_servicedependency->name=strdup(temp_servicedependency->name);
            if(new_servicedependency->name==NULL){
#ifdef DEBUG1
                  printf("Error: Could not allocate memory for duplicate definition of service dependency.\n");
#endif
                  free(new_servicedependency->host_name);
                  free(new_servicedependency->template);
                  free(new_servicedependency);
                  return ERROR;
                    }
              } 

      /* add new servicedependency to head of list in memory */
      new_servicedependency->next=xodtemplate_servicedependency_list;
      xodtemplate_servicedependency_list=new_servicedependency;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_servicedependency() end\n");
#endif

      return OK;
        }



/* duplicates a hostextinfo object definition */
int xodtemplate_duplicate_hostextinfo(xodtemplate_hostextinfo *this_hostextinfo, char *host_name){
      xodtemplate_hostextinfo *new_hostextinfo;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_hostextinfo() start\n");
#endif

      new_hostextinfo=(xodtemplate_hostextinfo *)malloc(sizeof(xodtemplate_hostextinfo));
      if(new_hostextinfo==NULL){
#ifdef DEBUG1
            printf("Error: Could not allocate memory for duplicate definition of extended host info.\n");
#endif
            return ERROR;
              }

      new_hostextinfo->template=NULL;
      new_hostextinfo->name=NULL;
      new_hostextinfo->host_name=NULL;
      new_hostextinfo->hostgroup_name=NULL;
      new_hostextinfo->notes=NULL;
      new_hostextinfo->notes_url=NULL;
      new_hostextinfo->action_url=NULL;
      new_hostextinfo->icon_image=NULL;
      new_hostextinfo->icon_image_alt=NULL;
      new_hostextinfo->vrml_image=NULL;
      new_hostextinfo->statusmap_image=NULL;

      /* duplicate strings (host_name member is passed in) */
      if(host_name!=NULL)
            new_hostextinfo->host_name=strdup(host_name);
      if(this_hostextinfo->template!=NULL)
            new_hostextinfo->template=strdup(this_hostextinfo->template);
      if(this_hostextinfo->name!=NULL)
            new_hostextinfo->name=strdup(this_hostextinfo->name);
      if(this_hostextinfo->notes!=NULL)
            new_hostextinfo->notes=strdup(this_hostextinfo->notes);
      if(this_hostextinfo->notes_url!=NULL)
            new_hostextinfo->notes_url=strdup(this_hostextinfo->notes_url);
      if(this_hostextinfo->action_url!=NULL)
            new_hostextinfo->action_url=strdup(this_hostextinfo->action_url);
      if(this_hostextinfo->icon_image!=NULL)
            new_hostextinfo->icon_image=strdup(this_hostextinfo->icon_image);
      if(this_hostextinfo->icon_image_alt!=NULL)
            new_hostextinfo->icon_image_alt=strdup(this_hostextinfo->icon_image_alt);
      if(this_hostextinfo->vrml_image!=NULL)
            new_hostextinfo->vrml_image=strdup(this_hostextinfo->vrml_image);
      if(this_hostextinfo->statusmap_image!=NULL)
            new_hostextinfo->statusmap_image=strdup(this_hostextinfo->statusmap_image);

      /* duplicate non-string members */
      new_hostextinfo->x_2d=this_hostextinfo->x_2d;
      new_hostextinfo->y_2d=this_hostextinfo->y_2d;
      new_hostextinfo->have_2d_coords=this_hostextinfo->have_2d_coords;
      new_hostextinfo->x_3d=this_hostextinfo->x_3d;
      new_hostextinfo->y_3d=this_hostextinfo->y_3d;
      new_hostextinfo->z_3d=this_hostextinfo->z_3d;
      new_hostextinfo->have_3d_coords=this_hostextinfo->have_3d_coords;

      new_hostextinfo->has_been_resolved=this_hostextinfo->has_been_resolved;
      new_hostextinfo->register_object=this_hostextinfo->register_object;

      /* add new object to head of list */
      new_hostextinfo->next=xodtemplate_hostextinfo_list;
      xodtemplate_hostextinfo_list=new_hostextinfo;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_hostextinfo() end\n");
#endif

      return OK;
        }



/* duplicates a serviceextinfo object definition */
int xodtemplate_duplicate_serviceextinfo(xodtemplate_serviceextinfo *this_serviceextinfo, char *host_name){
      xodtemplate_serviceextinfo *new_serviceextinfo;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_serviceextinfo() start\n");
#endif

      new_serviceextinfo=(xodtemplate_serviceextinfo *)malloc(sizeof(xodtemplate_serviceextinfo));
      if(new_serviceextinfo==NULL){
#ifdef DEBUG1
            printf("Error: Could not allocate memory for duplicate definition of extended service info.\n");
#endif
            return ERROR;
              }

      new_serviceextinfo->template=NULL;
      new_serviceextinfo->name=NULL;
      new_serviceextinfo->host_name=NULL;
      new_serviceextinfo->service_description=NULL;
      new_serviceextinfo->hostgroup_name=NULL;
      new_serviceextinfo->notes=NULL;
      new_serviceextinfo->notes_url=NULL;
      new_serviceextinfo->action_url=NULL;
      new_serviceextinfo->icon_image=NULL;
      new_serviceextinfo->icon_image_alt=NULL;

      new_serviceextinfo->has_been_resolved=this_serviceextinfo->has_been_resolved;
      new_serviceextinfo->register_object=this_serviceextinfo->register_object;

      /* duplicate strings (host_name member is passed in) */
      if(host_name!=NULL)
            new_serviceextinfo->host_name=strdup(host_name);
      if(this_serviceextinfo->template!=NULL)
            new_serviceextinfo->template=strdup(this_serviceextinfo->template);
      if(this_serviceextinfo->name!=NULL)
            new_serviceextinfo->name=strdup(this_serviceextinfo->name);
      if(this_serviceextinfo->service_description!=NULL)
            new_serviceextinfo->service_description=strdup(this_serviceextinfo->service_description);
      if(this_serviceextinfo->notes!=NULL)
            new_serviceextinfo->notes=strdup(this_serviceextinfo->notes);
      if(this_serviceextinfo->notes_url!=NULL)
            new_serviceextinfo->notes_url=strdup(this_serviceextinfo->notes_url);
      if(this_serviceextinfo->action_url!=NULL)
            new_serviceextinfo->action_url=strdup(this_serviceextinfo->action_url);
      if(this_serviceextinfo->icon_image!=NULL)
            new_serviceextinfo->icon_image=strdup(this_serviceextinfo->icon_image);
      if(this_serviceextinfo->icon_image_alt!=NULL)
            new_serviceextinfo->icon_image_alt=strdup(this_serviceextinfo->icon_image_alt);

      /* add new object to head of list */
      new_serviceextinfo->next=xodtemplate_serviceextinfo_list;
      xodtemplate_serviceextinfo_list=new_serviceextinfo;

#ifdef DEBUG0
      printf("xodtemplate_duplicate_serviceextinfo() end\n");
#endif

      return OK;
        }

#endif


/******************************************************************/
/***************** OBJECT RESOLUTION FUNCTIONS ********************/
/******************************************************************/

#ifdef NSCORE

/* resolves object definitions */
int xodtemplate_resolve_objects(void){
      xodtemplate_timeperiod *temp_timeperiod;
      xodtemplate_command *temp_command;
      xodtemplate_contactgroup *temp_contactgroup;
      xodtemplate_hostgroup *temp_hostgroup;
      xodtemplate_servicegroup *temp_servicegroup;
      xodtemplate_servicedependency *temp_servicedependency;
      xodtemplate_serviceescalation *temp_serviceescalation;
      xodtemplate_contact *temp_contact;
      xodtemplate_host *temp_host;
      xodtemplate_service *temp_service;
      xodtemplate_hostdependency *temp_hostdependency;
      xodtemplate_hostescalation *temp_hostescalation;
      xodtemplate_hostextinfo *temp_hostextinfo;
      xodtemplate_serviceextinfo *temp_serviceextinfo;

#ifdef DEBUG0
      printf("xodtemplate_resolve_objects() start\n");
#endif

      /* resolve all timeperiod objects */
      for(temp_timeperiod=xodtemplate_timeperiod_list;temp_timeperiod!=NULL;temp_timeperiod=temp_timeperiod->next){
            if(xodtemplate_resolve_timeperiod(temp_timeperiod)==ERROR)
                  return ERROR;
              }

      /* resolve all command objects */
      for(temp_command=xodtemplate_command_list;temp_command!=NULL;temp_command=temp_command->next){
            if(xodtemplate_resolve_command(temp_command)==ERROR)
                  return ERROR;
              }

      /* resolve all contactgroup objects */
      for(temp_contactgroup=xodtemplate_contactgroup_list;temp_contactgroup!=NULL;temp_contactgroup=temp_contactgroup->next){
            if(xodtemplate_resolve_contactgroup(temp_contactgroup)==ERROR)
                  return ERROR;
              }

      /* resolve all hostgroup objects */
      for(temp_hostgroup=xodtemplate_hostgroup_list;temp_hostgroup!=NULL;temp_hostgroup=temp_hostgroup->next){
            if(xodtemplate_resolve_hostgroup(temp_hostgroup)==ERROR)
                  return ERROR;
              }

      /* resolve all servicegroup objects */
      for(temp_servicegroup=xodtemplate_servicegroup_list;temp_servicegroup!=NULL;temp_servicegroup=temp_servicegroup->next){
            if(xodtemplate_resolve_servicegroup(temp_servicegroup)==ERROR)
                  return ERROR;
              }

      /* resolve all servicedependency objects */
      for(temp_servicedependency=xodtemplate_servicedependency_list;temp_servicedependency!=NULL;temp_servicedependency=temp_servicedependency->next){
            if(xodtemplate_resolve_servicedependency(temp_servicedependency)==ERROR)
                  return ERROR;
              }

      /* resolve all serviceescalation objects */
      for(temp_serviceescalation=xodtemplate_serviceescalation_list;temp_serviceescalation!=NULL;temp_serviceescalation=temp_serviceescalation->next){
            if(xodtemplate_resolve_serviceescalation(temp_serviceescalation)==ERROR)
                  return ERROR;
              }

      /* resolve all contact objects */
      for(temp_contact=xodtemplate_contact_list;temp_contact!=NULL;temp_contact=temp_contact->next){
            if(xodtemplate_resolve_contact(temp_contact)==ERROR)
                  return ERROR;
              }

      /* resolve all host objects */
      for(temp_host=xodtemplate_host_list;temp_host!=NULL;temp_host=temp_host->next){
            if(xodtemplate_resolve_host(temp_host)==ERROR)
                  return ERROR;
              }

      /* resolve all service objects */
      for(temp_service=xodtemplate_service_list;temp_service!=NULL;temp_service=temp_service->next){
            if(xodtemplate_resolve_service(temp_service)==ERROR)
                  return ERROR;
              }

      /* resolve all hostdependency objects */
      for(temp_hostdependency=xodtemplate_hostdependency_list;temp_hostdependency!=NULL;temp_hostdependency=temp_hostdependency->next){
            if(xodtemplate_resolve_hostdependency(temp_hostdependency)==ERROR)
                  return ERROR;
              }

      /* resolve all hostescalation objects */
      for(temp_hostescalation=xodtemplate_hostescalation_list;temp_hostescalation!=NULL;temp_hostescalation=temp_hostescalation->next){
            if(xodtemplate_resolve_hostescalation(temp_hostescalation)==ERROR)
                  return ERROR;
              }

      /* resolve all hostextinfo objects */
      for(temp_hostextinfo=xodtemplate_hostextinfo_list;temp_hostextinfo!=NULL;temp_hostextinfo=temp_hostextinfo->next){
            if(xodtemplate_resolve_hostextinfo(temp_hostextinfo)==ERROR)
                  return ERROR;
              }

      /* resolve all serviceextinfo objects */
      for(temp_serviceextinfo=xodtemplate_serviceextinfo_list;temp_serviceextinfo!=NULL;temp_serviceextinfo=temp_serviceextinfo->next){
            if(xodtemplate_resolve_serviceextinfo(temp_serviceextinfo)==ERROR)
                  return ERROR;
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_objects() end\n");
#endif

      return OK;
        }



/* resolves a timeperiod object */
int xodtemplate_resolve_timeperiod(xodtemplate_timeperiod *this_timeperiod){
      xodtemplate_timeperiod *template_timeperiod;
      int x;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_timeperiod() start\n");
#endif

      /* return if this timeperiod has already been resolved */
      if(this_timeperiod->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_timeperiod->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_timeperiod->template==NULL)
            return OK;

      template_timeperiod=xodtemplate_find_timeperiod(this_timeperiod->template);
      if(template_timeperiod==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in timeperiod definition could not be not found (config file '%s', starting on line %d)\n",this_timeperiod->template,xodtemplate_config_file_name(this_timeperiod->_config_file),this_timeperiod->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template timeperiod... */
      xodtemplate_resolve_timeperiod(template_timeperiod);

      /* apply missing properties from template timeperiod... */
      if(this_timeperiod->timeperiod_name==NULL && template_timeperiod->timeperiod_name!=NULL)
            this_timeperiod->timeperiod_name=strdup(template_timeperiod->timeperiod_name);
      if(this_timeperiod->alias==NULL && template_timeperiod->alias!=NULL)
            this_timeperiod->alias=strdup(template_timeperiod->alias);
      for(x=0;x<7;x++){
            if(this_timeperiod->timeranges[x]==NULL && template_timeperiod->timeranges[x]!=NULL){
                  this_timeperiod->timeranges[x]=strdup(template_timeperiod->timeranges[x]);
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_timeperiod() end\n");
#endif

      return OK;
        }




/* resolves a command object */
int xodtemplate_resolve_command(xodtemplate_command *this_command){
      xodtemplate_command *template_command;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_command() start\n");
#endif

      /* return if this command has already been resolved */
      if(this_command->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_command->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_command->template==NULL)
            return OK;

      template_command=xodtemplate_find_command(this_command->template);
      if(template_command==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in command definition could not be not found (config file '%s', starting on line %d)\n",this_command->template,xodtemplate_config_file_name(this_command->_config_file),this_command->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template command... */
      xodtemplate_resolve_command(template_command);

      /* apply missing properties from template command... */
      if(this_command->command_name==NULL && template_command->command_name!=NULL)
            this_command->command_name=strdup(template_command->command_name);
      if(this_command->command_line==NULL && template_command->command_line!=NULL)
            this_command->command_line=strdup(template_command->command_line);

#ifdef DEBUG0
      printf("xodtemplate_resolve_command() end\n");
#endif

      return OK;
        }




/* resolves a contactgroup object */
int xodtemplate_resolve_contactgroup(xodtemplate_contactgroup *this_contactgroup){
      xodtemplate_contactgroup *template_contactgroup;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_contactgroup() start\n");
#endif

      /* return if this contactgroup has already been resolved */
      if(this_contactgroup->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_contactgroup->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_contactgroup->template==NULL)
            return OK;

      template_contactgroup=xodtemplate_find_contactgroup(this_contactgroup->template);
      if(template_contactgroup==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in contactgroup definition could not be not found (config file '%s', starting on line %d)\n",this_contactgroup->template,xodtemplate_config_file_name(this_contactgroup->_config_file),this_contactgroup->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template contactgroup... */
      xodtemplate_resolve_contactgroup(template_contactgroup);

      /* apply missing properties from template contactgroup... */
      if(this_contactgroup->contactgroup_name==NULL && template_contactgroup->contactgroup_name!=NULL)
            this_contactgroup->contactgroup_name=strdup(template_contactgroup->contactgroup_name);
      if(this_contactgroup->alias==NULL && template_contactgroup->alias!=NULL)
            this_contactgroup->alias=strdup(template_contactgroup->alias);
      if(this_contactgroup->members==NULL && template_contactgroup->members!=NULL)
            this_contactgroup->members=strdup(template_contactgroup->members);

#ifdef DEBUG0
      printf("xodtemplate_resolve_contactgroup() end\n");
#endif

      return OK;
        }




/* resolves a hostgroup object */
int xodtemplate_resolve_hostgroup(xodtemplate_hostgroup *this_hostgroup){
      xodtemplate_hostgroup *template_hostgroup;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_hostgroup() start\n");
#endif

      /* return if this hostgroup has already been resolved */
      if(this_hostgroup->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_hostgroup->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_hostgroup->template==NULL)
            return OK;

      template_hostgroup=xodtemplate_find_hostgroup(this_hostgroup->template);
      if(template_hostgroup==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in hostgroup definition could not be not found (config file '%s', starting on line %d)\n",this_hostgroup->template,xodtemplate_config_file_name(this_hostgroup->_config_file),this_hostgroup->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template hostgroup... */
      xodtemplate_resolve_hostgroup(template_hostgroup);

      /* apply missing properties from template hostgroup... */
      if(this_hostgroup->hostgroup_name==NULL && template_hostgroup->hostgroup_name!=NULL)
            this_hostgroup->hostgroup_name=strdup(template_hostgroup->hostgroup_name);
      if(this_hostgroup->alias==NULL && template_hostgroup->alias!=NULL)
            this_hostgroup->alias=strdup(template_hostgroup->alias);
      if(this_hostgroup->members==NULL && template_hostgroup->members!=NULL)
            this_hostgroup->members=strdup(template_hostgroup->members);

#ifdef DEBUG0
      printf("xodtemplate_resolve_hostgroup() end\n");
#endif

      return OK;
        }




/* resolves a servicegroup object */
int xodtemplate_resolve_servicegroup(xodtemplate_servicegroup *this_servicegroup){
      xodtemplate_servicegroup *template_servicegroup;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_servicegroup() start\n");
#endif

      /* return if this servicegroup has already been resolved */
      if(this_servicegroup->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_servicegroup->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_servicegroup->template==NULL)
            return OK;

      template_servicegroup=xodtemplate_find_servicegroup(this_servicegroup->template);
      if(template_servicegroup==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in servicegroup definition could not be not found (config file '%s', starting on line %d)\n",this_servicegroup->template,xodtemplate_config_file_name(this_servicegroup->_config_file),this_servicegroup->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template servicegroup... */
      xodtemplate_resolve_servicegroup(template_servicegroup);

      /* apply missing properties from template servicegroup... */
      if(this_servicegroup->servicegroup_name==NULL && template_servicegroup->servicegroup_name!=NULL)
            this_servicegroup->servicegroup_name=strdup(template_servicegroup->servicegroup_name);
      if(this_servicegroup->alias==NULL && template_servicegroup->alias!=NULL)
            this_servicegroup->alias=strdup(template_servicegroup->alias);
      if(this_servicegroup->members==NULL && template_servicegroup->members!=NULL)
            this_servicegroup->members=strdup(template_servicegroup->members);

#ifdef DEBUG0
      printf("xodtemplate_resolve_servicegroup() end\n");
#endif

      return OK;
        }


/* resolves a servicedependency object */
int xodtemplate_resolve_servicedependency(xodtemplate_servicedependency *this_servicedependency){
      xodtemplate_servicedependency *template_servicedependency;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_servicedependency() start\n");
#endif

      /* return if this servicedependency has already been resolved */
      if(this_servicedependency->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_servicedependency->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_servicedependency->template==NULL)
            return OK;

      template_servicedependency=xodtemplate_find_servicedependency(this_servicedependency->template);
      if(template_servicedependency==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in service dependency definition could not be not found (config file '%s', starting on line %d)\n",this_servicedependency->template,xodtemplate_config_file_name(this_servicedependency->_config_file),this_servicedependency->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template servicedependency... */
      xodtemplate_resolve_servicedependency(template_servicedependency);

      /* apply missing properties from template servicedependency... */
      if(this_servicedependency->servicegroup_name==NULL && template_servicedependency->servicegroup_name!=NULL)
            this_servicedependency->servicegroup_name=strdup(template_servicedependency->servicegroup_name);
      if(this_servicedependency->hostgroup_name==NULL && template_servicedependency->hostgroup_name!=NULL)
            this_servicedependency->hostgroup_name=strdup(template_servicedependency->hostgroup_name);
      if(this_servicedependency->host_name==NULL && template_servicedependency->host_name!=NULL)
            this_servicedependency->host_name=strdup(template_servicedependency->host_name);
      if(this_servicedependency->service_description==NULL && template_servicedependency->service_description!=NULL)
            this_servicedependency->service_description=strdup(template_servicedependency->service_description);
      if(this_servicedependency->dependent_servicegroup_name==NULL && template_servicedependency->dependent_servicegroup_name!=NULL)
            this_servicedependency->dependent_servicegroup_name=strdup(template_servicedependency->dependent_servicegroup_name);
      if(this_servicedependency->dependent_hostgroup_name==NULL && template_servicedependency->dependent_hostgroup_name!=NULL)
            this_servicedependency->dependent_hostgroup_name=strdup(template_servicedependency->dependent_hostgroup_name);
      if(this_servicedependency->dependent_host_name==NULL && template_servicedependency->dependent_host_name!=NULL)
            this_servicedependency->dependent_host_name=strdup(template_servicedependency->dependent_host_name);
      if(this_servicedependency->dependent_service_description==NULL && template_servicedependency->dependent_service_description!=NULL)
            this_servicedependency->dependent_service_description=strdup(template_servicedependency->dependent_service_description);
      if(this_servicedependency->have_inherits_parent==FALSE && template_servicedependency->have_inherits_parent==TRUE){
            this_servicedependency->inherits_parent=template_servicedependency->inherits_parent;
            this_servicedependency->have_inherits_parent=TRUE;
              }
      if(this_servicedependency->have_execution_dependency_options==FALSE && template_servicedependency->have_execution_dependency_options==TRUE){
            this_servicedependency->fail_execute_on_ok=template_servicedependency->fail_execute_on_ok;
            this_servicedependency->fail_execute_on_unknown=template_servicedependency->fail_execute_on_unknown;
            this_servicedependency->fail_execute_on_warning=template_servicedependency->fail_execute_on_warning;
            this_servicedependency->fail_execute_on_critical=template_servicedependency->fail_execute_on_critical;
            this_servicedependency->fail_execute_on_pending=template_servicedependency->fail_execute_on_pending;
            this_servicedependency->have_execution_dependency_options=TRUE;
              }
      if(this_servicedependency->have_notification_dependency_options==FALSE && template_servicedependency->have_notification_dependency_options==TRUE){
            this_servicedependency->fail_notify_on_ok=template_servicedependency->fail_notify_on_ok;
            this_servicedependency->fail_notify_on_unknown=template_servicedependency->fail_notify_on_unknown;
            this_servicedependency->fail_notify_on_warning=template_servicedependency->fail_notify_on_warning;
            this_servicedependency->fail_notify_on_critical=template_servicedependency->fail_notify_on_critical;
            this_servicedependency->fail_notify_on_pending=template_servicedependency->fail_notify_on_pending;
            this_servicedependency->have_notification_dependency_options=TRUE;
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_servicedependency() end\n");
#endif

      return OK;
        }


/* resolves a serviceescalation object */
int xodtemplate_resolve_serviceescalation(xodtemplate_serviceescalation *this_serviceescalation){
      xodtemplate_serviceescalation *template_serviceescalation;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_serviceescalation() start\n");
#endif

      /* return if this serviceescalation has already been resolved */
      if(this_serviceescalation->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_serviceescalation->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_serviceescalation->template==NULL)
            return OK;

      template_serviceescalation=xodtemplate_find_serviceescalation(this_serviceescalation->template);
      if(template_serviceescalation==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in service escalation definition could not be not found (config file '%s', starting on line %d)\n",this_serviceescalation->template,xodtemplate_config_file_name(this_serviceescalation->_config_file),this_serviceescalation->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template serviceescalation... */
      xodtemplate_resolve_serviceescalation(template_serviceescalation);

      /* apply missing properties from template serviceescalation... */
      if(this_serviceescalation->servicegroup_name==NULL && template_serviceescalation->servicegroup_name!=NULL)
            this_serviceescalation->servicegroup_name=strdup(template_serviceescalation->servicegroup_name);
      if(this_serviceescalation->hostgroup_name==NULL && template_serviceescalation->hostgroup_name!=NULL)
            this_serviceescalation->hostgroup_name=strdup(template_serviceescalation->hostgroup_name);
      if(this_serviceescalation->host_name==NULL && template_serviceescalation->host_name!=NULL)
            this_serviceescalation->host_name=strdup(template_serviceescalation->host_name);
      if(this_serviceescalation->service_description==NULL && template_serviceescalation->service_description!=NULL)
            this_serviceescalation->service_description=strdup(template_serviceescalation->service_description);
      if(this_serviceescalation->escalation_period==NULL && template_serviceescalation->escalation_period!=NULL)
            this_serviceescalation->escalation_period=strdup(template_serviceescalation->escalation_period);
      if(this_serviceescalation->contact_groups==NULL && template_serviceescalation->contact_groups!=NULL)
            this_serviceescalation->contact_groups=strdup(template_serviceescalation->contact_groups);
      if(this_serviceescalation->have_first_notification==FALSE && template_serviceescalation->have_first_notification==TRUE){
            this_serviceescalation->first_notification=template_serviceescalation->first_notification;
            this_serviceescalation->have_first_notification=TRUE;
              }
      if(this_serviceescalation->have_last_notification==FALSE && template_serviceescalation->have_last_notification==TRUE){
            this_serviceescalation->last_notification=template_serviceescalation->last_notification;
            this_serviceescalation->have_last_notification=TRUE;
              }
      if(this_serviceescalation->have_notification_interval==FALSE && template_serviceescalation->have_notification_interval==TRUE){
            this_serviceescalation->notification_interval=template_serviceescalation->notification_interval;
            this_serviceescalation->have_notification_interval=TRUE;
              }
      if(this_serviceescalation->have_escalation_options==FALSE && template_serviceescalation->have_escalation_options==TRUE){
            this_serviceescalation->escalate_on_warning=template_serviceescalation->escalate_on_warning;
            this_serviceescalation->escalate_on_unknown=template_serviceescalation->escalate_on_unknown;
            this_serviceescalation->escalate_on_critical=template_serviceescalation->escalate_on_critical;
            this_serviceescalation->escalate_on_recovery=template_serviceescalation->escalate_on_recovery;
            this_serviceescalation->have_escalation_options=TRUE;
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_servicedeescalation() end\n");
#endif

      return OK;
        }



/* resolves a contact object */
int xodtemplate_resolve_contact(xodtemplate_contact *this_contact){
      xodtemplate_contact *template_contact;
      int x;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_contact() start\n");
#endif

      /* return if this contact has already been resolved */
      if(this_contact->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_contact->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_contact->template==NULL)
            return OK;

      template_contact=xodtemplate_find_contact(this_contact->template);
      if(template_contact==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in contact definition could not be not found (config file '%s', starting on line %d)\n",this_contact->template,xodtemplate_config_file_name(this_contact->_config_file),this_contact->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template contact... */
      xodtemplate_resolve_contact(template_contact);

      /* apply missing properties from template contact... */
      if(this_contact->contact_name==NULL && template_contact->contact_name!=NULL)
            this_contact->contact_name=strdup(template_contact->contact_name);
      if(this_contact->alias==NULL && template_contact->alias!=NULL)
            this_contact->alias=strdup(template_contact->alias);
      if(this_contact->email==NULL && template_contact->email!=NULL)
            this_contact->email=strdup(template_contact->email);
      if(this_contact->pager==NULL && template_contact->pager!=NULL)
            this_contact->pager=strdup(template_contact->pager);
      for(x=0;x<MAX_XODTEMPLATE_CONTACT_ADDRESSES;x++){
            if(this_contact->address[x]==NULL && template_contact->address[x]!=NULL)
                  this_contact->address[x]=strdup(template_contact->address[x]);
              }
      if(this_contact->contactgroups==NULL && template_contact->contactgroups!=NULL)
            this_contact->contactgroups=strdup(template_contact->contactgroups);
      if(this_contact->host_notification_period==NULL && template_contact->host_notification_period!=NULL)
            this_contact->host_notification_period=strdup(template_contact->host_notification_period);
      if(this_contact->service_notification_period==NULL && template_contact->service_notification_period!=NULL)
            this_contact->service_notification_period=strdup(template_contact->service_notification_period);
      if(this_contact->host_notification_commands==NULL && template_contact->host_notification_commands!=NULL)
            this_contact->host_notification_commands=strdup(template_contact->host_notification_commands);
      if(this_contact->service_notification_commands==NULL && template_contact->service_notification_commands!=NULL)
            this_contact->service_notification_commands=strdup(template_contact->service_notification_commands);
      if(this_contact->have_host_notification_options==FALSE && template_contact->have_host_notification_options==TRUE){
            this_contact->notify_on_host_down=template_contact->notify_on_host_down;
            this_contact->notify_on_host_unreachable=template_contact->notify_on_host_unreachable;
            this_contact->notify_on_host_recovery=template_contact->notify_on_host_recovery;
            this_contact->notify_on_host_flapping=template_contact->notify_on_host_flapping;
            this_contact->have_host_notification_options=TRUE;
              }
      if(this_contact->have_service_notification_options==FALSE && template_contact->have_service_notification_options==TRUE){
            this_contact->notify_on_service_unknown=template_contact->notify_on_service_unknown;
            this_contact->notify_on_service_warning=template_contact->notify_on_service_warning;
            this_contact->notify_on_service_critical=template_contact->notify_on_service_critical;
            this_contact->notify_on_service_recovery=template_contact->notify_on_service_recovery;
            this_contact->notify_on_service_flapping=template_contact->notify_on_service_flapping;
            this_contact->have_service_notification_options=TRUE;
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_contact() end\n");
#endif

      return OK;
        }



/* resolves a host object */
int xodtemplate_resolve_host(xodtemplate_host *this_host){
      xodtemplate_host *template_host;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_host() start\n");
#endif

      /* return if this host has already been resolved */
      if(this_host->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_host->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_host->template==NULL)
            return OK;

      template_host=xodtemplate_find_host(this_host->template);
      if(template_host==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in host definition could not be not found (config file '%s', starting on line %d)\n",this_host->template,xodtemplate_config_file_name(this_host->_config_file),this_host->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template host... */
      xodtemplate_resolve_host(template_host);

      /* apply missing properties from template host... */
      if(this_host->host_name==NULL && template_host->host_name!=NULL)
            this_host->host_name=strdup(template_host->host_name);
      if(this_host->alias==NULL && template_host->alias!=NULL)
            this_host->alias=strdup(template_host->alias);
      if(this_host->address==NULL && template_host->address!=NULL)
            this_host->address=strdup(template_host->address);
      if(this_host->parents==NULL && template_host->parents!=NULL)
            this_host->parents=strdup(template_host->parents);
      if(this_host->hostgroups==NULL && template_host->hostgroups!=NULL)
            this_host->hostgroups=strdup(template_host->hostgroups);
      if(this_host->check_command==NULL && template_host->check_command!=NULL)
            this_host->check_command=strdup(template_host->check_command);
      if(this_host->check_period==NULL && template_host->check_period!=NULL)
            this_host->check_period=strdup(template_host->check_period);
      if(this_host->event_handler==NULL && template_host->event_handler!=NULL)
            this_host->event_handler=strdup(template_host->event_handler);
      if(this_host->contact_groups==NULL && template_host->contact_groups!=NULL)
            this_host->contact_groups=strdup(template_host->contact_groups);
      if(this_host->notification_period==NULL && template_host->notification_period!=NULL)
            this_host->notification_period=strdup(template_host->notification_period);
      if(this_host->failure_prediction_options==NULL && template_host->failure_prediction_options!=NULL)
            this_host->failure_prediction_options=strdup(template_host->failure_prediction_options);
      if(this_host->have_check_interval==FALSE && template_host->have_check_interval==TRUE){
            this_host->check_interval=template_host->check_interval;
            this_host->have_check_interval=TRUE;
              }
      if(this_host->have_max_check_attempts==FALSE && template_host->have_max_check_attempts==TRUE){
            this_host->max_check_attempts=template_host->max_check_attempts;
            this_host->have_max_check_attempts=TRUE;
              }
      if(this_host->have_active_checks_enabled==FALSE && template_host->have_active_checks_enabled==TRUE){
            this_host->active_checks_enabled=template_host->active_checks_enabled;
            this_host->have_active_checks_enabled=TRUE;
              }
      if(this_host->have_passive_checks_enabled==FALSE && template_host->have_passive_checks_enabled==TRUE){
            this_host->passive_checks_enabled=template_host->passive_checks_enabled;
            this_host->have_passive_checks_enabled=TRUE;
              }
      if(this_host->have_obsess_over_host==FALSE && template_host->have_obsess_over_host==TRUE){
            this_host->obsess_over_host=template_host->obsess_over_host;
            this_host->have_obsess_over_host=TRUE;
              }
      if(this_host->have_event_handler_enabled==FALSE && template_host->have_event_handler_enabled==TRUE){
            this_host->event_handler_enabled=template_host->event_handler_enabled;
            this_host->have_event_handler_enabled=TRUE;
              }
      if(this_host->have_check_freshness==FALSE && template_host->have_check_freshness==TRUE){
            this_host->check_freshness=template_host->check_freshness;
            this_host->have_check_freshness=TRUE;
              }
      if(this_host->have_freshness_threshold==FALSE && template_host->have_freshness_threshold==TRUE){
            this_host->freshness_threshold=template_host->freshness_threshold;
            this_host->have_freshness_threshold=TRUE;
              }
      if(this_host->have_low_flap_threshold==FALSE && template_host->have_low_flap_threshold==TRUE){
            this_host->low_flap_threshold=template_host->low_flap_threshold;
            this_host->have_low_flap_threshold=TRUE;
              }
      if(this_host->have_high_flap_threshold==FALSE && template_host->have_high_flap_threshold==TRUE){
            this_host->high_flap_threshold=template_host->high_flap_threshold;
            this_host->have_high_flap_threshold=TRUE;
              }
      if(this_host->have_flap_detection_enabled==FALSE && template_host->have_flap_detection_enabled==TRUE){
            this_host->flap_detection_enabled=template_host->flap_detection_enabled;
            this_host->have_flap_detection_enabled=TRUE;
              }
      if(this_host->have_notification_options==FALSE && template_host->have_notification_options==TRUE){
            this_host->notify_on_down=template_host->notify_on_down;
            this_host->notify_on_unreachable=template_host->notify_on_unreachable;
            this_host->notify_on_recovery=template_host->notify_on_recovery;
            this_host->notify_on_flapping=template_host->notify_on_flapping;
            this_host->have_notification_options=TRUE;
              }
      if(this_host->have_notifications_enabled==FALSE && template_host->have_notifications_enabled==TRUE){
            this_host->notifications_enabled=template_host->notifications_enabled;
            this_host->have_notifications_enabled=TRUE;
              }
      if(this_host->have_notification_interval==FALSE && template_host->have_notification_interval==TRUE){
            this_host->notification_interval=template_host->notification_interval;
            this_host->have_notification_interval=TRUE;
              }
      if(this_host->have_stalking_options==FALSE && template_host->have_stalking_options==TRUE){
            this_host->stalk_on_up=template_host->stalk_on_up;
            this_host->stalk_on_down=template_host->stalk_on_down;
            this_host->stalk_on_unreachable=template_host->stalk_on_unreachable;
            this_host->have_stalking_options=TRUE;
              }
      if(this_host->have_process_perf_data==FALSE && template_host->have_process_perf_data==TRUE){
            this_host->process_perf_data=template_host->process_perf_data;
            this_host->have_process_perf_data=TRUE;
              }
      if(this_host->have_failure_prediction_enabled==FALSE && template_host->have_failure_prediction_enabled==TRUE){
            this_host->failure_prediction_enabled=template_host->failure_prediction_enabled;
            this_host->have_failure_prediction_enabled=TRUE;
              }
      if(this_host->have_retain_status_information==FALSE && template_host->have_retain_status_information==TRUE){
            this_host->retain_status_information=template_host->retain_status_information;
            this_host->have_retain_status_information=TRUE;
              }
      if(this_host->have_retain_nonstatus_information==FALSE && template_host->have_retain_nonstatus_information==TRUE){
            this_host->retain_nonstatus_information=template_host->retain_nonstatus_information;
            this_host->have_retain_nonstatus_information=TRUE;
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_host() end\n");
#endif

      return OK;
        }



/* resolves a service object */
int xodtemplate_resolve_service(xodtemplate_service *this_service){
      xodtemplate_service *template_service;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_service() start\n");
#endif

      /* return if this service has already been resolved */
      if(this_service->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_service->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_service->template==NULL)
            return OK;

      template_service=xodtemplate_find_service(this_service->template);
      if(template_service==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in service definition could not be not found (config file '%s', starting on line %d)\n",this_service->template,xodtemplate_config_file_name(this_service->_config_file),this_service->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template service... */
      xodtemplate_resolve_service(template_service);

      /* apply missing properties from template service... */
      if(this_service->hostgroup_name==NULL && template_service->hostgroup_name!=NULL)
            this_service->hostgroup_name=strdup(template_service->hostgroup_name);
      if(this_service->host_name==NULL && template_service->host_name!=NULL)
            this_service->host_name=strdup(template_service->host_name);
      if(this_service->service_description==NULL && template_service->service_description!=NULL)
            this_service->service_description=strdup(template_service->service_description);
      if(this_service->servicegroups==NULL && template_service->servicegroups!=NULL)
            this_service->servicegroups=strdup(template_service->servicegroups);
      if(this_service->check_command==NULL && template_service->check_command!=NULL)
            this_service->check_command=strdup(template_service->check_command);
      if(this_service->check_period==NULL && template_service->check_period!=NULL)
            this_service->check_period=strdup(template_service->check_period);
      if(this_service->event_handler==NULL && template_service->event_handler!=NULL)
            this_service->event_handler=strdup(template_service->event_handler);
      if(this_service->notification_period==NULL && template_service->notification_period!=NULL)
            this_service->notification_period=strdup(template_service->notification_period);
      if(this_service->contact_groups==NULL && template_service->contact_groups!=NULL)
            this_service->contact_groups=strdup(template_service->contact_groups);
      if(this_service->failure_prediction_options==NULL && template_service->failure_prediction_options!=NULL)
            this_service->failure_prediction_options=strdup(template_service->failure_prediction_options);
      if(this_service->have_max_check_attempts==FALSE && template_service->have_max_check_attempts==TRUE){
            this_service->max_check_attempts=template_service->max_check_attempts;
            this_service->have_max_check_attempts=TRUE;
              }
      if(this_service->have_normal_check_interval==FALSE && template_service->have_normal_check_interval==TRUE){
            this_service->normal_check_interval=template_service->normal_check_interval;
            this_service->have_normal_check_interval=TRUE;
              }
      if(this_service->have_retry_check_interval==FALSE && template_service->have_retry_check_interval==TRUE){
            this_service->retry_check_interval=template_service->retry_check_interval;
            this_service->have_retry_check_interval=TRUE;
              }
      if(this_service->have_active_checks_enabled==FALSE && template_service->have_active_checks_enabled==TRUE){
            this_service->active_checks_enabled=template_service->active_checks_enabled;
            this_service->have_active_checks_enabled=TRUE;
              }
      if(this_service->have_passive_checks_enabled==FALSE && template_service->have_passive_checks_enabled==TRUE){
            this_service->passive_checks_enabled=template_service->passive_checks_enabled;
            this_service->have_passive_checks_enabled=TRUE;
              }
      if(this_service->have_parallelize_check==FALSE && template_service->have_parallelize_check==TRUE){
            this_service->parallelize_check=template_service->parallelize_check;
            this_service->have_parallelize_check=TRUE;
              }
      if(this_service->have_is_volatile==FALSE && template_service->have_is_volatile==TRUE){
            this_service->is_volatile=template_service->is_volatile;
            this_service->have_is_volatile=TRUE;
              }
      if(this_service->have_obsess_over_service==FALSE && template_service->have_obsess_over_service==TRUE){
            this_service->obsess_over_service=template_service->obsess_over_service;
            this_service->have_obsess_over_service=TRUE;
              }
      if(this_service->have_event_handler_enabled==FALSE && template_service->have_event_handler_enabled==TRUE){
            this_service->event_handler_enabled=template_service->event_handler_enabled;
            this_service->have_event_handler_enabled=TRUE;
              }
      if(this_service->have_check_freshness==FALSE && template_service->have_check_freshness==TRUE){
            this_service->check_freshness=template_service->check_freshness;
            this_service->have_check_freshness=TRUE;
              }
      if(this_service->have_freshness_threshold==FALSE && template_service->have_freshness_threshold==TRUE){
            this_service->freshness_threshold=template_service->freshness_threshold;
            this_service->have_freshness_threshold=TRUE;
              }
      if(this_service->have_low_flap_threshold==FALSE && template_service->have_low_flap_threshold==TRUE){
            this_service->low_flap_threshold=template_service->low_flap_threshold;
            this_service->have_low_flap_threshold=TRUE;
              }
      if(this_service->have_high_flap_threshold==FALSE && template_service->have_high_flap_threshold==TRUE){
            this_service->high_flap_threshold=template_service->high_flap_threshold;
            this_service->have_high_flap_threshold=TRUE;
              }
      if(this_service->have_flap_detection_enabled==FALSE && template_service->have_flap_detection_enabled==TRUE){
            this_service->flap_detection_enabled=template_service->flap_detection_enabled;
            this_service->have_flap_detection_enabled=TRUE;
              }
      if(this_service->have_notification_options==FALSE && template_service->have_notification_options==TRUE){
            this_service->notify_on_unknown=template_service->notify_on_unknown;
            this_service->notify_on_warning=template_service->notify_on_warning;
            this_service->notify_on_critical=template_service->notify_on_critical;
            this_service->notify_on_recovery=template_service->notify_on_recovery;
            this_service->notify_on_flapping=template_service->notify_on_flapping;
            this_service->have_notification_options=TRUE;
              }
      if(this_service->have_notifications_enabled==FALSE && template_service->have_notifications_enabled==TRUE){
            this_service->notifications_enabled=template_service->notifications_enabled;
            this_service->have_notifications_enabled=TRUE;
              }
      if(this_service->have_notification_interval==FALSE && template_service->have_notification_interval==TRUE){
            this_service->notification_interval=template_service->notification_interval;
            this_service->have_notification_interval=TRUE;
              }
      if(this_service->have_stalking_options==FALSE && template_service->have_stalking_options==TRUE){
            this_service->stalk_on_ok=template_service->stalk_on_ok;
            this_service->stalk_on_unknown=template_service->stalk_on_unknown;
            this_service->stalk_on_warning=template_service->stalk_on_warning;
            this_service->stalk_on_critical=template_service->stalk_on_critical;
            this_service->have_stalking_options=TRUE;
              }
      if(this_service->have_process_perf_data==FALSE && template_service->have_process_perf_data==TRUE){
            this_service->process_perf_data=template_service->process_perf_data;
            this_service->have_process_perf_data=TRUE;
              }
      if(this_service->have_failure_prediction_enabled==FALSE && template_service->have_failure_prediction_enabled==TRUE){
            this_service->failure_prediction_enabled=template_service->failure_prediction_enabled;
            this_service->have_failure_prediction_enabled=TRUE;
              }
      if(this_service->have_retain_status_information==FALSE && template_service->have_retain_status_information==TRUE){
            this_service->retain_status_information=template_service->retain_status_information;
            this_service->have_retain_status_information=TRUE;
              }
      if(this_service->have_retain_nonstatus_information==FALSE && template_service->have_retain_nonstatus_information==TRUE){
            this_service->retain_nonstatus_information=template_service->retain_nonstatus_information;
            this_service->have_retain_nonstatus_information=TRUE;
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_service() end\n");
#endif

      return OK;
        }


/* resolves a hostdependency object */
int xodtemplate_resolve_hostdependency(xodtemplate_hostdependency *this_hostdependency){
      xodtemplate_hostdependency *template_hostdependency;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_hostdependency() start\n");
#endif

      /* return if this hostdependency has already been resolved */
      if(this_hostdependency->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_hostdependency->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_hostdependency->template==NULL)
            return OK;

      template_hostdependency=xodtemplate_find_hostdependency(this_hostdependency->template);
      if(template_hostdependency==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in host dependency definition could not be not found (config file '%s', starting on line %d)\n",this_hostdependency->template,xodtemplate_config_file_name(this_hostdependency->_config_file),this_hostdependency->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template hostdependency... */
      xodtemplate_resolve_hostdependency(template_hostdependency);

      /* apply missing properties from template hostdependency... */
      if(this_hostdependency->hostgroup_name==NULL && template_hostdependency->hostgroup_name!=NULL)
            this_hostdependency->hostgroup_name=strdup(template_hostdependency->hostgroup_name);
      if(this_hostdependency->dependent_hostgroup_name==NULL && template_hostdependency->dependent_hostgroup_name!=NULL)
            this_hostdependency->dependent_hostgroup_name=strdup(template_hostdependency->dependent_hostgroup_name);
      if(this_hostdependency->host_name==NULL && template_hostdependency->host_name!=NULL)
            this_hostdependency->host_name=strdup(template_hostdependency->host_name);
      if(this_hostdependency->dependent_host_name==NULL && template_hostdependency->dependent_host_name!=NULL)
            this_hostdependency->dependent_host_name=strdup(template_hostdependency->dependent_host_name);
      if(this_hostdependency->have_inherits_parent==FALSE && template_hostdependency->have_inherits_parent==TRUE){
            this_hostdependency->inherits_parent=template_hostdependency->inherits_parent;
            this_hostdependency->have_inherits_parent=TRUE;
              }
      if(this_hostdependency->have_execution_dependency_options==FALSE && template_hostdependency->have_execution_dependency_options==TRUE){
            this_hostdependency->fail_execute_on_up=template_hostdependency->fail_execute_on_up;
            this_hostdependency->fail_execute_on_down=template_hostdependency->fail_execute_on_down;
            this_hostdependency->fail_execute_on_unreachable=template_hostdependency->fail_execute_on_unreachable;
            this_hostdependency->fail_execute_on_pending=template_hostdependency->fail_execute_on_pending;
            this_hostdependency->have_execution_dependency_options=TRUE;
              }
      if(this_hostdependency->have_notification_dependency_options==FALSE && template_hostdependency->have_notification_dependency_options==TRUE){
            this_hostdependency->fail_notify_on_up=template_hostdependency->fail_notify_on_up;
            this_hostdependency->fail_notify_on_down=template_hostdependency->fail_notify_on_down;
            this_hostdependency->fail_notify_on_unreachable=template_hostdependency->fail_notify_on_unreachable;
            this_hostdependency->fail_notify_on_pending=template_hostdependency->fail_notify_on_pending;
            this_hostdependency->have_notification_dependency_options=TRUE;
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_hostdependency() end\n");
#endif

      return OK;
        }


/* resolves a hostescalation object */
int xodtemplate_resolve_hostescalation(xodtemplate_hostescalation *this_hostescalation){
      xodtemplate_hostescalation *template_hostescalation;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_hostescalation() start\n");
#endif

      /* return if this hostescalation has already been resolved */
      if(this_hostescalation->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_hostescalation->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_hostescalation->template==NULL)
            return OK;

      template_hostescalation=xodtemplate_find_hostescalation(this_hostescalation->template);
      if(template_hostescalation==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in host escalation definition could not be not found (config file '%s', starting on line %d)\n",this_hostescalation->template,xodtemplate_config_file_name(this_hostescalation->_config_file),this_hostescalation->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template hostescalation... */
      xodtemplate_resolve_hostescalation(template_hostescalation);

      /* apply missing properties from template hostescalation... */
      if(this_hostescalation->host_name==NULL && template_hostescalation->host_name!=NULL)
            this_hostescalation->host_name=strdup(template_hostescalation->host_name);
      if(this_hostescalation->escalation_period==NULL && template_hostescalation->escalation_period!=NULL)
            this_hostescalation->escalation_period=strdup(template_hostescalation->escalation_period);
      if(this_hostescalation->contact_groups==NULL && template_hostescalation->contact_groups!=NULL)
            this_hostescalation->contact_groups=strdup(template_hostescalation->contact_groups);
      if(this_hostescalation->have_first_notification==FALSE && template_hostescalation->have_first_notification==TRUE){
            this_hostescalation->first_notification=template_hostescalation->first_notification;
            this_hostescalation->have_first_notification=TRUE;
              }
      if(this_hostescalation->have_last_notification==FALSE && template_hostescalation->have_last_notification==TRUE){
            this_hostescalation->last_notification=template_hostescalation->last_notification;
            this_hostescalation->have_last_notification=TRUE;
              }
      if(this_hostescalation->have_notification_interval==FALSE && template_hostescalation->have_notification_interval==TRUE){
            this_hostescalation->notification_interval=template_hostescalation->notification_interval;
            this_hostescalation->have_notification_interval=TRUE;
              }
      if(this_hostescalation->have_escalation_options==FALSE && template_hostescalation->have_escalation_options==TRUE){
            this_hostescalation->escalate_on_down=template_hostescalation->escalate_on_down;
            this_hostescalation->escalate_on_unreachable=template_hostescalation->escalate_on_unreachable;
            this_hostescalation->escalate_on_recovery=template_hostescalation->escalate_on_recovery;
            this_hostescalation->have_escalation_options=TRUE;
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_hostdependency() end\n");
#endif

      return OK;
        }



/* resolves a hostextinfo object */
int xodtemplate_resolve_hostextinfo(xodtemplate_hostextinfo *this_hostextinfo){
      xodtemplate_hostextinfo *template_hostextinfo;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_hostextinfo() start\n");
#endif

      /* return if this object has already been resolved */
      if(this_hostextinfo->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_hostextinfo->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_hostextinfo->template==NULL)
            return OK;

      template_hostextinfo=xodtemplate_find_hostextinfo(this_hostextinfo->template);
      if(template_hostextinfo==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in extended host info definition could not be not found (config file '%s', starting on line %d)\n",this_hostextinfo->template,xodtemplate_config_file_name(this_hostextinfo->_config_file),this_hostextinfo->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template hostextinfo... */
      xodtemplate_resolve_hostextinfo(template_hostextinfo);

      /* apply missing properties from template hostextinfo... */
      if(this_hostextinfo->host_name==NULL && template_hostextinfo->host_name!=NULL)
            this_hostextinfo->host_name=strdup(template_hostextinfo->host_name);
      if(this_hostextinfo->hostgroup_name==NULL && template_hostextinfo->hostgroup_name!=NULL)
            this_hostextinfo->hostgroup_name=strdup(template_hostextinfo->hostgroup_name);
      if(this_hostextinfo->notes==NULL && template_hostextinfo->notes!=NULL)
            this_hostextinfo->notes=strdup(template_hostextinfo->notes);
      if(this_hostextinfo->notes_url==NULL && template_hostextinfo->notes_url!=NULL)
            this_hostextinfo->notes_url=strdup(template_hostextinfo->notes_url);
      if(this_hostextinfo->action_url==NULL && template_hostextinfo->action_url!=NULL)
            this_hostextinfo->action_url=strdup(template_hostextinfo->action_url);
      if(this_hostextinfo->icon_image==NULL && template_hostextinfo->icon_image!=NULL)
            this_hostextinfo->icon_image=strdup(template_hostextinfo->icon_image);
      if(this_hostextinfo->icon_image_alt==NULL && template_hostextinfo->icon_image_alt!=NULL)
            this_hostextinfo->icon_image_alt=strdup(template_hostextinfo->icon_image_alt);
      if(this_hostextinfo->vrml_image==NULL && template_hostextinfo->vrml_image!=NULL)
            this_hostextinfo->vrml_image=strdup(template_hostextinfo->vrml_image);
      if(this_hostextinfo->statusmap_image==NULL && template_hostextinfo->statusmap_image!=NULL)
            this_hostextinfo->statusmap_image=strdup(template_hostextinfo->statusmap_image);
      if(this_hostextinfo->have_2d_coords==FALSE && template_hostextinfo->have_2d_coords==TRUE){
            this_hostextinfo->x_2d=template_hostextinfo->x_2d;
            this_hostextinfo->y_2d=template_hostextinfo->y_2d;
            this_hostextinfo->have_2d_coords=TRUE;
              }
      if(this_hostextinfo->have_3d_coords==FALSE && template_hostextinfo->have_3d_coords==TRUE){
            this_hostextinfo->x_3d=template_hostextinfo->x_3d;
            this_hostextinfo->y_3d=template_hostextinfo->y_3d;
            this_hostextinfo->z_3d=template_hostextinfo->z_3d;
            this_hostextinfo->have_3d_coords=TRUE;
              }

#ifdef DEBUG0
      printf("xodtemplate_resolve_hostextinfo() end\n");
#endif

      return OK;
        }



/* resolves a serviceextinfo object */
int xodtemplate_resolve_serviceextinfo(xodtemplate_serviceextinfo *this_serviceextinfo){
      xodtemplate_serviceextinfo *template_serviceextinfo;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_resolve_serviceextinfo() start\n");
#endif

      /* return if this object has already been resolved */
      if(this_serviceextinfo->has_been_resolved==TRUE)
            return OK;

      /* set the resolved flag */
      this_serviceextinfo->has_been_resolved=TRUE;

      /* return if we have no template */
      if(this_serviceextinfo->template==NULL)
            return OK;

      template_serviceextinfo=xodtemplate_find_serviceextinfo(this_serviceextinfo->template);
      if(template_serviceextinfo==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Template '%s' specified in extended service info definition could not be not found (config file '%s', starting on line %d)\n",this_serviceextinfo->template,xodtemplate_config_file_name(this_serviceextinfo->_config_file),this_serviceextinfo->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* resolve the template serviceextinfo... */
      xodtemplate_resolve_serviceextinfo(template_serviceextinfo);

      /* apply missing properties from template serviceextinfo... */
      if(this_serviceextinfo->host_name==NULL && template_serviceextinfo->host_name!=NULL)
            this_serviceextinfo->host_name=strdup(template_serviceextinfo->host_name);
      if(this_serviceextinfo->hostgroup_name==NULL && template_serviceextinfo->hostgroup_name!=NULL)
            this_serviceextinfo->hostgroup_name=strdup(template_serviceextinfo->hostgroup_name);
      if(this_serviceextinfo->service_description==NULL && template_serviceextinfo->service_description!=NULL)
            this_serviceextinfo->service_description=strdup(template_serviceextinfo->service_description);
      if(this_serviceextinfo->notes==NULL && template_serviceextinfo->notes!=NULL)
            this_serviceextinfo->notes=strdup(template_serviceextinfo->notes);
      if(this_serviceextinfo->notes_url==NULL && template_serviceextinfo->notes_url!=NULL)
            this_serviceextinfo->notes_url=strdup(template_serviceextinfo->notes_url);
      if(this_serviceextinfo->action_url==NULL && template_serviceextinfo->action_url!=NULL)
            this_serviceextinfo->action_url=strdup(template_serviceextinfo->action_url);
      if(this_serviceextinfo->icon_image==NULL && template_serviceextinfo->icon_image!=NULL)
            this_serviceextinfo->icon_image=strdup(template_serviceextinfo->icon_image);
      if(this_serviceextinfo->icon_image_alt==NULL && template_serviceextinfo->icon_image_alt!=NULL)
            this_serviceextinfo->icon_image_alt=strdup(template_serviceextinfo->icon_image_alt);

#ifdef DEBUG0
      printf("xodtemplate_resolve_serviceextinfo() end\n");
#endif

      return OK;
        }

#endif



/******************************************************************/
/*************** OBJECT RECOMBOBULATION FUNCTIONS *****************/
/******************************************************************/

#ifdef NSCORE


/* recombobulates contactgroup definitions */
int xodtemplate_recombobulate_contactgroups(void){
      xodtemplate_contact *temp_contact;
      xodtemplate_contactgroup *temp_contactgroup;
      xodtemplate_contactlist *temp_contactlist;
      xodtemplate_contactlist *this_contactlist;
      char *contactgroup_names;
      char *temp_ptr;
      char *new_members;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_recombobulate_contactgroups() start\n");
#endif

      /* This should happen before we expand contactgroup members, to avoid duplicate contact memberships 01/07/2006 EG */
      /* process all contacts that have contactgroup directives */
      for(temp_contact=xodtemplate_contact_list;temp_contact!=NULL;temp_contact=temp_contact->next){

            /* skip contacts without contactgroup directives or contact names */
            if(temp_contact->contactgroups==NULL || temp_contact->contact_name==NULL)
                  continue;

            /* process the list of contactgroups */
            contactgroup_names=strdup(temp_contact->contactgroups);
            if(contactgroup_names==NULL)
                  continue;
            for(temp_ptr=strtok(contactgroup_names,",");temp_ptr;temp_ptr=strtok(NULL,",")){

                  /* strip trailing spaces */
                  strip(temp_ptr);
                  
                  /* find the contactgroup */
                  temp_contactgroup=xodtemplate_find_real_contactgroup(temp_ptr);
                  if(temp_contactgroup==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not find contactgroup '%s' specified in contact '%s' definition (config file '%s', starting on line %d)\n",temp_ptr,temp_contact->contact_name,xodtemplate_config_file_name(temp_contact->_config_file),temp_contact->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        free(contactgroup_names);
                        return ERROR;
                          }

                  /* add this contact to the contactgroup members directive */
                  if(temp_contactgroup->members==NULL)
                        temp_contactgroup->members=strdup(temp_contact->contact_name);
                  else{
                        new_members=(char *)realloc(temp_contactgroup->members,strlen(temp_contactgroup->members)+strlen(temp_contact->contact_name)+2);
                        if(new_members!=NULL){
                              temp_contactgroup->members=new_members;
                              strcat(temp_contactgroup->members,",");
                              strcat(temp_contactgroup->members,temp_contact->contact_name);
                                }
                          }
                    }

            /* free memory */
            free(contactgroup_names);
              }


      /* expand members of all contactgroups - this could be done in xodtemplate_register_contactgroup(), but we can save the CGIs some work if we do it here */
      for(temp_contactgroup=xodtemplate_contactgroup_list;temp_contactgroup;temp_contactgroup=temp_contactgroup->next){

            if(temp_contactgroup->members==NULL)
                  continue;

            /* get list of contacts in the contactgroup */
            temp_contactlist=xodtemplate_expand_contacts(temp_contactgroup->members);

            /* add all members to the contact group */
            if(temp_contactlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand member contacts specified in contactgroup (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_contactgroup->_config_file),temp_contactgroup->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                      }
            free(temp_contactgroup->members);
            temp_contactgroup->members=NULL;
            for(this_contactlist=temp_contactlist;this_contactlist;this_contactlist=this_contactlist->next){

                  /* add this contact to the contactgroup members directive */
                  if(temp_contactgroup->members==NULL)
                        temp_contactgroup->members=strdup(this_contactlist->contact_name);
                  else{
                        new_members=(char *)realloc(temp_contactgroup->members,strlen(temp_contactgroup->members)+strlen(this_contactlist->contact_name)+2);
                        if(new_members!=NULL){
                              temp_contactgroup->members=new_members;
                              strcat(temp_contactgroup->members,",");
                              strcat(temp_contactgroup->members,this_contactlist->contact_name);
                                }
                          }
                      }
            xodtemplate_free_contactlist(temp_contactlist);
              }

#ifdef DEBUG0
      printf("xodtemplate_recombobulate_contactgroups() end\n");
#endif

      return OK;
        }



/* recombobulates hostgroup definitions */
int xodtemplate_recombobulate_hostgroups(void){
      xodtemplate_host *temp_host;
      xodtemplate_hostgroup *temp_hostgroup;
      xodtemplate_hostlist *temp_hostlist;
      xodtemplate_hostlist *this_hostlist;
      char *hostgroup_names;
      char *temp_ptr;
      char *new_members;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_recombobulate_hostgroups() start\n");
#endif

      /* This should happen before we expand hostgroup members, to avoid duplicate host memberships 01/07/2006 EG */
      /* process all hosts that have hostgroup directives */
      for(temp_host=xodtemplate_host_list;temp_host!=NULL;temp_host=temp_host->next){

            /* skip hosts without hostgroup directives or host names */
            if(temp_host->hostgroups==NULL || temp_host->host_name==NULL)
                  continue;

            /* skip hosts that shouldn't be registered */
            if(temp_host->register_object==FALSE)
                  continue;

            /* process the list of hostgroups */
            hostgroup_names=strdup(temp_host->hostgroups);
            if(hostgroup_names==NULL)
                  continue;
            for(temp_ptr=strtok(hostgroup_names,",");temp_ptr;temp_ptr=strtok(NULL,",")){

                  /* strip trailing spaces */
                  strip(temp_ptr);
                  
                  /* find the hostgroup */
                  temp_hostgroup=xodtemplate_find_real_hostgroup(temp_ptr);
                  if(temp_hostgroup==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not find hostgroup '%s' specified in host '%s' definition (config file '%s', starting on line %d)\n",temp_ptr,temp_host->host_name,xodtemplate_config_file_name(temp_host->_config_file),temp_host->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        free(hostgroup_names);
                        return ERROR;
                          }

                  /* add this list to the hostgroup members directive */
                  if(temp_hostgroup->members==NULL)
                        temp_hostgroup->members=strdup(temp_host->host_name);
                  else{
                        new_members=(char *)realloc(temp_hostgroup->members,strlen(temp_hostgroup->members)+strlen(temp_host->host_name)+2);
                        if(new_members!=NULL){
                              temp_hostgroup->members=new_members;
                              strcat(temp_hostgroup->members,",");
                              strcat(temp_hostgroup->members,temp_host->host_name);
                                }
                          }
                    }

            /* free memory */
            free(hostgroup_names);
              }


      /* expand members of all hostgroups - this could be done in xodtemplate_register_hostgroup(), but we can save the CGIs some work if we do it here */
      for(temp_hostgroup=xodtemplate_hostgroup_list;temp_hostgroup;temp_hostgroup=temp_hostgroup->next){

            if(temp_hostgroup->members==NULL)
                  continue;

            /* skip hostgroups that shouldn't be registered */
            if(temp_hostgroup->register_object==FALSE)
                  continue;

            /* get list of hosts in the hostgroup */
            temp_hostlist=xodtemplate_expand_hostgroups_and_hosts(NULL,temp_hostgroup->members);

            /* add all members to the host group */
            if(temp_hostlist==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand member hosts specified in hostgroup (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_hostgroup->_config_file),temp_hostgroup->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                      }
            free(temp_hostgroup->members);
            temp_hostgroup->members=NULL;
            for(this_hostlist=temp_hostlist;this_hostlist;this_hostlist=this_hostlist->next){

                  /* add this host to the hostgroup members directive */
                  if(temp_hostgroup->members==NULL)
                        temp_hostgroup->members=strdup(this_hostlist->host_name);
                  else{
                        new_members=(char *)realloc(temp_hostgroup->members,strlen(temp_hostgroup->members)+strlen(this_hostlist->host_name)+2);
                        if(new_members!=NULL){
                              temp_hostgroup->members=new_members;
                              strcat(temp_hostgroup->members,",");
                              strcat(temp_hostgroup->members,this_hostlist->host_name);
                                }
                          }
                      }
            xodtemplate_free_hostlist(temp_hostlist);
              }

#ifdef DEBUG0
      printf("xodtemplate_recombobulate_hostgroups() end\n");
#endif

      return OK;
        }


/* recombobulates servicegroup definitions */
/***** THIS NEEDS TO BE CALLED AFTER OBJECTS (SERVICES) ARE RESOLVED AND DUPLICATED *****/
int xodtemplate_recombobulate_servicegroups(void){
      xodtemplate_service *temp_service=NULL;
      xodtemplate_servicegroup *temp_servicegroup;
      xodtemplate_servicelist *temp_servicelist;
      xodtemplate_servicelist *this_servicelist;
      char *servicegroup_names;
      char *member_names;
      char *host_name=NULL;
      char *service_description=NULL;
      char *temp_ptr;
      char *temp_ptr2;
      char *new_members;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_recombobulate_servicegroups() start\n");
#endif

      /* This should happen before we expand servicegroup members, to avoid duplicate service memberships 01/07/2006 EG */
      /* process all services that have servicegroup directives */
      for(temp_service=xodtemplate_service_list;temp_service!=NULL;temp_service=temp_service->next){

            /* skip services without servicegroup directives or service names */
            if(temp_service->servicegroups==NULL || temp_service->host_name==NULL || temp_service->service_description==NULL)
                  continue;

            /* skip services that shouldn't be registered */
            if(temp_service->register_object==FALSE)
                  continue;

            /* process the list of servicegroups */
            servicegroup_names=strdup(temp_service->servicegroups);
            if(servicegroup_names==NULL)
                  continue;
            for(temp_ptr=strtok(servicegroup_names,",");temp_ptr;temp_ptr=strtok(NULL,",")){

                  /* strip trailing spaces */
                  strip(temp_ptr);
                  
                  /* find the servicegroup */
                  temp_servicegroup=xodtemplate_find_real_servicegroup(temp_ptr);
                  if(temp_servicegroup==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not find servicegroup '%s' specified in service '%s' on host '%s' definition (config file '%s', starting on line %d)\n",temp_ptr,temp_service->service_description,temp_service->host_name,xodtemplate_config_file_name(temp_service->_config_file),temp_service->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        free(servicegroup_names);
                        return ERROR;
                          }

                  /* add this list to the servicegroup members directive */
                  if(temp_servicegroup->members==NULL){
                        temp_servicegroup->members=(char *)malloc(strlen(temp_service->host_name)+strlen(temp_service->service_description)+2);
                        if(temp_servicegroup->members!=NULL){
                              strcpy(temp_servicegroup->members,temp_service->host_name);
                              strcat(temp_servicegroup->members,",");
                              strcat(temp_servicegroup->members,temp_service->service_description);
                                }
                          }
                  else{
                        new_members=(char *)realloc(temp_servicegroup->members,strlen(temp_servicegroup->members)+strlen(temp_service->host_name)+strlen(temp_service->service_description)+3);
                        if(new_members!=NULL){
                              temp_servicegroup->members=new_members;
                              strcat(temp_servicegroup->members,",");
                              strcat(temp_servicegroup->members,temp_service->host_name);
                              strcat(temp_servicegroup->members,",");
                              strcat(temp_servicegroup->members,temp_service->service_description);
                                }
                          }
                    }
              }


      /* expand members of all servicegroups - this could be done in xodtemplate_register_servicegroup(), but we can save the CGIs some work if we do it here */
      for(temp_servicegroup=xodtemplate_servicegroup_list;temp_servicegroup;temp_servicegroup=temp_servicegroup->next){

            if(temp_servicegroup->members==NULL)
                  continue;

            /* skip servicegroups that shouldn't be registered */
            if(temp_servicegroup->register_object==FALSE)
                  continue;

            member_names=temp_servicegroup->members;
            temp_servicegroup->members=NULL;

            for(temp_ptr=member_names;temp_ptr;temp_ptr=strchr(temp_ptr+1,',')){

                  /* this is the host name */
                  if(host_name==NULL)
                        host_name=strdup((temp_ptr[0]==',')?temp_ptr+1:temp_ptr);

                  /* this is the service description */
                  else{
                        service_description=strdup(temp_ptr+1);

                        /* strsep and strtok cannot be used, as they're used in expand_servicegroups...() */
                        temp_ptr2=strchr(host_name,',');
                        if(temp_ptr2)
                              temp_ptr2[0]='\x0';
                        temp_ptr2=strchr(service_description,',');
                        if(temp_ptr2)
                              temp_ptr2[0]='\x0';

                        /* strip trailing spaces */
                        strip(host_name);
                        strip(service_description);

                        /* get list of services in the servicegroup */
                        temp_servicelist=xodtemplate_expand_servicegroups_and_services(NULL,host_name,service_description);

                        /* add all members to the service group */
                        if(temp_servicelist==NULL){
#ifdef NSCORE
                              snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not expand member services specified in servicegroup (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_servicegroup->_config_file),temp_servicegroup->_start_line);
                              temp_buffer[sizeof(temp_buffer)-1]='\x0';
                              write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                              free(member_names);
                              free(host_name);
                              free(service_description);
                              return ERROR;
                                }

                        for(this_servicelist=temp_servicelist;this_servicelist;this_servicelist=this_servicelist->next){

                              /* add this service to the servicegroup members directive */
                              if(temp_servicegroup->members==NULL){
                                    temp_servicegroup->members=(char *)malloc(strlen(this_servicelist->host_name)+strlen(this_servicelist->service_description)+2);
                                    if(temp_servicegroup!=NULL){
                                          strcpy(temp_servicegroup->members,this_servicelist->host_name);
                                          strcat(temp_servicegroup->members,",");
                                          strcat(temp_servicegroup->members,this_servicelist->service_description);
                                            }
                                      }
                              else{
                                    new_members=(char *)realloc(temp_servicegroup->members,strlen(temp_servicegroup->members)+strlen(this_servicelist->host_name)+strlen(this_servicelist->service_description)+3);
                                    if(new_members!=NULL){
                                          temp_servicegroup->members=new_members;
                                          strcat(temp_servicegroup->members,",");
                                          strcat(temp_servicegroup->members,this_servicelist->host_name);
                                          strcat(temp_servicegroup->members,",");
                                          strcat(temp_servicegroup->members,this_servicelist->service_description);
                                            }
                                      }
                                }
                        xodtemplate_free_servicelist(temp_servicelist);

                        free(host_name);
                        free(service_description);
                        host_name=NULL;
                        service_description=NULL;
                          }
                    }

            free(member_names);

            /* error if there were an odd number of items specified (unmatched host/service pair) */
            if(host_name!=NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Servicegroup members must be specified in <host_name>,<service_description> pairs (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(temp_servicegroup->_config_file),temp_servicegroup->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  free(host_name);
                  return ERROR;
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_recombobulate_servicegroups() end\n");
#endif

      return OK;
        }

#endif



/******************************************************************/
/******************* OBJECT SEARCH FUNCTIONS **********************/
/******************************************************************/

#ifdef NSCORE

/* finds a specific timeperiod object */
xodtemplate_timeperiod *xodtemplate_find_timeperiod(char *name){
      xodtemplate_timeperiod *temp_timeperiod;

      if(name==NULL)
            return NULL;

      for(temp_timeperiod=xodtemplate_timeperiod_list;temp_timeperiod!=NULL;temp_timeperiod=temp_timeperiod->next){
            if(temp_timeperiod->name==NULL)
                  continue;
            if(!strcmp(temp_timeperiod->name,name))
                  break;
              }

      return temp_timeperiod;
        }


/* finds a specific command object */
xodtemplate_command *xodtemplate_find_command(char *name){
      xodtemplate_command *temp_command;

      if(name==NULL)
            return NULL;

      for(temp_command=xodtemplate_command_list;temp_command!=NULL;temp_command=temp_command->next){
            if(temp_command->name==NULL)
                  continue;
            if(!strcmp(temp_command->name,name))
                  break;
              }

      return temp_command;
        }


/* finds a specific contactgroup object */
xodtemplate_contactgroup *xodtemplate_find_contactgroup(char *name){
      xodtemplate_contactgroup *temp_contactgroup;

      if(name==NULL)
            return NULL;

      for(temp_contactgroup=xodtemplate_contactgroup_list;temp_contactgroup!=NULL;temp_contactgroup=temp_contactgroup->next){
            if(temp_contactgroup->name==NULL)
                  continue;
            if(!strcmp(temp_contactgroup->name,name))
                  break;
              }

      return temp_contactgroup;
        }


/* finds a specific contactgroup object by its REAL name, not its TEMPLATE name */
xodtemplate_contactgroup *xodtemplate_find_real_contactgroup(char *name){
      xodtemplate_contactgroup *temp_contactgroup;

      if(name==NULL)
            return NULL;

      for(temp_contactgroup=xodtemplate_contactgroup_list;temp_contactgroup!=NULL;temp_contactgroup=temp_contactgroup->next){
            if(temp_contactgroup->register_object==FALSE)
                  continue;
            if(temp_contactgroup->contactgroup_name==NULL)
                  continue;
            if(!strcmp(temp_contactgroup->contactgroup_name,name))
                  break;
              }

      return temp_contactgroup;
        }


/* finds a specific hostgroup object */
xodtemplate_hostgroup *xodtemplate_find_hostgroup(char *name){
      xodtemplate_hostgroup *temp_hostgroup;

      if(name==NULL)
            return NULL;

      for(temp_hostgroup=xodtemplate_hostgroup_list;temp_hostgroup!=NULL;temp_hostgroup=temp_hostgroup->next){
            if(temp_hostgroup->name==NULL)
                  continue;
            if(!strcmp(temp_hostgroup->name,name))
                  break;
              }

      return temp_hostgroup;
        }


/* finds a specific hostgroup object by its REAL name, not its TEMPLATE name */
xodtemplate_hostgroup *xodtemplate_find_real_hostgroup(char *name){
      xodtemplate_hostgroup *temp_hostgroup;

      if(name==NULL)
            return NULL;

      for(temp_hostgroup=xodtemplate_hostgroup_list;temp_hostgroup!=NULL;temp_hostgroup=temp_hostgroup->next){
            if(temp_hostgroup->register_object==FALSE)
                  continue;
            if(temp_hostgroup->hostgroup_name==NULL)
                  continue;
            if(!strcmp(temp_hostgroup->hostgroup_name,name))
                  break;
              }

      return temp_hostgroup;
        }


/* finds a specific servicegroup object */
xodtemplate_servicegroup *xodtemplate_find_servicegroup(char *name){
      xodtemplate_servicegroup *temp_servicegroup;

      if(name==NULL)
            return NULL;

      for(temp_servicegroup=xodtemplate_servicegroup_list;temp_servicegroup!=NULL;temp_servicegroup=temp_servicegroup->next){
            if(temp_servicegroup->name==NULL)
                  continue;
            if(!strcmp(temp_servicegroup->name,name))
                  break;
              }

      return temp_servicegroup;
        }


/* finds a specific servicegroup object by its REAL name, not its TEMPLATE name */
xodtemplate_servicegroup *xodtemplate_find_real_servicegroup(char *name){
      xodtemplate_servicegroup *temp_servicegroup;

      if(name==NULL)
            return NULL;

      for(temp_servicegroup=xodtemplate_servicegroup_list;temp_servicegroup!=NULL;temp_servicegroup=temp_servicegroup->next){
            if(temp_servicegroup->register_object==FALSE)
                  continue;
            if(temp_servicegroup->servicegroup_name==NULL)
                  continue;
            if(!strcmp(temp_servicegroup->servicegroup_name,name))
                  break;
              }

      return temp_servicegroup;
        }


/* finds a specific servicedependency object */
xodtemplate_servicedependency *xodtemplate_find_servicedependency(char *name){
      xodtemplate_servicedependency *temp_servicedependency;

      if(name==NULL)
            return NULL;

      for(temp_servicedependency=xodtemplate_servicedependency_list;temp_servicedependency!=NULL;temp_servicedependency=temp_servicedependency->next){
            if(temp_servicedependency->name==NULL)
                  continue;
            if(!strcmp(temp_servicedependency->name,name))
                  break;
              }

      return temp_servicedependency;
        }


/* finds a specific serviceescalation object */
xodtemplate_serviceescalation *xodtemplate_find_serviceescalation(char *name){
      xodtemplate_serviceescalation *temp_serviceescalation;

      if(name==NULL)
            return NULL;

      for(temp_serviceescalation=xodtemplate_serviceescalation_list;temp_serviceescalation!=NULL;temp_serviceescalation=temp_serviceescalation->next){
            if(temp_serviceescalation->name==NULL)
                  continue;
            if(!strcmp(temp_serviceescalation->name,name))
                  break;
              }

      return temp_serviceescalation;
        }


/* finds a specific contact object */
xodtemplate_contact *xodtemplate_find_contact(char *name){
      xodtemplate_contact *temp_contact;

      if(name==NULL)
            return NULL;

      for(temp_contact=xodtemplate_contact_list;temp_contact!=NULL;temp_contact=temp_contact->next){
            if(temp_contact->name==NULL)
                  continue;
            if(!strcmp(temp_contact->name,name))
                  break;
              }

      return temp_contact;
        }

/* finds a specific contact object by its REAL name, not its TEMPLATE name */
xodtemplate_contact *xodtemplate_find_real_contact(char *name){
      xodtemplate_contact *temp_contact;

      if(name==NULL)
            return NULL;

      for(temp_contact=xodtemplate_contact_list;temp_contact!=NULL;temp_contact=temp_contact->next){
            if(temp_contact->register_object==FALSE)
                  continue;
            if(temp_contact->contact_name==NULL)
                  continue;
            if(!strcmp(temp_contact->contact_name,name))
                  break;
              }

      return temp_contact;
        }


/* finds a specific host object */
xodtemplate_host *xodtemplate_find_host(char *name){
      xodtemplate_host *temp_host;

      if(name==NULL)
            return NULL;

      for(temp_host=xodtemplate_host_list;temp_host!=NULL;temp_host=temp_host->next){
            if(temp_host->name==NULL)
                  continue;
            if(!strcmp(temp_host->name,name))
                  break;
              }

      return temp_host;
        }


/* finds a specific host object by its REAL name, not its TEMPLATE name */
xodtemplate_host *xodtemplate_find_real_host(char *name){
      xodtemplate_host *temp_host;

      if(name==NULL)
            return NULL;

      for(temp_host=xodtemplate_host_list;temp_host!=NULL;temp_host=temp_host->next){
            if(temp_host->register_object==FALSE)
                  continue;
            if(temp_host->host_name==NULL)
                  continue;
            if(!strcmp(temp_host->host_name,name))
                  break;
              }

      return temp_host;
        }


/* finds a specific hostdependency object */
xodtemplate_hostdependency *xodtemplate_find_hostdependency(char *name){
      xodtemplate_hostdependency *temp_hostdependency;

      if(name==NULL)
            return NULL;

      for(temp_hostdependency=xodtemplate_hostdependency_list;temp_hostdependency!=NULL;temp_hostdependency=temp_hostdependency->next){
            if(temp_hostdependency->name==NULL)
                  continue;
            if(!strcmp(temp_hostdependency->name,name))
                  break;
              }

      return temp_hostdependency;
        }


/* finds a specific hostescalation object */
xodtemplate_hostescalation *xodtemplate_find_hostescalation(char *name){
      xodtemplate_hostescalation *temp_hostescalation;

      if(name==NULL)
            return NULL;

      for(temp_hostescalation=xodtemplate_hostescalation_list;temp_hostescalation!=NULL;temp_hostescalation=temp_hostescalation->next){
            if(temp_hostescalation->name==NULL)
                  continue;
            if(!strcmp(temp_hostescalation->name,name))
                  break;
              }

      return temp_hostescalation;
        }


/* finds a specific hostextinfo object */
xodtemplate_hostextinfo *xodtemplate_find_hostextinfo(char *name){
      xodtemplate_hostextinfo *temp_hostextinfo;

      if(name==NULL)
            return NULL;

      for(temp_hostextinfo=xodtemplate_hostextinfo_list;temp_hostextinfo!=NULL;temp_hostextinfo=temp_hostextinfo->next){
            if(temp_hostextinfo->name==NULL)
                  continue;
            if(!strcmp(temp_hostextinfo->name,name))
                  break;
              }

      return temp_hostextinfo;
        }


/* finds a specific serviceextinfo object */
xodtemplate_serviceextinfo *xodtemplate_find_serviceextinfo(char *name){
      xodtemplate_serviceextinfo *temp_serviceextinfo;

      if(name==NULL)
            return NULL;

      for(temp_serviceextinfo=xodtemplate_serviceextinfo_list;temp_serviceextinfo!=NULL;temp_serviceextinfo=temp_serviceextinfo->next){
            if(temp_serviceextinfo->name==NULL)
                  continue;
            if(!strcmp(temp_serviceextinfo->name,name))
                  break;
              }

      return temp_serviceextinfo;
        }


/* finds a specific service object */
xodtemplate_service *xodtemplate_find_service(char *name){
      xodtemplate_service *temp_service;

      for(temp_service=xodtemplate_service_list;temp_service!=NULL;temp_service=temp_service->next){
            if(temp_service->name==NULL)
                  continue;
            if(!strcmp(temp_service->name,name))
                  break;
              }

      return temp_service;
        }


/* finds a specific service object by its REAL name, not its TEMPLATE name */
xodtemplate_service *xodtemplate_find_real_service(char *host_name, char *service_description){
      xodtemplate_service *temp_service;

      if(host_name==NULL || service_description==NULL || xodtemplate_service_list==NULL)
            return NULL;


      for(temp_service=xodtemplate_service_list;temp_service!=NULL;temp_service=temp_service->next){
            if(temp_service->register_object==FALSE)
                  continue;
            if(temp_service->host_name==NULL || temp_service->service_description==NULL)
                  continue;
            if(!strcmp(host_name,temp_service->host_name) && !strcmp(service_description,temp_service->service_description))
                  break;
              }

      return temp_service;
        }

#endif



/******************************************************************/
/**************** OBJECT REGISTRATION FUNCTIONS *******************/
/******************************************************************/

/* registers object definitions */
int xodtemplate_register_objects(void){
      int result=OK;
      xodtemplate_timeperiod *temp_timeperiod;
      xodtemplate_command *temp_command;
      xodtemplate_contactgroup *temp_contactgroup;
      xodtemplate_hostgroup *temp_hostgroup;
      xodtemplate_servicegroup *temp_servicegroup;
      xodtemplate_contact *temp_contact;
      xodtemplate_host *temp_host;
      xodtemplate_service *temp_service;
      xodtemplate_servicedependency *temp_servicedependency;
      xodtemplate_serviceescalation *temp_serviceescalation;
      xodtemplate_hostdependency *temp_hostdependency;
      xodtemplate_hostescalation *temp_hostescalation;
      xodtemplate_hostextinfo *temp_hostextinfo;
      xodtemplate_serviceextinfo *temp_serviceextinfo;

#ifdef DEBUG0
      printf("xodtemplate_register_objects() start\n");
#endif

      /* register timeperiods */
      for(temp_timeperiod=xodtemplate_timeperiod_list;temp_timeperiod!=NULL;temp_timeperiod=temp_timeperiod->next){
            if((result=xodtemplate_register_timeperiod(temp_timeperiod))==ERROR)
                  return ERROR;
              }

      /* register commands */
      for(temp_command=xodtemplate_command_list;temp_command!=NULL;temp_command=temp_command->next){
            if((result=xodtemplate_register_command(temp_command))==ERROR)
                  return ERROR;
              }

      /* register contactgroups */
      for(temp_contactgroup=xodtemplate_contactgroup_list;temp_contactgroup!=NULL;temp_contactgroup=temp_contactgroup->next){
            if((result=xodtemplate_register_contactgroup(temp_contactgroup))==ERROR)
                  return ERROR;
              }

      /* register hostgroups */
      for(temp_hostgroup=xodtemplate_hostgroup_list;temp_hostgroup!=NULL;temp_hostgroup=temp_hostgroup->next){
            if((result=xodtemplate_register_hostgroup(temp_hostgroup))==ERROR)
                  return ERROR;
              }

      /* register servicegroups */
      for(temp_servicegroup=xodtemplate_servicegroup_list;temp_servicegroup!=NULL;temp_servicegroup=temp_servicegroup->next){
            if((result=xodtemplate_register_servicegroup(temp_servicegroup))==ERROR)
                  return ERROR;
              }

      /* register contacts */
      for(temp_contact=xodtemplate_contact_list;temp_contact!=NULL;temp_contact=temp_contact->next){
            if((result=xodtemplate_register_contact(temp_contact))==ERROR)
                  return ERROR;
              }

      /* register hosts */
      for(temp_host=xodtemplate_host_list;temp_host!=NULL;temp_host=temp_host->next){
            if((result=xodtemplate_register_host(temp_host))==ERROR)
                  return ERROR;
              }

      /* register services */
      for(temp_service=xodtemplate_service_list;temp_service!=NULL;temp_service=temp_service->next){
            if((result=xodtemplate_register_service(temp_service))==ERROR)
                  return ERROR;
              }

      /* register service dependencies */
      for(temp_servicedependency=xodtemplate_servicedependency_list;temp_servicedependency!=NULL;temp_servicedependency=temp_servicedependency->next){
            if((result=xodtemplate_register_servicedependency(temp_servicedependency))==ERROR)
                  return ERROR;
              }

      /* register service escalations */
      for(temp_serviceescalation=xodtemplate_serviceescalation_list;temp_serviceescalation!=NULL;temp_serviceescalation=temp_serviceescalation->next){
            if((result=xodtemplate_register_serviceescalation(temp_serviceescalation))==ERROR)
                  return ERROR;
              }

      /* register host dependencies */
      for(temp_hostdependency=xodtemplate_hostdependency_list;temp_hostdependency!=NULL;temp_hostdependency=temp_hostdependency->next){
            if((result=xodtemplate_register_hostdependency(temp_hostdependency))==ERROR)
                  return ERROR;
              }

      /* register host escalations */
      for(temp_hostescalation=xodtemplate_hostescalation_list;temp_hostescalation!=NULL;temp_hostescalation=temp_hostescalation->next){
            if((result=xodtemplate_register_hostescalation(temp_hostescalation))==ERROR)
                  return ERROR;
              }

      /* register host extended info */
      for(temp_hostextinfo=xodtemplate_hostextinfo_list;temp_hostextinfo!=NULL;temp_hostextinfo=temp_hostextinfo->next){
            if((result=xodtemplate_register_hostextinfo(temp_hostextinfo))==ERROR)
                  return ERROR;
              }

      /* register service extended info */
      for(temp_serviceextinfo=xodtemplate_serviceextinfo_list;temp_serviceextinfo!=NULL;temp_serviceextinfo=temp_serviceextinfo->next){
            if((result=xodtemplate_register_serviceextinfo(temp_serviceextinfo))==ERROR)
                  return ERROR;
              }


#ifdef DEBUG0
      printf("xodtemplate_register_objects() end\n");
#endif

      return OK;
        }



/* registers a timeperiod definition */
int xodtemplate_register_timeperiod(xodtemplate_timeperiod *this_timeperiod){
      timeperiod *new_timeperiod;
      timerange *new_timerange;
      int day;
      char *day_range_ptr;
      char *day_range_start_buffer;
      char *range_ptr;
      char *range_buffer;
      char *time_ptr;
      char *time_buffer;
      int hours;
      int minutes;
      unsigned long range_start_time;
      unsigned long range_end_time;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif
      

#ifdef DEBUG0
      printf("xodtemplate_register_timeperiod() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_timeperiod->register_object==FALSE)
            return OK;

      /* add the timeperiod */
      new_timeperiod=add_timeperiod(this_timeperiod->timeperiod_name,this_timeperiod->alias);

      /* return with an error if we couldn't add the timeperiod */
      if(new_timeperiod==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register timeperiod (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_timeperiod->_config_file),this_timeperiod->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* add all necessary timeranges to timeperiod */
      for(day=0;day<7;day++){

            if(this_timeperiod->timeranges[day]==NULL)
                  continue;

            day_range_ptr=this_timeperiod->timeranges[day];
            for(day_range_start_buffer=my_strsep(&day_range_ptr,", ");day_range_start_buffer!=NULL;day_range_start_buffer=my_strsep(&day_range_ptr,", ")){

                  range_ptr=day_range_start_buffer;
                  range_buffer=my_strsep(&range_ptr,"-");
                  if(range_buffer==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add timerange for day %d to timeperiod (No start time delimiter) (config file '%s', starting on line %d)\n",day,xodtemplate_config_file_name(this_timeperiod->_config_file),this_timeperiod->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }

                  time_ptr=range_buffer;
                  time_buffer=my_strsep(&time_ptr,":");
                  if(time_buffer==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add timerange for day %d to timeperiod (No start time hours) (config file '%s', starting on line %d)\n",day,xodtemplate_config_file_name(this_timeperiod->_config_file),this_timeperiod->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                  hours=atoi(time_buffer);
                  time_buffer=my_strsep(&time_ptr,":");
                  if(time_buffer==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add timerange for day %d to timeperiod (No start time minutes) (config file '%s', starting on line %d)\n",day,xodtemplate_config_file_name(this_timeperiod->_config_file),this_timeperiod->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                  minutes=atoi(time_buffer);

                  /* calculate the range start time in seconds */
                  range_start_time=(unsigned long)((minutes*60)+(hours*60*60));

                  range_buffer=my_strsep(&range_ptr,"-");
                  if(range_buffer==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add timerange for day %d to timeperiod (No end time delimiter) (config file '%s', starting on line %d)\n",day,xodtemplate_config_file_name(this_timeperiod->_config_file),this_timeperiod->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }

                  time_ptr=range_buffer;
                  time_buffer=my_strsep(&time_ptr,":");
                  if(time_buffer==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add timerange for day %d to timeperiod (No end time hours) (config file '%s', starting on line %d)\n",day,xodtemplate_config_file_name(this_timeperiod->_config_file),this_timeperiod->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                  hours=atoi(time_buffer);

                  time_buffer=my_strsep(&time_ptr,":");
                  if(time_buffer==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add timerange for day %d to timeperiod (No end time minutes) (config file '%s', starting on line %d)\n",day,xodtemplate_config_file_name(this_timeperiod->_config_file),this_timeperiod->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                  minutes=atoi(time_buffer);

                  /* calculate the range end time in seconds */
                  range_end_time=(unsigned long)((minutes*60)+(hours*3600));

                  /* add the new time range to the time period */
                  new_timerange=add_timerange_to_timeperiod(new_timeperiod,day,range_start_time,range_end_time);
                  if(new_timerange==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add timerange for day %d to timeperiod (config file '%s', starting on line %d)\n",day,xodtemplate_config_file_name(this_timeperiod->_config_file),this_timeperiod->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                    }
            
              }

#ifdef DEBUG0
      printf("xodtemplate_register_timeperiod() end\n");
#endif

      return OK;
        }



/* registers a command definition */
int xodtemplate_register_command(xodtemplate_command *this_command){
      command *new_command;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_command() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_command->register_object==FALSE)
            return OK;

      /* add the command */
      new_command=add_command(this_command->command_name,this_command->command_line);

      /* return with an error if we couldn't add the command */
      if(new_command==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register command (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_command->_config_file),this_command->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

#ifdef DEBUG0
      printf("xodtemplate_register_command() end\n");
#endif

      return OK;
        }



/* registers a contactgroup definition */
int xodtemplate_register_contactgroup(xodtemplate_contactgroup *this_contactgroup){
      contactgroup *new_contactgroup;
      contactgroupmember *new_contactgroupmember;
      char *contact_name;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_contactgroup() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_contactgroup->register_object==FALSE)
            return OK;

      /* add the contact group */
      new_contactgroup=add_contactgroup(this_contactgroup->contactgroup_name,this_contactgroup->alias);

      /* return with an error if we couldn't add the contactgroup */
      if(new_contactgroup==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register contactgroup (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_contactgroup->_config_file),this_contactgroup->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* add all members to the contact group */
      if(this_contactgroup->members==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Contactgroup has no members (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_contactgroup->_config_file),this_contactgroup->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }
      for(contact_name=strtok(this_contactgroup->members,",");contact_name!=NULL;contact_name=strtok(NULL,",")){
            strip(contact_name);
            new_contactgroupmember=add_contact_to_contactgroup(new_contactgroup,contact_name);
            if(new_contactgroupmember==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add contact '%s' to contactgroup (config file '%s', starting on line %d)\n",contact_name,xodtemplate_config_file_name(this_contactgroup->_config_file),this_contactgroup->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_register_contactgroup() end\n");
#endif

      return OK;
        }



/* registers a hostgroup definition */
int xodtemplate_register_hostgroup(xodtemplate_hostgroup *this_hostgroup){
      hostgroup *new_hostgroup;
      hostgroupmember *new_hostgroupmember;
      char *host_name;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_hostgroup() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_hostgroup->register_object==FALSE)
            return OK;

      /* add the  host group */
      new_hostgroup=add_hostgroup(this_hostgroup->hostgroup_name,this_hostgroup->alias);

      /* return with an error if we couldn't add the hostgroup */
      if(new_hostgroup==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register hostgroup (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_hostgroup->_config_file),this_hostgroup->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* add all members to hostgroup */
      if(this_hostgroup->members==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Hostgroup has no members (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_hostgroup->_config_file),this_hostgroup->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }
      for(host_name=strtok(this_hostgroup->members,",");host_name!=NULL;host_name=strtok(NULL,",")){
            strip(host_name);
            new_hostgroupmember=add_host_to_hostgroup(new_hostgroup,host_name);
            if(new_hostgroupmember==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add host '%s' to hostgroup (config file '%s', starting on line %d)\n",host_name,xodtemplate_config_file_name(this_hostgroup->_config_file),this_hostgroup->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_register_hostgroup() end\n");
#endif

      return OK;
        }



/* registers a servicegroup definition */
int xodtemplate_register_servicegroup(xodtemplate_servicegroup *this_servicegroup){
      servicegroup *new_servicegroup;
      servicegroupmember *new_servicegroupmember;
      char *host_name;
      char *svc_description;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_servicegroup() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_servicegroup->register_object==FALSE)
            return OK;

      /* add the  service group */
      new_servicegroup=add_servicegroup(this_servicegroup->servicegroup_name,this_servicegroup->alias);

      /* return with an error if we couldn't add the servicegroup */
      if(new_servicegroup==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register servicegroup (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_servicegroup->_config_file),this_servicegroup->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* add all members to servicegroup */
      if(this_servicegroup->members==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Servicegroup has no members (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_servicegroup->_config_file),this_servicegroup->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }
      for(host_name=strtok(this_servicegroup->members,",");host_name!=NULL;host_name=strtok(NULL,",")){
            strip(host_name);
            svc_description=strtok(NULL,",");
            if(svc_description==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Missing service name in servicegroup definition (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_servicegroup->_config_file),this_servicegroup->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                      }
            strip(svc_description);

            new_servicegroupmember=add_service_to_servicegroup(new_servicegroup,host_name,svc_description);
            if(new_servicegroupmember==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add service '%s' on host '%s' to servicegroup (config file '%s', starting on line %d)\n",svc_description,host_name,xodtemplate_config_file_name(this_servicegroup->_config_file),this_servicegroup->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_register_servicegroup() end\n");
#endif

      return OK;
        }



/* registers a servicedependency definition */
int xodtemplate_register_servicedependency(xodtemplate_servicedependency *this_servicedependency){
      servicedependency *new_servicedependency;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_servicedependency() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_servicedependency->register_object==FALSE)
            return OK;

      /* throw a warning on servicedeps that have no options */
      if(this_servicedependency->have_notification_dependency_options==FALSE && this_servicedependency->have_execution_dependency_options==FALSE){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Ignoring lame service dependency (config file '%s', line %d)\n",xodtemplate_config_file_name(this_servicedependency->_config_file),this_servicedependency->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
#endif
            return OK;
              }

      /* add the servicedependency */
      if(this_servicedependency->have_execution_dependency_options==TRUE){

            new_servicedependency=add_service_dependency(this_servicedependency->dependent_host_name,this_servicedependency->dependent_service_description,this_servicedependency->host_name,this_servicedependency->service_description,EXECUTION_DEPENDENCY,this_servicedependency->inherits_parent,this_servicedependency->fail_execute_on_ok,this_servicedependency->fail_execute_on_warning,this_servicedependency->fail_execute_on_unknown,this_servicedependency->fail_execute_on_critical,this_servicedependency->fail_execute_on_pending);

            /* return with an error if we couldn't add the servicedependency */
            if(new_servicedependency==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register service execution dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_servicedependency->_config_file),this_servicedependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }
              }
      if(this_servicedependency->have_notification_dependency_options==TRUE){

            new_servicedependency=add_service_dependency(this_servicedependency->dependent_host_name,this_servicedependency->dependent_service_description,this_servicedependency->host_name,this_servicedependency->service_description,NOTIFICATION_DEPENDENCY,this_servicedependency->inherits_parent,this_servicedependency->fail_notify_on_ok,this_servicedependency->fail_notify_on_warning,this_servicedependency->fail_notify_on_unknown,this_servicedependency->fail_notify_on_critical,this_servicedependency->fail_notify_on_pending);

            /* return with an error if we couldn't add the servicedependency */
            if(new_servicedependency==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register service notification dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_servicedependency->_config_file),this_servicedependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_register_servicedependency() end\n");
#endif

      return OK;
        }



/* registers a serviceescalation definition */
int xodtemplate_register_serviceescalation(xodtemplate_serviceescalation *this_serviceescalation){
      serviceescalation *new_serviceescalation;
      contactgroupsmember *new_contactgroupsmember;
      char *contact_group;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_serviceescalation() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_serviceescalation->register_object==FALSE)
            return OK;

      /* default options if none specified */
      if(this_serviceescalation->have_escalation_options==FALSE){
            this_serviceescalation->escalate_on_warning=TRUE;
            this_serviceescalation->escalate_on_unknown=TRUE;
            this_serviceescalation->escalate_on_critical=TRUE;
            this_serviceescalation->escalate_on_recovery=TRUE;
              }

      /* add the serviceescalation */
      new_serviceescalation=add_serviceescalation(this_serviceescalation->host_name,this_serviceescalation->service_description,this_serviceescalation->first_notification,this_serviceescalation->last_notification,this_serviceescalation->notification_interval,this_serviceescalation->escalation_period,this_serviceescalation->escalate_on_warning,this_serviceescalation->escalate_on_unknown,this_serviceescalation->escalate_on_critical,this_serviceescalation->escalate_on_recovery);

      /* return with an error if we couldn't add the serviceescalation */
      if(new_serviceescalation==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register service escalation (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_serviceescalation->_config_file),this_serviceescalation->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* add the contact groups */
      if(this_serviceescalation->contact_groups==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Service escalation has no contact groups (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_serviceescalation->_config_file),this_serviceescalation->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }
      for(contact_group=strtok(this_serviceescalation->contact_groups,", ");contact_group!=NULL;contact_group=strtok(NULL,", ")){
            new_contactgroupsmember=add_contactgroup_to_serviceescalation(new_serviceescalation,contact_group);
            if(new_contactgroupsmember==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add contactgroup '%s' to service escalation (config file '%s', starting on line %d)\n",contact_group,xodtemplate_config_file_name(this_serviceescalation->_config_file),this_serviceescalation->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_register_serviceescalation() end\n");
#endif

      return OK;
        }



/* registers a contact definition */
int xodtemplate_register_contact(xodtemplate_contact *this_contact){
      contact *new_contact;
      char *command_name;
      commandsmember *new_commandsmember;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_contact() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_contact->register_object==FALSE)
            return OK;

      /* add the contact */
      new_contact=add_contact(this_contact->contact_name,this_contact->alias,this_contact->email,this_contact->pager,this_contact->address,this_contact->service_notification_period,this_contact->host_notification_period,this_contact->notify_on_service_recovery,this_contact->notify_on_service_critical,this_contact->notify_on_service_warning,this_contact->notify_on_service_unknown,this_contact->notify_on_service_flapping,this_contact->notify_on_host_recovery,this_contact->notify_on_host_down,this_contact->notify_on_host_unreachable,this_contact->notify_on_host_flapping);

      /* return with an error if we couldn't add the contact */
      if(new_contact==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register contact (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_contact->_config_file),this_contact->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* add all the host notification commands */
      if(this_contact->host_notification_commands!=NULL){

            for(command_name=strtok(this_contact->host_notification_commands,", ");command_name!=NULL;command_name=strtok(NULL,", ")){
                  new_commandsmember=add_host_notification_command_to_contact(new_contact,command_name);
                  if(new_commandsmember==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add host notification command '%s' to contact (config file '%s', starting on line %d)\n",command_name,xodtemplate_config_file_name(this_contact->_config_file),this_contact->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                    }
              }

      /* add all the service notification commands */
      if(this_contact->service_notification_commands!=NULL){

            for(command_name=strtok(this_contact->service_notification_commands,", ");command_name!=NULL;command_name=strtok(NULL,", ")){
                  new_commandsmember=add_service_notification_command_to_contact(new_contact,command_name);
                  if(new_commandsmember==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add service notification command '%s' to contact (config file '%s', starting on line %d)\n",command_name,xodtemplate_config_file_name(this_contact->_config_file),this_contact->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_register_contact() end\n");
#endif

      return OK;
        }



/* registers a host definition */
int xodtemplate_register_host(xodtemplate_host *this_host){
      host *new_host;
      char *parent_host;
      hostsmember *new_hostsmember;
      contactgroupsmember *new_contactgroupsmember;
      char *contact_group;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_host() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_host->register_object==FALSE)
            return OK;

      /* if host has no alias or address, use host name - added 3/11/05 */
      if(this_host->alias==NULL && this_host->host_name!=NULL)
            this_host->alias=strdup(this_host->host_name);
      if(this_host->address==NULL && this_host->host_name!=NULL)
            this_host->address=strdup(this_host->host_name);

      /* add the host definition */
      new_host=add_host(this_host->host_name,this_host->alias,(this_host->address==NULL)?this_host->host_name:this_host->address,this_host->check_period,this_host->check_interval,this_host->max_check_attempts,this_host->notify_on_recovery,this_host->notify_on_down,this_host->notify_on_unreachable,this_host->notify_on_flapping,this_host->notification_interval,this_host->notification_period,this_host->notifications_enabled,this_host->check_command,this_host->active_checks_enabled,this_host->passive_checks_enabled,this_host->event_handler,this_host->event_handler_enabled,this_host->flap_detection_enabled,this_host->low_flap_threshold,this_host->high_flap_threshold,this_host->stalk_on_up,this_host->stalk_on_down,this_host->stalk_on_unreachable,this_host->process_perf_data,this_host->failure_prediction_enabled,this_host->failure_prediction_options,this_host->check_freshness,this_host->freshness_threshold,this_host->retain_status_information,this_host->retain_nonstatus_information,this_host->obsess_over_host);

#ifdef TEST_DEBUG
      printf("HOST: %s, MAXATTEMPTS: %d, NOTINVERVAL: %d \n",this_host->host_name,this_host->max_check_attempts,this_host->notification_interval);
#endif

      /* return with an error if we couldn't add the host */
      if(new_host==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register host (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_host->_config_file),this_host->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* add the parent hosts */
      if(this_host->parents!=NULL){

            for(parent_host=strtok(this_host->parents,",");parent_host!=NULL;parent_host=strtok(NULL,",")){
                  strip(parent_host);
                  new_hostsmember=add_parent_host_to_host(new_host,parent_host);
                  if(new_hostsmember==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add parent host '%s' to host (config file '%s', starting on line %d)\n",parent_host,xodtemplate_config_file_name(this_host->_config_file),this_host->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                    }
              }

      /* add all contact groups to the host group */
      if(this_host->contact_groups!=NULL){

            for(contact_group=strtok(this_host->contact_groups,",");contact_group!=NULL;contact_group=strtok(NULL,",")){

                  strip(contact_group);
                  new_contactgroupsmember=add_contactgroup_to_host(new_host,contact_group);
                  if(new_contactgroupsmember==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add contactgroup '%s' to host (config file '%s', starting on line %d)\n",contact_group,xodtemplate_config_file_name(this_host->_config_file),this_host->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                          }
                      }
              }

#ifdef DEBUG0
      printf("xodtemplate_register_host() end\n");
#endif

      return OK;
        }



/* registers a service definition */
int xodtemplate_register_service(xodtemplate_service *this_service){
      service *new_service;
      contactgroupsmember *new_contactgroupsmember;
      char *contactgroup_name;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_service() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_service->register_object==FALSE)
            return OK;

      /* add the service */
      new_service=add_service(this_service->host_name,this_service->service_description,this_service->check_period,this_service->max_check_attempts,this_service->parallelize_check,this_service->passive_checks_enabled,this_service->normal_check_interval,this_service->retry_check_interval,this_service->notification_interval,this_service->notification_period,this_service->notify_on_recovery,this_service->notify_on_unknown,this_service->notify_on_warning,this_service->notify_on_critical,this_service->notify_on_flapping,this_service->notifications_enabled,this_service->is_volatile,this_service->event_handler,this_service->event_handler_enabled,this_service->check_command,this_service->active_checks_enabled,this_service->flap_detection_enabled,this_service->low_flap_threshold,this_service->high_flap_threshold,this_service->stalk_on_ok,this_service->stalk_on_warning,this_service->stalk_on_unknown,this_service->stalk_on_critical,this_service->process_perf_data,this_service->failure_prediction_enabled,this_service->failure_prediction_options,this_service->check_freshness,this_service->freshness_threshold,this_service->retain_status_information,this_service->retain_nonstatus_information,this_service->obsess_over_service);

      /* return with an error if we couldn't add the service */
      if(new_service==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register service (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_service->_config_file),this_service->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* add all the contact groups to the service */
      if(this_service->contact_groups!=NULL){

            for(contactgroup_name=strtok(this_service->contact_groups,",");contactgroup_name!=NULL;contactgroup_name=strtok(NULL,",")){

                  /* add this contactgroup to the service definition */
                  strip(contactgroup_name);
                  new_contactgroupsmember=add_contactgroup_to_service(new_service,contactgroup_name);

                  /* stop adding contact groups if we ran into an error */
                  if(new_contactgroupsmember==NULL){
#ifdef NSCORE
                        snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add contact group '%s' to service (config file '%s', starting on line %d)\n",contactgroup_name,xodtemplate_config_file_name(this_service->_config_file),this_service->_start_line);
                        temp_buffer[sizeof(temp_buffer)-1]='\x0';
                        write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                        return ERROR;
                            }
                    }
              }


#ifdef DEBUG0
      printf("xodtemplate_register_service() end\n");
#endif

      return OK;
        }



/* registers a hostdependency definition */
int xodtemplate_register_hostdependency(xodtemplate_hostdependency *this_hostdependency){
      hostdependency *new_hostdependency;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_hostdependency() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_hostdependency->register_object==FALSE)
            return OK;

      /* add the host execution dependency */
      if(this_hostdependency->have_execution_dependency_options==TRUE){

            new_hostdependency=add_host_dependency(this_hostdependency->dependent_host_name,this_hostdependency->host_name,EXECUTION_DEPENDENCY,this_hostdependency->inherits_parent,this_hostdependency->fail_execute_on_up,this_hostdependency->fail_execute_on_down,this_hostdependency->fail_execute_on_unreachable,this_hostdependency->fail_execute_on_pending);

            /* return with an error if we couldn't add the hostdependency */
            if(new_hostdependency==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register host execution dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_hostdependency->_config_file),this_hostdependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                        }
              }

      /* add the host notification dependency */
      if(this_hostdependency->have_notification_dependency_options==TRUE){

            new_hostdependency=add_host_dependency(this_hostdependency->dependent_host_name,this_hostdependency->host_name,NOTIFICATION_DEPENDENCY,this_hostdependency->inherits_parent,this_hostdependency->fail_notify_on_up,this_hostdependency->fail_notify_on_down,this_hostdependency->fail_notify_on_unreachable,this_hostdependency->fail_notify_on_pending);

            /* return with an error if we couldn't add the hostdependency */
            if(new_hostdependency==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register host notification dependency (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_hostdependency->_config_file),this_hostdependency->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                        }
              }

#ifdef DEBUG0
      printf("xodtemplate_register_hostdependency() end\n");
#endif

      return OK;
        }



/* registers a hostescalation definition */
int xodtemplate_register_hostescalation(xodtemplate_hostescalation *this_hostescalation){
      hostescalation *new_hostescalation;
      contactgroupsmember *new_contactgroupsmember;
      char *contact_group;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_hostescalation() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_hostescalation->register_object==FALSE)
            return OK;

      /* default options if none specified */
      if(this_hostescalation->have_escalation_options==FALSE){
            this_hostescalation->escalate_on_down=TRUE;
            this_hostescalation->escalate_on_unreachable=TRUE;
            this_hostescalation->escalate_on_recovery=TRUE;
              }

      /* add the hostescalation */
      new_hostescalation=add_hostescalation(this_hostescalation->host_name,this_hostescalation->first_notification,this_hostescalation->last_notification,this_hostescalation->notification_interval,this_hostescalation->escalation_period,this_hostescalation->escalate_on_down,this_hostescalation->escalate_on_unreachable,this_hostescalation->escalate_on_recovery);

      /* return with an error if we couldn't add the hostescalation */
      if(new_hostescalation==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register host escalation (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_hostescalation->_config_file),this_hostescalation->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

      /* add the contact groups */
      if(this_hostescalation->contact_groups==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Host escalation has no contact groups (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_hostescalation->_config_file),this_hostescalation->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }
      for(contact_group=strtok(this_hostescalation->contact_groups,", ");contact_group!=NULL;contact_group=strtok(NULL,", ")){
            new_contactgroupsmember=add_contactgroup_to_hostescalation(new_hostescalation,contact_group);
            if(new_contactgroupsmember==NULL){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not add contactgroup '%s' to host escalation (config file '%s', starting on line %d)\n",contact_group,xodtemplate_config_file_name(this_hostescalation->_config_file),this_hostescalation->_start_line);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  return ERROR;
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_register_hostescalation() end\n");
#endif

      return OK;
        }



/* registers a hostextinfo definition */
int xodtemplate_register_hostextinfo(xodtemplate_hostextinfo *this_hostextinfo){
      hostextinfo *new_hostextinfo;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_hostextinfo() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_hostextinfo->register_object==FALSE)
            return OK;

      /* register the extended host object */
      new_hostextinfo=add_hostextinfo(this_hostextinfo->host_name,this_hostextinfo->notes,this_hostextinfo->notes_url,this_hostextinfo->action_url,this_hostextinfo->icon_image,this_hostextinfo->vrml_image,this_hostextinfo->statusmap_image,this_hostextinfo->icon_image_alt,this_hostextinfo->x_2d,this_hostextinfo->y_2d,this_hostextinfo->x_3d,this_hostextinfo->y_3d,this_hostextinfo->z_3d,this_hostextinfo->have_2d_coords,this_hostextinfo->have_3d_coords);

      /* return with an error if we couldn't add the definition */
      if(new_hostextinfo==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register extended host information (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_hostextinfo->_config_file),this_hostextinfo->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

#ifdef DEBUG0
      printf("xodtemplate_register_hostextinfo() end\n");
#endif

      return OK;
        }



/* registers a serviceextinfo definition */
int xodtemplate_register_serviceextinfo(xodtemplate_serviceextinfo *this_serviceextinfo){
      serviceextinfo *new_serviceextinfo;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_register_serviceextinfo() start\n");
#endif

      /* bail out if we shouldn't register this object */
      if(this_serviceextinfo->register_object==FALSE)
            return OK;

      /* register the extended service object */
      new_serviceextinfo=add_serviceextinfo(this_serviceextinfo->host_name,this_serviceextinfo->service_description,this_serviceextinfo->notes,this_serviceextinfo->notes_url,this_serviceextinfo->action_url,this_serviceextinfo->icon_image,this_serviceextinfo->icon_image_alt);

      /* return with an error if we couldn't add the definition */
      if(new_serviceextinfo==NULL){
#ifdef NSCORE
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not register extended service information (config file '%s', starting on line %d)\n",xodtemplate_config_file_name(this_serviceextinfo->_config_file),this_serviceextinfo->_start_line);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
            return ERROR;
              }

#ifdef DEBUG0
      printf("xodtemplate_register_serviceextinfo() end\n");
#endif

      return OK;
        }



/******************************************************************/
/********************** SORTING FUNCTIONS *************************/
/******************************************************************/

#ifdef NSCORE

/* sorts all objects by name */
int xodtemplate_sort_objects(void){

#ifdef DEBUG0
      printf("xodtemplate_sort_objects() start\n");
#endif

      /* sort timeperiods */
      if(xodtemplate_sort_timeperiods()==ERROR)
            return ERROR;

      /* sort commands */
      if(xodtemplate_sort_commands()==ERROR)
            return ERROR;

      /* sort contactgroups */
      if(xodtemplate_sort_contactgroups()==ERROR)
            return ERROR;

      /* sort hostgroups */
      if(xodtemplate_sort_hostgroups()==ERROR)
            return ERROR;

      /* sort servicegroups */
      if(xodtemplate_sort_servicegroups()==ERROR)
            return ERROR;

      /* sort contacts */
      if(xodtemplate_sort_contacts()==ERROR)
            return ERROR;

      /* sort hosts */
      if(xodtemplate_sort_hosts()==ERROR)
            return ERROR;

      /* sort services */
      if(xodtemplate_sort_services()==ERROR)
            return ERROR;

      /* sort service dependencies */
      if(xodtemplate_sort_servicedependencies()==ERROR)
            return ERROR;

      /* sort service escalations */
      if(xodtemplate_sort_serviceescalations()==ERROR)
            return ERROR;

      /* sort host dependencies */
      if(xodtemplate_sort_hostdependencies()==ERROR)
            return ERROR;

      /* sort hostescalations */
      if(xodtemplate_sort_hostescalations()==ERROR)
            return ERROR;

      /* sort host extended info */
      if(xodtemplate_sort_hostextinfo()==ERROR)
            return ERROR;

      /* sort service extended info */
      if(xodtemplate_sort_serviceextinfo()==ERROR)
            return ERROR;

#ifdef DEBUG0
      printf("xodtemplate_sort_objects() end\n");
#endif

      return OK;
      }


/* used to compare two strings (object names) */
int xodtemplate_compare_strings1(char *string1, char *string2){
      
      if(string1==NULL && string2==NULL)
            return 0;
      else if(string1==NULL)
            return -1;
      else if(string2==NULL)
            return 1;
      else
            return strcmp(string1,string2);
      }


/* used to compare two sets of strings (dually-named objects, i.e. services) */
int xodtemplate_compare_strings2(char *string1a, char *string1b, char *string2a, char *string2b){
      int result;

      if((result=xodtemplate_compare_strings1(string1a,string2a))==0)
            result=xodtemplate_compare_strings1(string1b,string2b);

      return result;
      }


/* sort timeperiods by name */
int xodtemplate_sort_timeperiods(){
      xodtemplate_timeperiod *new_timeperiod_list=NULL;
      xodtemplate_timeperiod *temp_timeperiod=NULL;
      xodtemplate_timeperiod *last_timeperiod=NULL;
      xodtemplate_timeperiod *temp_timeperiod_orig=NULL;
      xodtemplate_timeperiod *next_timeperiod_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_timeperiods() start\n");
#endif

      /* sort all existing timeperiods */
      for(temp_timeperiod_orig=xodtemplate_timeperiod_list;temp_timeperiod_orig!=NULL;temp_timeperiod_orig=next_timeperiod_orig){

            next_timeperiod_orig=temp_timeperiod_orig->next;

            /* add timeperiod to new list, sorted by timeperiod name */
            last_timeperiod=new_timeperiod_list;
            for(temp_timeperiod=new_timeperiod_list;temp_timeperiod!=NULL;temp_timeperiod=temp_timeperiod->next){

                  if(xodtemplate_compare_strings1(temp_timeperiod_orig->timeperiod_name,temp_timeperiod->timeperiod_name)<=0)
                        break;
                  else
                        last_timeperiod=temp_timeperiod;
                  }

            /* first item added to new sorted list */
            if(new_timeperiod_list==NULL){
                  temp_timeperiod_orig->next=NULL;
                  new_timeperiod_list=temp_timeperiod_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_timeperiod==new_timeperiod_list){
                  temp_timeperiod_orig->next=new_timeperiod_list;
                  new_timeperiod_list=temp_timeperiod_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_timeperiod_orig->next=temp_timeperiod;
                  last_timeperiod->next=temp_timeperiod_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_timeperiod_list=new_timeperiod_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_timeperiods() end\n");
#endif

      return OK;
      }


/* sort commands by name */
int xodtemplate_sort_commands(){
      xodtemplate_command *new_command_list=NULL;
      xodtemplate_command *temp_command=NULL;
      xodtemplate_command *last_command=NULL;
      xodtemplate_command *temp_command_orig=NULL;
      xodtemplate_command *next_command_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_commands() start\n");
#endif

      /* sort all existing commands */
      for(temp_command_orig=xodtemplate_command_list;temp_command_orig!=NULL;temp_command_orig=next_command_orig){

            next_command_orig=temp_command_orig->next;

            /* add command to new list, sorted by command name */
            last_command=new_command_list;
            for(temp_command=new_command_list;temp_command!=NULL;temp_command=temp_command->next){

                  if(xodtemplate_compare_strings1(temp_command_orig->command_name,temp_command->command_name)<=0)
                        break;
                  else
                        last_command=temp_command;
                  }

            /* first item added to new sorted list */
            if(new_command_list==NULL){
                  temp_command_orig->next=NULL;
                  new_command_list=temp_command_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_command==new_command_list){
                  temp_command_orig->next=new_command_list;
                  new_command_list=temp_command_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_command_orig->next=temp_command;
                  last_command->next=temp_command_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_command_list=new_command_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_commands() end\n");
#endif

      return OK;
      }


/* sort contactgroups by name */
int xodtemplate_sort_contactgroups(){
      xodtemplate_contactgroup *new_contactgroup_list=NULL;
      xodtemplate_contactgroup *temp_contactgroup=NULL;
      xodtemplate_contactgroup *last_contactgroup=NULL;
      xodtemplate_contactgroup *temp_contactgroup_orig=NULL;
      xodtemplate_contactgroup *next_contactgroup_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_contactgroups() start\n");
#endif

      /* sort all existing contactgroups */
      for(temp_contactgroup_orig=xodtemplate_contactgroup_list;temp_contactgroup_orig!=NULL;temp_contactgroup_orig=next_contactgroup_orig){

            next_contactgroup_orig=temp_contactgroup_orig->next;

            /* add contactgroup to new list, sorted by contactgroup name */
            last_contactgroup=new_contactgroup_list;
            for(temp_contactgroup=new_contactgroup_list;temp_contactgroup!=NULL;temp_contactgroup=temp_contactgroup->next){

                  if(xodtemplate_compare_strings1(temp_contactgroup_orig->contactgroup_name,temp_contactgroup->contactgroup_name)<=0)
                        break;
                  else
                        last_contactgroup=temp_contactgroup;
                  }

            /* first item added to new sorted list */
            if(new_contactgroup_list==NULL){
                  temp_contactgroup_orig->next=NULL;
                  new_contactgroup_list=temp_contactgroup_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_contactgroup==new_contactgroup_list){
                  temp_contactgroup_orig->next=new_contactgroup_list;
                  new_contactgroup_list=temp_contactgroup_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_contactgroup_orig->next=temp_contactgroup;
                  last_contactgroup->next=temp_contactgroup_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_contactgroup_list=new_contactgroup_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_contactgroups() end\n");
#endif

      return OK;
      }


/* sort hostgroups by name */
int xodtemplate_sort_hostgroups(){
      xodtemplate_hostgroup *new_hostgroup_list=NULL;
      xodtemplate_hostgroup *temp_hostgroup=NULL;
      xodtemplate_hostgroup *last_hostgroup=NULL;
      xodtemplate_hostgroup *temp_hostgroup_orig=NULL;
      xodtemplate_hostgroup *next_hostgroup_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_hostgroups() start\n");
#endif

      /* sort all existing hostgroups */
      for(temp_hostgroup_orig=xodtemplate_hostgroup_list;temp_hostgroup_orig!=NULL;temp_hostgroup_orig=next_hostgroup_orig){

            next_hostgroup_orig=temp_hostgroup_orig->next;

            /* add hostgroup to new list, sorted by hostgroup name */
            last_hostgroup=new_hostgroup_list;
            for(temp_hostgroup=new_hostgroup_list;temp_hostgroup!=NULL;temp_hostgroup=temp_hostgroup->next){

                  if(xodtemplate_compare_strings1(temp_hostgroup_orig->hostgroup_name,temp_hostgroup->hostgroup_name)<=0)
                        break;
                  else
                        last_hostgroup=temp_hostgroup;
                  }

            /* first item added to new sorted list */
            if(new_hostgroup_list==NULL){
                  temp_hostgroup_orig->next=NULL;
                  new_hostgroup_list=temp_hostgroup_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_hostgroup==new_hostgroup_list){
                  temp_hostgroup_orig->next=new_hostgroup_list;
                  new_hostgroup_list=temp_hostgroup_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_hostgroup_orig->next=temp_hostgroup;
                  last_hostgroup->next=temp_hostgroup_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_hostgroup_list=new_hostgroup_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_hostgroups() end\n");
#endif

      return OK;
      }


/* sort servicegroups by name */
int xodtemplate_sort_servicegroups(){
      xodtemplate_servicegroup *new_servicegroup_list=NULL;
      xodtemplate_servicegroup *temp_servicegroup=NULL;
      xodtemplate_servicegroup *last_servicegroup=NULL;
      xodtemplate_servicegroup *temp_servicegroup_orig=NULL;
      xodtemplate_servicegroup *next_servicegroup_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_servicegroups() start\n");
#endif

      /* sort all existing servicegroups */
      for(temp_servicegroup_orig=xodtemplate_servicegroup_list;temp_servicegroup_orig!=NULL;temp_servicegroup_orig=next_servicegroup_orig){

            next_servicegroup_orig=temp_servicegroup_orig->next;

            /* add servicegroup to new list, sorted by servicegroup name */
            last_servicegroup=new_servicegroup_list;
            for(temp_servicegroup=new_servicegroup_list;temp_servicegroup!=NULL;temp_servicegroup=temp_servicegroup->next){

                  if(xodtemplate_compare_strings1(temp_servicegroup_orig->servicegroup_name,temp_servicegroup->servicegroup_name)<=0)
                        break;
                  else
                        last_servicegroup=temp_servicegroup;
                  }

            /* first item added to new sorted list */
            if(new_servicegroup_list==NULL){
                  temp_servicegroup_orig->next=NULL;
                  new_servicegroup_list=temp_servicegroup_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_servicegroup==new_servicegroup_list){
                  temp_servicegroup_orig->next=new_servicegroup_list;
                  new_servicegroup_list=temp_servicegroup_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_servicegroup_orig->next=temp_servicegroup;
                  last_servicegroup->next=temp_servicegroup_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_servicegroup_list=new_servicegroup_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_servicegroups() end\n");
#endif

      return OK;
      }


/* sort contacts by name */
int xodtemplate_sort_contacts(){
      xodtemplate_contact *new_contact_list=NULL;
      xodtemplate_contact *temp_contact=NULL;
      xodtemplate_contact *last_contact=NULL;
      xodtemplate_contact *temp_contact_orig=NULL;
      xodtemplate_contact *next_contact_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_contacts() start\n");
#endif

      /* sort all existing contacts */
      for(temp_contact_orig=xodtemplate_contact_list;temp_contact_orig!=NULL;temp_contact_orig=next_contact_orig){

            next_contact_orig=temp_contact_orig->next;

            /* add contact to new list, sorted by contact name */
            last_contact=new_contact_list;
            for(temp_contact=new_contact_list;temp_contact!=NULL;temp_contact=temp_contact->next){

                  if(xodtemplate_compare_strings1(temp_contact_orig->contact_name,temp_contact->contact_name)<=0)
                        break;
                  else
                        last_contact=temp_contact;
                  }

            /* first item added to new sorted list */
            if(new_contact_list==NULL){
                  temp_contact_orig->next=NULL;
                  new_contact_list=temp_contact_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_contact==new_contact_list){
                  temp_contact_orig->next=new_contact_list;
                  new_contact_list=temp_contact_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_contact_orig->next=temp_contact;
                  last_contact->next=temp_contact_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_contact_list=new_contact_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_contacts() end\n");
#endif

      return OK;
      }


/* sort hosts by name */
int xodtemplate_sort_hosts(){
      xodtemplate_host *new_host_list=NULL;
      xodtemplate_host *temp_host=NULL;
      xodtemplate_host *last_host=NULL;
      xodtemplate_host *temp_host_orig=NULL;
      xodtemplate_host *next_host_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_hosts() start\n");
#endif

      /* sort all existing hosts */
      for(temp_host_orig=xodtemplate_host_list;temp_host_orig!=NULL;temp_host_orig=next_host_orig){

            next_host_orig=temp_host_orig->next;

            /* add host to new list, sorted by host name */
            last_host=new_host_list;
            for(temp_host=new_host_list;temp_host!=NULL;temp_host=temp_host->next){

                  if(xodtemplate_compare_strings1(temp_host_orig->host_name,temp_host->host_name)<=0)
                        break;
                  else
                        last_host=temp_host;
                  }

            /* first item added to new sorted list */
            if(new_host_list==NULL){
                  temp_host_orig->next=NULL;
                  new_host_list=temp_host_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_host==new_host_list){
                  temp_host_orig->next=new_host_list;
                  new_host_list=temp_host_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_host_orig->next=temp_host;
                  last_host->next=temp_host_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_host_list=new_host_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_hosts() end\n");
#endif

      return OK;
      }


/* sort services by name */
int xodtemplate_sort_services(){
      xodtemplate_service *new_service_list=NULL;
      xodtemplate_service *temp_service=NULL;
      xodtemplate_service *last_service=NULL;
      xodtemplate_service *temp_service_orig=NULL;
      xodtemplate_service *next_service_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_services() start\n");
#endif

      /* sort all existing services */
      for(temp_service_orig=xodtemplate_service_list;temp_service_orig!=NULL;temp_service_orig=next_service_orig){

            next_service_orig=temp_service_orig->next;

            /* add service to new list, sorted by host name then service description */
            last_service=new_service_list;
            for(temp_service=new_service_list;temp_service!=NULL;temp_service=temp_service->next){

                  if(xodtemplate_compare_strings2(temp_service_orig->host_name,temp_service_orig->service_description,temp_service->host_name,temp_service->service_description)<=0)
                        break;
                  else
                        last_service=temp_service;
                  }

            /* first item added to new sorted list */
            if(new_service_list==NULL){
                  temp_service_orig->next=NULL;
                  new_service_list=temp_service_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_service==new_service_list){
                  temp_service_orig->next=new_service_list;
                  new_service_list=temp_service_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_service_orig->next=temp_service;
                  last_service->next=temp_service_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_service_list=new_service_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_services() end\n");
#endif

      return OK;
      }


/* sort servicedependencies by name */
int xodtemplate_sort_servicedependencies(){
      xodtemplate_servicedependency *new_servicedependency_list=NULL;
      xodtemplate_servicedependency *temp_servicedependency=NULL;
      xodtemplate_servicedependency *last_servicedependency=NULL;
      xodtemplate_servicedependency *temp_servicedependency_orig=NULL;
      xodtemplate_servicedependency *next_servicedependency_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_servicedependencies() start\n");
#endif

      /* sort all existing servicedependencies */
      for(temp_servicedependency_orig=xodtemplate_servicedependency_list;temp_servicedependency_orig!=NULL;temp_servicedependency_orig=next_servicedependency_orig){

            next_servicedependency_orig=temp_servicedependency_orig->next;

            /* add servicedependency to new list, sorted by host name then service description */
            last_servicedependency=new_servicedependency_list;
            for(temp_servicedependency=new_servicedependency_list;temp_servicedependency!=NULL;temp_servicedependency=temp_servicedependency->next){

                  if(xodtemplate_compare_strings2(temp_servicedependency_orig->host_name,temp_servicedependency_orig->service_description,temp_servicedependency->host_name,temp_servicedependency->service_description)<=0)
                        break;
                  else
                        last_servicedependency=temp_servicedependency;
                  }

            /* first item added to new sorted list */
            if(new_servicedependency_list==NULL){
                  temp_servicedependency_orig->next=NULL;
                  new_servicedependency_list=temp_servicedependency_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_servicedependency==new_servicedependency_list){
                  temp_servicedependency_orig->next=new_servicedependency_list;
                  new_servicedependency_list=temp_servicedependency_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_servicedependency_orig->next=temp_servicedependency;
                  last_servicedependency->next=temp_servicedependency_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_servicedependency_list=new_servicedependency_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_servicedependencies() end\n");
#endif

      return OK;
      }


/* sort serviceescalations by name */
int xodtemplate_sort_serviceescalations(){
      xodtemplate_serviceescalation *new_serviceescalation_list=NULL;
      xodtemplate_serviceescalation *temp_serviceescalation=NULL;
      xodtemplate_serviceescalation *last_serviceescalation=NULL;
      xodtemplate_serviceescalation *temp_serviceescalation_orig=NULL;
      xodtemplate_serviceescalation *next_serviceescalation_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_serviceescalations() start\n");
#endif

      /* sort all existing serviceescalations */
      for(temp_serviceescalation_orig=xodtemplate_serviceescalation_list;temp_serviceescalation_orig!=NULL;temp_serviceescalation_orig=next_serviceescalation_orig){

            next_serviceescalation_orig=temp_serviceescalation_orig->next;

            /* add serviceescalation to new list, sorted by host name then service description */
            last_serviceescalation=new_serviceescalation_list;
            for(temp_serviceescalation=new_serviceescalation_list;temp_serviceescalation!=NULL;temp_serviceescalation=temp_serviceescalation->next){

                  if(xodtemplate_compare_strings2(temp_serviceescalation_orig->host_name,temp_serviceescalation_orig->service_description,temp_serviceescalation->host_name,temp_serviceescalation->service_description)<=0)
                        break;
                  else
                        last_serviceescalation=temp_serviceescalation;
                  }

            /* first item added to new sorted list */
            if(new_serviceescalation_list==NULL){
                  temp_serviceescalation_orig->next=NULL;
                  new_serviceescalation_list=temp_serviceescalation_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_serviceescalation==new_serviceescalation_list){
                  temp_serviceescalation_orig->next=new_serviceescalation_list;
                  new_serviceescalation_list=temp_serviceescalation_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_serviceescalation_orig->next=temp_serviceescalation;
                  last_serviceescalation->next=temp_serviceescalation_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_serviceescalation_list=new_serviceescalation_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_serviceescalations() end\n");
#endif

      return OK;
      }


/* sort hostescalations by name */
int xodtemplate_sort_hostescalations(){
      xodtemplate_hostescalation *new_hostescalation_list=NULL;
      xodtemplate_hostescalation *temp_hostescalation=NULL;
      xodtemplate_hostescalation *last_hostescalation=NULL;
      xodtemplate_hostescalation *temp_hostescalation_orig=NULL;
      xodtemplate_hostescalation *next_hostescalation_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_hostescalations() start\n");
#endif

      /* sort all existing hostescalations */
      for(temp_hostescalation_orig=xodtemplate_hostescalation_list;temp_hostescalation_orig!=NULL;temp_hostescalation_orig=next_hostescalation_orig){

            next_hostescalation_orig=temp_hostescalation_orig->next;

            /* add hostescalation to new list, sorted by host name then hostescalation description */
            last_hostescalation=new_hostescalation_list;
            for(temp_hostescalation=new_hostescalation_list;temp_hostescalation!=NULL;temp_hostescalation=temp_hostescalation->next){

                  if(xodtemplate_compare_strings1(temp_hostescalation_orig->host_name,temp_hostescalation->host_name)<=0)
                        break;
                  else
                        last_hostescalation=temp_hostescalation;
                  }

            /* first item added to new sorted list */
            if(new_hostescalation_list==NULL){
                  temp_hostescalation_orig->next=NULL;
                  new_hostescalation_list=temp_hostescalation_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_hostescalation==new_hostescalation_list){
                  temp_hostescalation_orig->next=new_hostescalation_list;
                  new_hostescalation_list=temp_hostescalation_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_hostescalation_orig->next=temp_hostescalation;
                  last_hostescalation->next=temp_hostescalation_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_hostescalation_list=new_hostescalation_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_hostescalations() end\n");
#endif

      return OK;
      }


/* sort hostdependencies by name */
int xodtemplate_sort_hostdependencies(){
      xodtemplate_hostdependency *new_hostdependency_list=NULL;
      xodtemplate_hostdependency *temp_hostdependency=NULL;
      xodtemplate_hostdependency *last_hostdependency=NULL;
      xodtemplate_hostdependency *temp_hostdependency_orig=NULL;
      xodtemplate_hostdependency *next_hostdependency_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_hostdependencies() start\n");
#endif

      /* sort all existing hostdependencys */
      for(temp_hostdependency_orig=xodtemplate_hostdependency_list;temp_hostdependency_orig!=NULL;temp_hostdependency_orig=next_hostdependency_orig){

            next_hostdependency_orig=temp_hostdependency_orig->next;

            /* add hostdependency to new list, sorted by host name then hostdependency description */
            last_hostdependency=new_hostdependency_list;
            for(temp_hostdependency=new_hostdependency_list;temp_hostdependency!=NULL;temp_hostdependency=temp_hostdependency->next){

                  if(xodtemplate_compare_strings1(temp_hostdependency_orig->host_name,temp_hostdependency->host_name)<=0)
                        break;
                  else
                        last_hostdependency=temp_hostdependency;
                  }

            /* first item added to new sorted list */
            if(new_hostdependency_list==NULL){
                  temp_hostdependency_orig->next=NULL;
                  new_hostdependency_list=temp_hostdependency_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_hostdependency==new_hostdependency_list){
                  temp_hostdependency_orig->next=new_hostdependency_list;
                  new_hostdependency_list=temp_hostdependency_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_hostdependency_orig->next=temp_hostdependency;
                  last_hostdependency->next=temp_hostdependency_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_hostdependency_list=new_hostdependency_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_hostdependencies() end\n");
#endif

      return OK;
      }


/* sort extended host info by name */
int xodtemplate_sort_hostextinfo(){
      xodtemplate_hostextinfo *new_hostextinfo_list=NULL;
      xodtemplate_hostextinfo *temp_hostextinfo=NULL;
      xodtemplate_hostextinfo *last_hostextinfo=NULL;
      xodtemplate_hostextinfo *temp_hostextinfo_orig=NULL;
      xodtemplate_hostextinfo *next_hostextinfo_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_hostextinfo() start\n");
#endif

      /* sort all existing existing host info */
      for(temp_hostextinfo_orig=xodtemplate_hostextinfo_list;temp_hostextinfo_orig!=NULL;temp_hostextinfo_orig=next_hostextinfo_orig){

            next_hostextinfo_orig=temp_hostextinfo_orig->next;

            /* add hostextinfo to new list, sorted by host name then hostextinfo description */
            last_hostextinfo=new_hostextinfo_list;
            for(temp_hostextinfo=new_hostextinfo_list;temp_hostextinfo!=NULL;temp_hostextinfo=temp_hostextinfo->next){

                  if(xodtemplate_compare_strings1(temp_hostextinfo_orig->host_name,temp_hostextinfo->host_name)<=0)
                        break;
                  else
                        last_hostextinfo=temp_hostextinfo;
                  }

            /* first item added to new sorted list */
            if(new_hostextinfo_list==NULL){
                  temp_hostextinfo_orig->next=NULL;
                  new_hostextinfo_list=temp_hostextinfo_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_hostextinfo==new_hostextinfo_list){
                  temp_hostextinfo_orig->next=new_hostextinfo_list;
                  new_hostextinfo_list=temp_hostextinfo_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_hostextinfo_orig->next=temp_hostextinfo;
                  last_hostextinfo->next=temp_hostextinfo_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_hostextinfo_list=new_hostextinfo_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_hostextinfo() end\n");
#endif

      return OK;
      }


/* sort extended service info by name */
int xodtemplate_sort_serviceextinfo(){
      xodtemplate_serviceextinfo *new_serviceextinfo_list=NULL;
      xodtemplate_serviceextinfo *temp_serviceextinfo=NULL;
      xodtemplate_serviceextinfo *last_serviceextinfo=NULL;
      xodtemplate_serviceextinfo *temp_serviceextinfo_orig=NULL;
      xodtemplate_serviceextinfo *next_serviceextinfo_orig=NULL;

#ifdef DEBUG0
      printf("xodtemplate_sort_serviceextinfo() start\n");
#endif

      /* sort all existing extended service info */
      for(temp_serviceextinfo_orig=xodtemplate_serviceextinfo_list;temp_serviceextinfo_orig!=NULL;temp_serviceextinfo_orig=next_serviceextinfo_orig){

            next_serviceextinfo_orig=temp_serviceextinfo_orig->next;

            /* add serviceextinfo to new list, sorted by host name then service description */
            last_serviceextinfo=new_serviceextinfo_list;
            for(temp_serviceextinfo=new_serviceextinfo_list;temp_serviceextinfo!=NULL;temp_serviceextinfo=temp_serviceextinfo->next){

                  if(xodtemplate_compare_strings2(temp_serviceextinfo_orig->host_name,temp_serviceextinfo_orig->service_description,temp_serviceextinfo->host_name,temp_serviceextinfo->service_description)<=0)
                        break;
                  else
                        last_serviceextinfo=temp_serviceextinfo;
                  }

            /* first item added to new sorted list */
            if(new_serviceextinfo_list==NULL){
                  temp_serviceextinfo_orig->next=NULL;
                  new_serviceextinfo_list=temp_serviceextinfo_orig;
                  }

            /* item goes at head of new sorted list */
            else if(temp_serviceextinfo==new_serviceextinfo_list){
                  temp_serviceextinfo_orig->next=new_serviceextinfo_list;
                  new_serviceextinfo_list=temp_serviceextinfo_orig;
                  }

            /* item goes in middle or at end of new sorted list */
            else{
                  temp_serviceextinfo_orig->next=temp_serviceextinfo;
                  last_serviceextinfo->next=temp_serviceextinfo_orig;
                  }
              }

      /* list is now sorted */
      xodtemplate_serviceextinfo_list=new_serviceextinfo_list;

#ifdef DEBUG0
      printf("xodtemplate_sort_serviceextinfo() end\n");
#endif

      return OK;
      }

#endif



/******************************************************************/
/*********************** CACHE FUNCTIONS **************************/
/******************************************************************/

#ifdef NSCORE

/* writes cached object definitions for use by web interface */
int xodtemplate_cache_objects(char *cache_file){
      FILE *fp;
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
      int x;
      char *days[7]={"sunday","monday","tuesday","wednesday","thursday","friday","saturday"};
      xodtemplate_timeperiod *temp_timeperiod;
      xodtemplate_command *temp_command;
      xodtemplate_contactgroup *temp_contactgroup;
      xodtemplate_hostgroup *temp_hostgroup;
      xodtemplate_servicegroup *temp_servicegroup;
      xodtemplate_contact *temp_contact;
      xodtemplate_host *temp_host;
      xodtemplate_service *temp_service;
      xodtemplate_servicedependency *temp_servicedependency;
      xodtemplate_serviceescalation *temp_serviceescalation;
      xodtemplate_hostdependency *temp_hostdependency;
      xodtemplate_hostescalation *temp_hostescalation;
      xodtemplate_hostextinfo *temp_hostextinfo;
      xodtemplate_serviceextinfo *temp_serviceextinfo;
      time_t current_time;

#ifdef DEBUG0
      printf("xodtemplate_cache_objects() start\n");
#endif

      time(&current_time);

      /* open the cache file for writing */
      fp=fopen(cache_file,"w");
      if(fp==NULL){
            snprintf(temp_buffer,sizeof(temp_buffer)-1,"Warning: Could not open object cache file '%s' for writing!\n",cache_file);
            temp_buffer[sizeof(temp_buffer)-1]='\x0';
            write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_WARNING,TRUE);
            return ERROR;
              }

      /* write header to cache file */
      fprintf(fp,"########################################\n");
      fprintf(fp,"#       NAGIOS OBJECT CACHE FILE\n");
      fprintf(fp,"#\n");
      fprintf(fp,"# THIS FILE IS AUTOMATICALLY GENERATED\n");
      fprintf(fp,"# BY NAGIOS.  DO NOT MODIFY THIS FILE!\n");
      fprintf(fp,"#\n");
      fprintf(fp,"# Created: %s",ctime(&current_time));
      fprintf(fp,"########################################\n\n");


      /* cache timeperiods */
      for(temp_timeperiod=xodtemplate_timeperiod_list;temp_timeperiod!=NULL;temp_timeperiod=temp_timeperiod->next){
            if(temp_timeperiod->register_object==FALSE)
                  continue;
            fprintf(fp,"define timeperiod {\n");
            if(temp_timeperiod->timeperiod_name)
                  fprintf(fp,"\ttimeperiod_name\t%s\n",temp_timeperiod->timeperiod_name);
            if(temp_timeperiod->alias)
                  fprintf(fp,"\talias\t%s\n",temp_timeperiod->alias);
            for(x=0;x<7;x++){
                  if(temp_timeperiod->timeranges[x]!=NULL)
                        fprintf(fp,"\t%s\t%s\n",days[x],temp_timeperiod->timeranges[x]);
                    }
            fprintf(fp,"\t}\n\n");
              }

      /* cache commands */
      for(temp_command=xodtemplate_command_list;temp_command!=NULL;temp_command=temp_command->next){
            if(temp_command->register_object==FALSE)
                  continue;
            fprintf(fp,"define command {\n");
            if(temp_command->command_name)
                  fprintf(fp,"\tcommand_name\t%s\n",temp_command->command_name);
            if(temp_command->command_line)
                  fprintf(fp,"\tcommand_line\t%s\n",temp_command->command_line);
            fprintf(fp,"\t}\n\n");
              }

      /* cache contactgroups */
      for(temp_contactgroup=xodtemplate_contactgroup_list;temp_contactgroup!=NULL;temp_contactgroup=temp_contactgroup->next){
            if(temp_contactgroup->register_object==FALSE)
                  continue;
            fprintf(fp,"define contactgroup {\n");
            if(temp_contactgroup->contactgroup_name)
                  fprintf(fp,"\tcontactgroup_name\t%s\n",temp_contactgroup->contactgroup_name);
            if(temp_contactgroup->alias)
                  fprintf(fp,"\talias\t%s\n",temp_contactgroup->alias);
            if(temp_contactgroup->members)
                  fprintf(fp,"\tmembers\t%s\n",temp_contactgroup->members);
            fprintf(fp,"\t}\n\n");
              }

      /* cache hostgroups */
      for(temp_hostgroup=xodtemplate_hostgroup_list;temp_hostgroup!=NULL;temp_hostgroup=temp_hostgroup->next){
            if(temp_hostgroup->register_object==FALSE)
                  continue;
            fprintf(fp,"define hostgroup {\n");
            if(temp_hostgroup->hostgroup_name)
                  fprintf(fp,"\thostgroup_name\t%s\n",temp_hostgroup->hostgroup_name);
            if(temp_hostgroup->alias)
                  fprintf(fp,"\talias\t%s\n",temp_hostgroup->alias);
            if(temp_hostgroup->members)
                  fprintf(fp,"\tmembers\t%s\n",temp_hostgroup->members);
            fprintf(fp,"\t}\n\n");
              }

      /* cache servicegroups */
      for(temp_servicegroup=xodtemplate_servicegroup_list;temp_servicegroup!=NULL;temp_servicegroup=temp_servicegroup->next){
            if(temp_servicegroup->register_object==FALSE)
                  continue;
            fprintf(fp,"define servicegroup {\n");
            if(temp_servicegroup->servicegroup_name)
                  fprintf(fp,"\tservicegroup_name\t%s\n",temp_servicegroup->servicegroup_name);
            if(temp_servicegroup->alias)
                  fprintf(fp,"\talias\t%s\n",temp_servicegroup->alias);
            if(temp_servicegroup->members)
                  fprintf(fp,"\tmembers\t%s\n",temp_servicegroup->members);
            fprintf(fp,"\t}\n\n");
              }

      /* cache contacts */
      for(temp_contact=xodtemplate_contact_list;temp_contact!=NULL;temp_contact=temp_contact->next){
            if(temp_contact->register_object==FALSE)
                  continue;
            fprintf(fp,"define contact {\n");
            if(temp_contact->contact_name)
                  fprintf(fp,"\tcontact_name\t%s\n",temp_contact->contact_name);
            if(temp_contact->alias)
                  fprintf(fp,"\talias\t%s\n",temp_contact->alias);
            if(temp_contact->service_notification_period)
                  fprintf(fp,"\tservice_notification_period\t%s\n",temp_contact->service_notification_period);
            if(temp_contact->host_notification_period)
                  fprintf(fp,"\thost_notification_period\t%s\n",temp_contact->host_notification_period);
            fprintf(fp,"\tservice_notification_options\t");
            x=0;
            if(temp_contact->notify_on_service_warning==TRUE)
                  fprintf(fp,"%sw",(x++>0)?",":"");
            if(temp_contact->notify_on_service_unknown==TRUE)
                  fprintf(fp,"%su",(x++>0)?",":"");
            if(temp_contact->notify_on_service_critical==TRUE)
                  fprintf(fp,"%sc",(x++>0)?",":"");
            if(temp_contact->notify_on_service_recovery==TRUE)
                  fprintf(fp,"%sr",(x++>0)?",":"");
            if(temp_contact->notify_on_service_flapping==TRUE)
                  fprintf(fp,"%sf",(x++>0)?",":"");
            if(x==0)
                  fprintf(fp,"n");
            fprintf(fp,"\n");
            fprintf(fp,"\thost_notification_options\t");
            x=0;
            if(temp_contact->notify_on_host_down==TRUE)
                  fprintf(fp,"%sd",(x++>0)?",":"");
            if(temp_contact->notify_on_host_unreachable==TRUE)
                  fprintf(fp,"%su",(x++>0)?",":"");
            if(temp_contact->notify_on_host_recovery==TRUE)
                  fprintf(fp,"%sr",(x++>0)?",":"");
            if(temp_contact->notify_on_host_flapping==TRUE)
                  fprintf(fp,"%sf",(x++>0)?",":"");
            if(x==0)
                  fprintf(fp,"n");
            fprintf(fp,"\n");
            if(temp_contact->service_notification_commands)
                  fprintf(fp,"\tservice_notification_commands\t%s\n",temp_contact->service_notification_commands);
            if(temp_contact->host_notification_commands)
                  fprintf(fp,"\thost_notification_commands\t%s\n",temp_contact->host_notification_commands);
            if(temp_contact->email)
                  fprintf(fp,"\temail\t%s\n",temp_contact->email);
            if(temp_contact->pager)
                  fprintf(fp,"\tpager\t%s\n",temp_contact->pager);
            fprintf(fp,"\t}\n\n");
              }

      /* cache hosts */
      for(temp_host=xodtemplate_host_list;temp_host!=NULL;temp_host=temp_host->next){
            if(temp_host->register_object==FALSE)
                  continue;
            fprintf(fp,"define host {\n");
            if(temp_host->host_name)
                  fprintf(fp,"\thost_name\t%s\n",temp_host->host_name);
            if(temp_host->alias)
                  fprintf(fp,"\talias\t%s\n",temp_host->alias);
            if(temp_host->address)
                  fprintf(fp,"\taddress\t%s\n",temp_host->address);
            if(temp_host->parents)
                  fprintf(fp,"\tparents\t%s\n",temp_host->parents);
            if(temp_host->check_period)
                  fprintf(fp,"\tcheck_period\t%s\n",temp_host->check_period);
            if(temp_host->check_command)
                  fprintf(fp,"\tcheck_command\t%s\n",temp_host->check_command);
            if(temp_host->event_handler)
                  fprintf(fp,"\tevent_handler\t%s\n",temp_host->event_handler);
            if(temp_host->contact_groups)
                  fprintf(fp,"\tcontact_groups\t%s\n",temp_host->contact_groups);
            if(temp_host->notification_period)
                  fprintf(fp,"\tnotification_period\t%s\n",temp_host->notification_period);
            if(temp_host->failure_prediction_options)
                  fprintf(fp,"\tfailure_prediction_options\t%s\n",temp_host->failure_prediction_options);
            fprintf(fp,"\tcheck_interval\t%d\n",temp_host->check_interval);
            fprintf(fp,"\tmax_check_attempts\t%d\n",temp_host->max_check_attempts);
            fprintf(fp,"\tactive_checks_enabled\t%d\n",temp_host->active_checks_enabled);
            fprintf(fp,"\tpassive_checks_enabled\t%d\n",temp_host->passive_checks_enabled);
            fprintf(fp,"\tobsess_over_host\t%d\n",temp_host->obsess_over_host);
            fprintf(fp,"\tevent_handler_enabled\t%d\n",temp_host->event_handler_enabled);
            fprintf(fp,"\tlow_flap_threshold\t%f\n",temp_host->low_flap_threshold);
            fprintf(fp,"\thigh_flap_threshold\t%f\n",temp_host->high_flap_threshold);
            fprintf(fp,"\tflap_detection_enabled\t%d\n",temp_host->flap_detection_enabled);
            fprintf(fp,"\tfreshness_threshold\t%d\n",temp_host->freshness_threshold);
            fprintf(fp,"\tcheck_freshness\t%d\n",temp_host->check_freshness);
            fprintf(fp,"\tnotification_options\t");
            x=0;
            if(temp_host->notify_on_down==TRUE)
                  fprintf(fp,"%sd",(x++>0)?",":"");
            if(temp_host->notify_on_unreachable==TRUE)
                  fprintf(fp,"%su",(x++>0)?",":"");
            if(temp_host->notify_on_recovery==TRUE)
                  fprintf(fp,"%sr",(x++>0)?",":"");
            if(temp_host->notify_on_flapping==TRUE)
                  fprintf(fp,"%sf",(x++>0)?",":"");
            if(x==0)
                  fprintf(fp,"n");
            fprintf(fp,"\n");
            fprintf(fp,"\tnotifications_enabled\t%d\n",temp_host->notifications_enabled);
            fprintf(fp,"\tnotification_interval\t%d\n",temp_host->notification_interval);
            fprintf(fp,"\tstalking_options\t");
            x=0;
            if(temp_host->stalk_on_up==TRUE)
                  fprintf(fp,"%so",(x++>0)?",":"");
            if(temp_host->stalk_on_down==TRUE)
                  fprintf(fp,"%sd",(x++>0)?",":"");
            if(temp_host->stalk_on_unreachable==TRUE)
                  fprintf(fp,"%su",(x++>0)?",":"");
            if(x==0)
                  fprintf(fp,"n");
            fprintf(fp,"\n");
            fprintf(fp,"\tprocess_perf_data\t%d\n",temp_host->process_perf_data);
            fprintf(fp,"\tfailure_prediction_enabled\t%d\n",temp_host->failure_prediction_enabled);
            fprintf(fp,"\tretain_status_information\t%d\n",temp_host->retain_status_information);
            fprintf(fp,"\tretain_nonstatus_information\t%d\n",temp_host->retain_nonstatus_information);

            fprintf(fp,"\t}\n\n");
              }

      /* cache services */
      for(temp_service=xodtemplate_service_list;temp_service!=NULL;temp_service=temp_service->next){
            if(temp_service->register_object==FALSE)
                  continue;
            fprintf(fp,"define service {\n");
            if(temp_service->host_name)
                  fprintf(fp,"\thost_name\t%s\n",temp_service->host_name);
            if(temp_service->service_description)
                  fprintf(fp,"\tservice_description\t%s\n",temp_service->service_description);
            if(temp_service->check_period)
                  fprintf(fp,"\tcheck_period\t%s\n",temp_service->check_period);
            if(temp_service->check_command)
                  fprintf(fp,"\tcheck_command\t%s\n",temp_service->check_command);
            if(temp_service->event_handler)
                  fprintf(fp,"\tevent_handler\t%s\n",temp_service->event_handler);
            if(temp_service->contact_groups)
                  fprintf(fp,"\tcontact_groups\t%s\n",temp_service->contact_groups);
            if(temp_service->notification_period)
                  fprintf(fp,"\tnotification_period\t%s\n",temp_service->notification_period);
            if(temp_service->failure_prediction_options)
                  fprintf(fp,"\tfailure_prediction_options\t%s\n",temp_service->failure_prediction_options);
            fprintf(fp,"\tnormal_check_interval\t%d\n",temp_service->normal_check_interval);
            fprintf(fp,"\tretry_check_interval\t%d\n",temp_service->retry_check_interval);
            fprintf(fp,"\tmax_check_attempts\t%d\n",temp_service->max_check_attempts);
            fprintf(fp,"\tis_volatile\t%d\n",temp_service->is_volatile);
            fprintf(fp,"\tparallelize_check\t%d\n",temp_service->parallelize_check);
            fprintf(fp,"\tactive_checks_enabled\t%d\n",temp_service->active_checks_enabled);
            fprintf(fp,"\tpassive_checks_enabled\t%d\n",temp_service->passive_checks_enabled);
            fprintf(fp,"\tobsess_over_service\t%d\n",temp_service->obsess_over_service);
            fprintf(fp,"\tevent_handler_enabled\t%d\n",temp_service->event_handler_enabled);
            fprintf(fp,"\tlow_flap_threshold\t%f\n",temp_service->low_flap_threshold);
            fprintf(fp,"\thigh_flap_threshold\t%f\n",temp_service->high_flap_threshold);
            fprintf(fp,"\tflap_detection_enabled\t%d\n",temp_service->flap_detection_enabled);
            fprintf(fp,"\tfreshness_threshold\t%d\n",temp_service->freshness_threshold);
            fprintf(fp,"\tcheck_freshness\t%d\n",temp_service->check_freshness);
            fprintf(fp,"\tnotification_options\t");
            x=0;
            if(temp_service->notify_on_unknown==TRUE)
                  fprintf(fp,"%su",(x++>0)?",":"");
            if(temp_service->notify_on_warning==TRUE)
                  fprintf(fp,"%sw",(x++>0)?",":"");
            if(temp_service->notify_on_critical==TRUE)
                  fprintf(fp,"%sc",(x++>0)?",":"");
            if(temp_service->notify_on_recovery==TRUE)
                  fprintf(fp,"%sr",(x++>0)?",":"");
            if(temp_service->notify_on_flapping==TRUE)
                  fprintf(fp,"%sf",(x++>0)?",":"");
            if(x==0)
                  fprintf(fp,"n");
            fprintf(fp,"\n");
            fprintf(fp,"\tnotifications_enabled\t%d\n",temp_service->notifications_enabled);
            fprintf(fp,"\tnotification_interval\t%d\n",temp_service->notification_interval);
            fprintf(fp,"\tstalking_options\t");
            x=0;
            if(temp_service->stalk_on_ok==TRUE)
                  fprintf(fp,"%so",(x++>0)?",":"");
            if(temp_service->stalk_on_unknown==TRUE)
                  fprintf(fp,"%su",(x++>0)?",":"");
            if(temp_service->stalk_on_warning==TRUE)
                  fprintf(fp,"%sw",(x++>0)?",":"");
            if(temp_service->stalk_on_critical==TRUE)
                  fprintf(fp,"%sc",(x++>0)?",":"");
            if(x==0)
                  fprintf(fp,"n");
            fprintf(fp,"\n");
            fprintf(fp,"\tprocess_perf_data\t%d\n",temp_service->process_perf_data);
            fprintf(fp,"\tfailure_prediction_enabled\t%d\n",temp_service->failure_prediction_enabled);
            fprintf(fp,"\tretain_status_information\t%d\n",temp_service->retain_status_information);
            fprintf(fp,"\tretain_nonstatus_information\t%d\n",temp_service->retain_nonstatus_information);

            fprintf(fp,"\t}\n\n");
              }

      /* cache service dependencies */
      for(temp_servicedependency=xodtemplate_servicedependency_list;temp_servicedependency!=NULL;temp_servicedependency=temp_servicedependency->next){
            if(temp_servicedependency->register_object==FALSE)
                  continue;
            fprintf(fp,"define servicedependency {\n");
            if(temp_servicedependency->host_name)
                  fprintf(fp,"\thost_name\t%s\n",temp_servicedependency->host_name);
            if(temp_servicedependency->service_description)
                  fprintf(fp,"\tservice_description\t%s\n",temp_servicedependency->service_description);
            if(temp_servicedependency->dependent_host_name)
                  fprintf(fp,"\tdependent_host_name\t%s\n",temp_servicedependency->dependent_host_name);
            if(temp_servicedependency->dependent_service_description)
                  fprintf(fp,"\tdependent_service_description\t%s\n",temp_servicedependency->dependent_service_description);
            fprintf(fp,"\tinherits_parent\t%d\n",temp_servicedependency->inherits_parent);
            if(temp_servicedependency->have_notification_dependency_options==TRUE){
                  fprintf(fp,"\tnotification_failure_options\t");
                  x=0;
                  if(temp_servicedependency->fail_notify_on_ok==TRUE)
                        fprintf(fp,"%so",(x++>0)?",":"");
                  if(temp_servicedependency->fail_notify_on_unknown==TRUE)
                        fprintf(fp,"%su",(x++>0)?",":"");
                  if(temp_servicedependency->fail_notify_on_warning==TRUE)
                        fprintf(fp,"%sw",(x++>0)?",":"");
                  if(temp_servicedependency->fail_notify_on_critical==TRUE)
                        fprintf(fp,"%sc",(x++>0)?",":"");
                  if(temp_servicedependency->fail_notify_on_pending==TRUE)
                        fprintf(fp,"%sp",(x++>0)?",":"");
                  if(x==0)
                        fprintf(fp,"n");
                  fprintf(fp,"\n");
                    }
            if(temp_servicedependency->have_execution_dependency_options==TRUE){
                  fprintf(fp,"\texecution_failure_options\t");
                  x=0;
                  if(temp_servicedependency->fail_execute_on_ok==TRUE)
                        fprintf(fp,"%so",(x++>0)?",":"");
                  if(temp_servicedependency->fail_execute_on_unknown==TRUE)
                        fprintf(fp,"%su",(x++>0)?",":"");
                  if(temp_servicedependency->fail_execute_on_warning==TRUE)
                        fprintf(fp,"%sw",(x++>0)?",":"");
                  if(temp_servicedependency->fail_execute_on_critical==TRUE)
                        fprintf(fp,"%sc",(x++>0)?",":"");
                  if(temp_servicedependency->fail_execute_on_pending==TRUE)
                        fprintf(fp,"%sp",(x++>0)?",":"");
                  if(x==0)
                        fprintf(fp,"n");
                  fprintf(fp,"\n");
                    }
            fprintf(fp,"\t}\n\n");
              }

      /* cache service escalations */
      for(temp_serviceescalation=xodtemplate_serviceescalation_list;temp_serviceescalation!=NULL;temp_serviceescalation=temp_serviceescalation->next){
            if(temp_serviceescalation->register_object==FALSE)
                  continue;
            fprintf(fp,"define serviceescalation {\n");
            if(temp_serviceescalation->host_name)
                  fprintf(fp,"\thost_name\t%s\n",temp_serviceescalation->host_name);
            if(temp_serviceescalation->service_description)
                  fprintf(fp,"\tservice_description\t%s\n",temp_serviceescalation->service_description);
            fprintf(fp,"\tfirst_notification\t%d\n",temp_serviceescalation->first_notification);
            fprintf(fp,"\tlast_notification\t%d\n",temp_serviceescalation->last_notification);
            fprintf(fp,"\tnotification_interval\t%d\n",temp_serviceescalation->notification_interval);
            if(temp_serviceescalation->escalation_period)
                  fprintf(fp,"\tescalation_period\t%s\n",temp_serviceescalation->escalation_period);
            if(temp_serviceescalation->have_escalation_options==TRUE){
                  fprintf(fp,"\tescalation_options\t");
                  x=0;
                  if(temp_serviceescalation->escalate_on_warning==TRUE)
                        fprintf(fp,"%sw",(x++>0)?",":"");
                  if(temp_serviceescalation->escalate_on_unknown==TRUE)
                        fprintf(fp,"%su",(x++>0)?",":"");
                  if(temp_serviceescalation->escalate_on_critical==TRUE)
                        fprintf(fp,"%sc",(x++>0)?",":"");
                  if(temp_serviceescalation->escalate_on_recovery==TRUE)
                        fprintf(fp,"%sr",(x++>0)?",":"");
                  if(x==0)
                        fprintf(fp,"n");
                  fprintf(fp,"\n");
                    }
            if(temp_serviceescalation->contact_groups)
                  fprintf(fp,"\tcontact_groups\t%s\n",temp_serviceescalation->contact_groups);
            fprintf(fp,"\t}\n\n");
              }

      /* cache host dependencies */
      for(temp_hostdependency=xodtemplate_hostdependency_list;temp_hostdependency!=NULL;temp_hostdependency=temp_hostdependency->next){
            if(temp_hostdependency->register_object==FALSE)
                  continue;
            fprintf(fp,"define hostdependency {\n");
            if(temp_hostdependency->host_name)
                  fprintf(fp,"\thost_name\t%s\n",temp_hostdependency->host_name);
            if(temp_hostdependency->dependent_host_name)
                  fprintf(fp,"\tdependent_host_name\t%s\n",temp_hostdependency->dependent_host_name);
            fprintf(fp,"\tinherits_parent\t%d\n",temp_hostdependency->inherits_parent);
            if(temp_hostdependency->have_notification_dependency_options==TRUE){
                  fprintf(fp,"\tnotification_failure_options\t");
                  x=0;
                  if(temp_hostdependency->fail_notify_on_up==TRUE)
                        fprintf(fp,"%so",(x++>0)?",":"");
                  if(temp_hostdependency->fail_notify_on_down==TRUE)
                        fprintf(fp,"%sd",(x++>0)?",":"");
                  if(temp_hostdependency->fail_notify_on_unreachable==TRUE)
                        fprintf(fp,"%su",(x++>0)?",":"");
                  if(temp_hostdependency->fail_notify_on_pending==TRUE)
                        fprintf(fp,"%sp",(x++>0)?",":"");
                  if(x==0)
                        fprintf(fp,"n");
                  fprintf(fp,"\n");
                    }
            if(temp_hostdependency->have_execution_dependency_options==TRUE){
                  fprintf(fp,"\texecution_failure_options\t");
                  x=0;
                  if(temp_hostdependency->fail_execute_on_up==TRUE)
                        fprintf(fp,"%so",(x++>0)?",":"");
                  if(temp_hostdependency->fail_execute_on_down==TRUE)
                        fprintf(fp,"%sd",(x++>0)?",":"");
                  if(temp_hostdependency->fail_execute_on_unreachable==TRUE)
                        fprintf(fp,"%su",(x++>0)?",":"");
                  if(temp_hostdependency->fail_execute_on_pending==TRUE)
                        fprintf(fp,"%sp",(x++>0)?",":"");
                  if(x==0)
                        fprintf(fp,"n");
                  fprintf(fp,"\n");
                    }
            fprintf(fp,"\t}\n\n");
              }

      /* cache host escalations */
      for(temp_hostescalation=xodtemplate_hostescalation_list;temp_hostescalation!=NULL;temp_hostescalation=temp_hostescalation->next){
            if(temp_hostescalation->register_object==FALSE)
                  continue;
            fprintf(fp,"define hostescalation {\n");
            if(temp_hostescalation->host_name)
                  fprintf(fp,"\thost_name\t%s\n",temp_hostescalation->host_name);
            fprintf(fp,"\tfirst_notification\t%d\n",temp_hostescalation->first_notification);
            fprintf(fp,"\tlast_notification\t%d\n",temp_hostescalation->last_notification);
            fprintf(fp,"\tnotification_interval\t%d\n",temp_hostescalation->notification_interval);
            if(temp_hostescalation->escalation_period)
                  fprintf(fp,"\tescalation_period\t%s\n",temp_hostescalation->escalation_period);
            if(temp_hostescalation->have_escalation_options==TRUE){
                  fprintf(fp,"\tescalation_options\t");
                  x=0;
                  if(temp_hostescalation->escalate_on_down==TRUE)
                        fprintf(fp,"%sd",(x++>0)?",":"");
                  if(temp_hostescalation->escalate_on_unreachable==TRUE)
                        fprintf(fp,"%su",(x++>0)?",":"");
                  if(temp_hostescalation->escalate_on_recovery==TRUE)
                        fprintf(fp,"%sr",(x++>0)?",":"");
                  if(x==0)
                        fprintf(fp,"n");
                  fprintf(fp,"\n");
                    }
            if(temp_hostescalation->contact_groups)
                  fprintf(fp,"\tcontact_groups\t%s\n",temp_hostescalation->contact_groups);
            fprintf(fp,"\t}\n\n");
              }

      /* cache host extended info */
      for(temp_hostextinfo=xodtemplate_hostextinfo_list;temp_hostextinfo!=NULL;temp_hostextinfo=temp_hostextinfo->next){
            if(temp_hostextinfo->register_object==FALSE)
                  continue;
            fprintf(fp,"define hostextinfo {\n");
            if(temp_hostextinfo->host_name)
                  fprintf(fp,"\thost_name\t%s\n",temp_hostextinfo->host_name);
            if(temp_hostextinfo->icon_image)
                  fprintf(fp,"\ticon_image\t%s\n",temp_hostextinfo->icon_image);
            if(temp_hostextinfo->icon_image_alt)
                  fprintf(fp,"\ticon_image_alt\t%s\n",temp_hostextinfo->icon_image_alt);
            if(temp_hostextinfo->vrml_image)
                  fprintf(fp,"\tvrml_image\t%s\n",temp_hostextinfo->vrml_image);
            if(temp_hostextinfo->statusmap_image)
                  fprintf(fp,"\tstatusmap_image\t%s\n",temp_hostextinfo->statusmap_image);
            if(temp_hostextinfo->have_2d_coords==TRUE)
                  fprintf(fp,"\t2d_coords\t%d,%d\n",temp_hostextinfo->x_2d,temp_hostextinfo->y_2d);
            if(temp_hostextinfo->have_3d_coords==TRUE)
                  fprintf(fp,"\t3d_coords\t%f,%f,%f\n",temp_hostextinfo->x_3d,temp_hostextinfo->y_3d,temp_hostextinfo->z_3d);
            if(temp_hostextinfo->notes)
                  fprintf(fp,"\tnotes\t%s\n",temp_hostextinfo->notes);
            if(temp_hostextinfo->notes_url)
                  fprintf(fp,"\tnotes_url\t%s\n",temp_hostextinfo->notes_url);
            if(temp_hostextinfo->action_url)
                  fprintf(fp,"\taction_url\t%s\n",temp_hostextinfo->action_url);
            fprintf(fp,"\t}\n\n");
              }

      /* cache service extended info */
      for(temp_serviceextinfo=xodtemplate_serviceextinfo_list;temp_serviceextinfo!=NULL;temp_serviceextinfo=temp_serviceextinfo->next){
            if(temp_serviceextinfo->register_object==FALSE)
                  continue;
            fprintf(fp,"define serviceextinfo {\n");
            if(temp_serviceextinfo->host_name)
                  fprintf(fp,"\thost_name\t%s\n",temp_serviceextinfo->host_name);
            if(temp_serviceextinfo->service_description)
                  fprintf(fp,"\tservice_description\t%s\n",temp_serviceextinfo->service_description);
            if(temp_serviceextinfo->icon_image)
                  fprintf(fp,"\ticon_image\t%s\n",temp_serviceextinfo->icon_image);
            if(temp_serviceextinfo->icon_image_alt)
                  fprintf(fp,"\ticon_image_alt\t%s\n",temp_serviceextinfo->icon_image_alt);
            if(temp_serviceextinfo->notes)
                  fprintf(fp,"\tnotes\t%s\n",temp_serviceextinfo->notes);
            if(temp_serviceextinfo->notes_url)
                  fprintf(fp,"\tnotes_url\t%s\n",temp_serviceextinfo->notes_url);
            if(temp_serviceextinfo->action_url)
                  fprintf(fp,"\taction_url\t%s\n",temp_serviceextinfo->action_url);
            fprintf(fp,"\t}\n\n");
              }

      fclose(fp);

#ifdef DEBUG0
      printf("xodtemplate_cache_objects() end\n");
#endif

      return OK;
        }

#endif

/******************************************************************/
/********************** CLEANUP FUNCTIONS *************************/
/******************************************************************/

/* frees memory */
int xodtemplate_free_memory(void){
      xodtemplate_timeperiod *this_timeperiod;
      xodtemplate_timeperiod *next_timeperiod;
      xodtemplate_command *this_command;
      xodtemplate_command *next_command;
      xodtemplate_contactgroup *this_contactgroup;
      xodtemplate_contactgroup *next_contactgroup;
      xodtemplate_hostgroup *this_hostgroup;
      xodtemplate_hostgroup *next_hostgroup;
      xodtemplate_servicegroup *this_servicegroup;
      xodtemplate_servicegroup *next_servicegroup;
      xodtemplate_servicedependency *this_servicedependency;
      xodtemplate_servicedependency *next_servicedependency;
      xodtemplate_serviceescalation *this_serviceescalation;
      xodtemplate_serviceescalation *next_serviceescalation;
      xodtemplate_contact *this_contact;
      xodtemplate_contact *next_contact;
      xodtemplate_host *this_host;
      xodtemplate_host *next_host;
      xodtemplate_service *this_service;
      xodtemplate_service *next_service;
      xodtemplate_hostdependency *this_hostdependency;
      xodtemplate_hostdependency *next_hostdependency;
      xodtemplate_hostescalation *this_hostescalation;
      xodtemplate_hostescalation *next_hostescalation;
      xodtemplate_hostextinfo *this_hostextinfo;
      xodtemplate_hostextinfo *next_hostextinfo;
      xodtemplate_serviceextinfo *this_serviceextinfo;
      xodtemplate_serviceextinfo *next_serviceextinfo;
      int x;

#ifdef DEBUG0
      printf("xodtemplate_free_memory() start\n");
#endif

      /* free memory allocated to timeperiod list */
      for(this_timeperiod=xodtemplate_timeperiod_list;this_timeperiod!=NULL;this_timeperiod=next_timeperiod){
            next_timeperiod=this_timeperiod->next;
            free(this_timeperiod->template);
            free(this_timeperiod->name);
            free(this_timeperiod->timeperiod_name);
            free(this_timeperiod->alias);
            for(x=0;x<7;x++)
                  free(this_timeperiod->timeranges[x]);
            free(this_timeperiod);
              }
      xodtemplate_timeperiod_list=NULL;

      /* free memory allocated to command list */
      for(this_command=xodtemplate_command_list;this_command!=NULL;this_command=next_command){
            next_command=this_command->next;
            free(this_command->template);
            free(this_command->name);
            free(this_command->command_name);
            free(this_command->command_line);
            free(this_command);
              }
      xodtemplate_command_list=NULL;

      /* free memory allocated to contactgroup list */
      for(this_contactgroup=xodtemplate_contactgroup_list;this_contactgroup!=NULL;this_contactgroup=next_contactgroup){
            next_contactgroup=this_contactgroup->next;
            free(this_contactgroup->template);
            free(this_contactgroup->name);
            free(this_contactgroup->contactgroup_name);
            free(this_contactgroup->alias);
            free(this_contactgroup->members);
            free(this_contactgroup);
              }
      xodtemplate_contactgroup_list=NULL;

      /* free memory allocated to hostgroup list */
      for(this_hostgroup=xodtemplate_hostgroup_list;this_hostgroup!=NULL;this_hostgroup=next_hostgroup){
            next_hostgroup=this_hostgroup->next;
            free(this_hostgroup->template);
            free(this_hostgroup->name);
            free(this_hostgroup->hostgroup_name);
            free(this_hostgroup->alias);
            free(this_hostgroup->members);
            free(this_hostgroup);
              }
      xodtemplate_hostgroup_list=NULL;

      /* free memory allocated to servicegroup list */
      for(this_servicegroup=xodtemplate_servicegroup_list;this_servicegroup!=NULL;this_servicegroup=next_servicegroup){
            next_servicegroup=this_servicegroup->next;
            free(this_servicegroup->template);
            free(this_servicegroup->name);
            free(this_servicegroup->servicegroup_name);
            free(this_servicegroup->alias);
            free(this_servicegroup->members);
            free(this_servicegroup);
              }
      xodtemplate_servicegroup_list=NULL;

      /* free memory allocated to servicedependency list */
      for(this_servicedependency=xodtemplate_servicedependency_list;this_servicedependency!=NULL;this_servicedependency=next_servicedependency){
            next_servicedependency=this_servicedependency->next;
            free(this_servicedependency->template);
            free(this_servicedependency->name);
            free(this_servicedependency->servicegroup_name);
            free(this_servicedependency->hostgroup_name);
            free(this_servicedependency->host_name);
            free(this_servicedependency->service_description);
            free(this_servicedependency->dependent_servicegroup_name);
            free(this_servicedependency->dependent_hostgroup_name);
            free(this_servicedependency->dependent_host_name);
            free(this_servicedependency->dependent_service_description);
            free(this_servicedependency);
              }
      xodtemplate_servicedependency_list=NULL;

      /* free memory allocated to serviceescalation list */
      for(this_serviceescalation=xodtemplate_serviceescalation_list;this_serviceescalation!=NULL;this_serviceescalation=next_serviceescalation){
            next_serviceescalation=this_serviceescalation->next;
            free(this_serviceescalation->template);
            free(this_serviceescalation->name);
            free(this_serviceescalation->servicegroup_name);
            free(this_serviceescalation->hostgroup_name);
            free(this_serviceescalation->host_name);
            free(this_serviceescalation->service_description);
            free(this_serviceescalation->escalation_period);
            free(this_serviceescalation->contact_groups);
            free(this_serviceescalation);
              }
      xodtemplate_serviceescalation_list=NULL;

      /* free memory allocated to contact list */
      for(this_contact=xodtemplate_contact_list;this_contact!=NULL;this_contact=next_contact){
            next_contact=this_contact->next;
            free(this_contact->template);
            free(this_contact->name);
            free(this_contact->contact_name);
            free(this_contact->alias);
            free(this_contact->contactgroups);
            free(this_contact->email);
            free(this_contact->pager);
            for(x=0;x<MAX_XODTEMPLATE_CONTACT_ADDRESSES;x++)
                  free(this_contact->address[x]);
            free(this_contact->service_notification_period);
            free(this_contact->service_notification_commands);
            free(this_contact->host_notification_period);
            free(this_contact->host_notification_commands);
            free(this_contact);
              }
      xodtemplate_contact_list=NULL;

      /* free memory allocated to host list */
      for(this_host=xodtemplate_host_list;this_host!=NULL;this_host=next_host){
            next_host=this_host->next;
            free(this_host->template);
            free(this_host->name);
            free(this_host->host_name);
            free(this_host->alias);
            free(this_host->address);
            free(this_host->parents);
            free(this_host->hostgroups);
            free(this_host->check_command);
            free(this_host->check_period);
            free(this_host->event_handler);
            free(this_host->contact_groups);
            free(this_host->notification_period);
            free(this_host->failure_prediction_options);
            free(this_host);
              }
      xodtemplate_host_list=NULL;

      /* free memory allocated to service list (chained hash) */
      for(this_service=xodtemplate_service_list;this_service!=NULL;this_service=next_service){
            next_service=this_service->next;
            free(this_service->template);
            free(this_service->name);
            free(this_service->hostgroup_name);
            free(this_service->host_name);
            free(this_service->service_description);
            free(this_service->servicegroups);
            free(this_service->check_command);
            free(this_service->check_period);
            free(this_service->event_handler);
            free(this_service->notification_period);
            free(this_service->contact_groups);
            free(this_service->failure_prediction_options);
            free(this_service);
              }
      xodtemplate_service_list=NULL;

      /* free memory allocated to hostdependency list */
      for(this_hostdependency=xodtemplate_hostdependency_list;this_hostdependency!=NULL;this_hostdependency=next_hostdependency){
            next_hostdependency=this_hostdependency->next;
            free(this_hostdependency->template);
            free(this_hostdependency->name);
            free(this_hostdependency->hostgroup_name);
            free(this_hostdependency->dependent_hostgroup_name);
            free(this_hostdependency->host_name);
            free(this_hostdependency->dependent_host_name);
            free(this_hostdependency);
              }
      xodtemplate_hostdependency_list=NULL;

      /* free memory allocated to hostescalation list */
      for(this_hostescalation=xodtemplate_hostescalation_list;this_hostescalation!=NULL;this_hostescalation=next_hostescalation){
            next_hostescalation=this_hostescalation->next;
            free(this_hostescalation->template);
            free(this_hostescalation->name);
            free(this_hostescalation->hostgroup_name);
            free(this_hostescalation->host_name);
            free(this_hostescalation->escalation_period);
            free(this_hostescalation->contact_groups);
            free(this_hostescalation);
              }
      xodtemplate_hostescalation_list=NULL;

      /* free memory allocated to hostextinfo list */
      for(this_hostextinfo=xodtemplate_hostextinfo_list;this_hostextinfo!=NULL;this_hostextinfo=next_hostextinfo){
            next_hostextinfo=this_hostextinfo->next;
            free(this_hostextinfo->template);
            free(this_hostextinfo->name);
            free(this_hostextinfo->host_name);
            free(this_hostextinfo->hostgroup_name);
            free(this_hostextinfo->notes);
            free(this_hostextinfo->notes_url);
            free(this_hostextinfo->action_url);
            free(this_hostextinfo->icon_image);
            free(this_hostextinfo->icon_image_alt);
            free(this_hostextinfo->vrml_image);
            free(this_hostextinfo->statusmap_image);
            free(this_hostextinfo);
              }
      xodtemplate_hostextinfo_list=NULL;

      /* free memory allocated to serviceextinfo list */
      for(this_serviceextinfo=xodtemplate_serviceextinfo_list;this_serviceextinfo!=NULL;this_serviceextinfo=next_serviceextinfo){
            next_serviceextinfo=this_serviceextinfo->next;
            free(this_serviceextinfo->template);
            free(this_serviceextinfo->name);
            free(this_serviceextinfo->host_name);
            free(this_serviceextinfo->hostgroup_name);
            free(this_serviceextinfo->service_description);
            free(this_serviceextinfo->notes);
            free(this_serviceextinfo->notes_url);
            free(this_serviceextinfo->action_url);
            free(this_serviceextinfo->icon_image);
            free(this_serviceextinfo->icon_image_alt);
            free(this_serviceextinfo);
              }
      xodtemplate_serviceextinfo_list=NULL;

      /* free memory for the config file names */
      for(x=0;x<xodtemplate_current_config_file;x++)
            free(xodtemplate_config_files[x]);
      free(xodtemplate_config_files);
      xodtemplate_current_config_file=0;


#ifdef DEBUG0
      printf("xodtemplate_free_memory() end\n");
#endif

      return OK;
        }


/* frees memory allocated to a temporary contact list */
int xodtemplate_free_contactlist(xodtemplate_contactlist *temp_list){
      xodtemplate_contactlist *this_contactlist;
      xodtemplate_contactlist *next_contactlist;

#ifdef DEBUG0
      printf("xodtemplate_free_contactlist() start\n");
#endif

      /* free memory allocated to contact name list */
      for(this_contactlist=temp_list;this_contactlist!=NULL;this_contactlist=next_contactlist){
            next_contactlist=this_contactlist->next;
            free(this_contactlist->contact_name);
            free(this_contactlist);
              }

      temp_list=NULL;

#ifdef DEBUG0
      printf("xodtemplate_free_contactlist() end\n");
#endif

      return OK;
        }


/* remove an entry from the contact list */
void xodtemplate_remove_contactlist_item(xodtemplate_contactlist *item,xodtemplate_contactlist **list){
      xodtemplate_contactlist *temp_item;

#ifdef DEBUG0
      printf("xodtemplate_remove_contactlist_item() start\n");
#endif

      if(item==NULL || list==NULL)
            return;

      if(*list==NULL)
            return;

      if(*list==item)
            *list=item->next;

      else{

            for(temp_item=*list;temp_item!=NULL;temp_item=temp_item->next){
                  if(temp_item->next==item){
                        temp_item->next=item->next;
                        free(item->contact_name);
                        free(item);
                        break;
                          }
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_remove_contactlist_item() end\n");
#endif

      return;
        }



/* frees memory allocated to a temporary host list */
int xodtemplate_free_hostlist(xodtemplate_hostlist *temp_list){
      xodtemplate_hostlist *this_hostlist;
      xodtemplate_hostlist *next_hostlist;

#ifdef DEBUG0
      printf("xodtemplate_free_hostlist() start\n");
#endif

      /* free memory allocated to host name list */
      for(this_hostlist=temp_list;this_hostlist!=NULL;this_hostlist=next_hostlist){
            next_hostlist=this_hostlist->next;
            free(this_hostlist->host_name);
            free(this_hostlist);
              }

      temp_list=NULL;

#ifdef DEBUG0
      printf("xodtemplate_free_hostlist() end\n");
#endif

      return OK;
        }


/* remove an entry from the host list */
void xodtemplate_remove_hostlist_item(xodtemplate_hostlist *item,xodtemplate_hostlist **list){
      xodtemplate_hostlist *temp_item;

#ifdef DEBUG0
      printf("xodtemplate_remove_hostlist_item() start\n");
#endif

      if(item==NULL || list==NULL)
            return;

      if(*list==NULL)
            return;

      if(*list==item)
            *list=item->next;

      else{

            for(temp_item=*list;temp_item!=NULL;temp_item=temp_item->next){
                  if(temp_item->next==item){
                        temp_item->next=item->next;
                        free(item->host_name);
                        free(item);
                        break;
                          }
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_remove_hostlist_item() end\n");
#endif

      return;
        }


/* frees memory allocated to a temporary service list */
int xodtemplate_free_servicelist(xodtemplate_servicelist *temp_list){
      xodtemplate_servicelist *this_servicelist;
      xodtemplate_servicelist *next_servicelist;

#ifdef DEBUG0
      printf("xodtemplate_free_servicelist() start\n");
#endif

      /* free memory allocated to service name list */
      for(this_servicelist=temp_list;this_servicelist!=NULL;this_servicelist=next_servicelist){
            next_servicelist=this_servicelist->next;
            free(this_servicelist->host_name);
            free(this_servicelist->service_description);
            free(this_servicelist);
              }

      temp_list=NULL;

#ifdef DEBUG0
      printf("xodtemplate_free_servicelist() end\n");
#endif

      return OK;
        }


/* remove an entry from the service list */
void xodtemplate_remove_servicelist_item(xodtemplate_servicelist *item,xodtemplate_servicelist **list){
      xodtemplate_servicelist *temp_item;

#ifdef DEBUG0
      printf("xodtemplate_remove_servicelist_item() start\n");
#endif

      if(item==NULL || list==NULL)
            return;

      if(*list==NULL)
            return;

      if(*list==item)
            *list=item->next;

      else{

            for(temp_item=*list;temp_item!=NULL;temp_item=temp_item->next){
                  if(temp_item->next==item){
                        temp_item->next=item->next;
                        free(item->host_name);
                        free(item->service_description);
                        free(item);
                        break;
                          }
                    }
              }

#ifdef DEBUG0
      printf("xodtemplate_remove_servicelist_item() end\n");
#endif

      return;
        }



/******************************************************************/
/********************** UTILITY FUNCTIONS *************************/
/******************************************************************/

#ifdef NSCORE

/* expands a comma-delimited list of contact names */
xodtemplate_contactlist *xodtemplate_expand_contacts(char *contacts){
      xodtemplate_contactlist *temp_list=NULL;
      xodtemplate_contactlist *reject_list=NULL;
      xodtemplate_contactlist *list_ptr=NULL;
      xodtemplate_contactlist *reject_ptr=NULL;
      int result;

#ifdef DEBUG0
      printf("xodtemplate_expand_contacts() start\n");
#endif

      /* process contact names */
      if(contacts!=NULL){

            /* expand contacts */
            result=xodtemplate_expand_contacts2(&temp_list,&reject_list,contacts);
            if(result!=OK){
                  xodtemplate_free_contactlist(temp_list);
                  xodtemplate_free_contactlist(reject_list);
                  return NULL;
                    }

            /* remove rejects (if any) from the list (no duplicate entries exist in either list) */
            for(reject_ptr=reject_list;reject_ptr!=NULL;reject_ptr=reject_ptr->next){
                  for(list_ptr=temp_list;list_ptr!=NULL;list_ptr=list_ptr->next){
                        if(!strcmp(reject_ptr->contact_name,list_ptr->contact_name)){
                              xodtemplate_remove_contactlist_item(list_ptr,&temp_list);
                              break;
                                  }
                            }
                      }
            xodtemplate_free_contactlist(reject_list);
            reject_list=NULL;
              }

#ifdef DEBUG0
      printf("xodtemplate_expand_contacts() end\n");
#endif

      return temp_list;
        }



/* expands contacts */
int xodtemplate_expand_contacts2(xodtemplate_contactlist **list, xodtemplate_contactlist **reject_list,char *contacts){
      char *contact_names;
      char *temp_ptr;
      xodtemplate_contact *temp_contact;
      regex_t preg;
      int found_match=TRUE;
      int reject_item=FALSE;
      int use_regexp=FALSE;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_expand_contacts2() start\n");
#endif

      if(list==NULL || contacts==NULL)
            return ERROR;

      contact_names=strdup(contacts);
      if(contact_names==NULL)
            return ERROR;

      /* expand each contact name */
      for(temp_ptr=strtok(contact_names,",");temp_ptr;temp_ptr=strtok(NULL,",")){

            found_match=FALSE;
            reject_item=FALSE;

            /* strip trailing spaces */
            strip(temp_ptr);

            /* should we use regular expression matching? */
            if(use_regexp_matches==TRUE && (use_true_regexp_matching==TRUE || strstr(temp_ptr,"*") || strstr(temp_ptr,"?")))
                  use_regexp=TRUE;

            /* use regular expression matching */
            if(use_regexp==TRUE){

                  /* compile regular expression */
                  if(regcomp(&preg,temp_ptr,0)){
                        free(contact_names);
                        return ERROR;
                            }
                  
                  /* test match against all contacts */
                  for(temp_contact=xodtemplate_contact_list;temp_contact!=NULL;temp_contact=temp_contact->next){

                        if(temp_contact->contact_name==NULL)
                              continue;

                        /* skip this contact if it did not match the expression */
                        if(regexec(&preg,temp_contact->contact_name,0,NULL,0))
                              continue;

                        found_match=TRUE;

                        /* dont' add contacts that shouldn't be registered */
                        if(temp_contact->register_object==FALSE)
                              continue;

                        /* add contact to list */
                        xodtemplate_add_contact_to_contactlist(list,temp_contact->contact_name);
                            } 

                  /* free memory allocated to compiled regexp */
                  regfree(&preg);
                    }
            
            /* use standard matching... */
            else{

                  /* return a list of all contacts */
                  if(!strcmp(temp_ptr,"*")){

                        found_match=TRUE;

                        for(temp_contact=xodtemplate_contact_list;temp_contact!=NULL;temp_contact=temp_contact->next){

                              if(temp_contact->contact_name==NULL)
                                    continue;

                              /* dont' add contacts that shouldn't be registered */
                              if(temp_contact->register_object==FALSE)
                                    continue;

                              /* add contact to list */
                              xodtemplate_add_contact_to_contactlist(list,temp_contact->contact_name);
                                }
                          }

                  /* else this is just a single contact... */
                  else{

                        /* this contact should be excluded (rejected) */
                        if(temp_ptr[0]=='!'){
                              reject_item=TRUE;
                              temp_ptr++;
                                  }

                        /* find the contact */
                        temp_contact=xodtemplate_find_real_contact(temp_ptr);
                        if(temp_contact!=NULL){

                              found_match=TRUE;

                              /* add contact to list */
                              xodtemplate_add_contact_to_contactlist((reject_item==TRUE)?reject_list:list,temp_ptr);
                                }
                          }
                    }

            if(found_match==FALSE){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not find any contact matching '%s'\n",temp_ptr);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  break;
                      }
              }

      /* free memory */
      free(contact_names);

#ifdef DEBUG0
      printf("xodtemplate_expand_contacts2() end\n");
#endif

      if(found_match==FALSE)
            return ERROR;

      return OK;
        }



/* adds a contact entry to the list of expanded (accepted) or rejected contacts */
int xodtemplate_add_contact_to_contactlist(xodtemplate_contactlist **list, char *contact_name){
      xodtemplate_contactlist *temp_item;
      xodtemplate_contactlist *new_item;

      if(list==NULL || contact_name==NULL)
            return ERROR;

      /* skip this contact if its already in the list */
      for(temp_item=*list;temp_item;temp_item=temp_item->next)
            if(!strcmp(temp_item->contact_name,contact_name))
                  break;
      if(temp_item)
            return OK;

      /* allocate memory for a new list item */
      new_item=(xodtemplate_contactlist *)malloc(sizeof(xodtemplate_contactlist));
      if(new_item==NULL)
            return ERROR;

      /* save the contact name */
      new_item->contact_name=strdup(contact_name);
      if(new_item->contact_name==NULL){
            free(new_item);
            return ERROR;
              }

      /* add new item to head of list */
      new_item->next=*list;
      *list=new_item;

      return OK;
        }



/* expands a comma-delimited list of hostgroups and/or hosts to member host names */
xodtemplate_hostlist *xodtemplate_expand_hostgroups_and_hosts(char *hostgroups,char *hosts){
      xodtemplate_hostlist *temp_list=NULL;
      xodtemplate_hostlist *reject_list=NULL;
      xodtemplate_hostlist *list_ptr=NULL;
      xodtemplate_hostlist *reject_ptr=NULL;
      int result;

#ifdef DEBUG0
      printf("xodtemplate_expand_hostgroups_and_hosts() start\n");
#endif

      /* process list of hostgroups... */
      if(hostgroups!=NULL){

            /* expand host */
            result=xodtemplate_expand_hostgroups(&temp_list,&reject_list,hostgroups);
            if(result!=OK){
                  xodtemplate_free_hostlist(temp_list);
                  xodtemplate_free_hostlist(reject_list);
                  return NULL;
                    }

            /* remove rejects (if any) from the list (no duplicate entries exist in either list) */
            for(reject_ptr=reject_list;reject_ptr!=NULL;reject_ptr=reject_ptr->next){
                  for(list_ptr=temp_list;list_ptr!=NULL;list_ptr=list_ptr->next){
                        if(!strcmp(reject_ptr->host_name,list_ptr->host_name)){
                              xodtemplate_remove_hostlist_item(list_ptr,&temp_list);
                              break;
                                  }
                            }
                      }
            xodtemplate_free_hostlist(reject_list);
            reject_list=NULL;
              }


      /* process host names */
      if(hosts!=NULL){

            /* expand hosts */
            result=xodtemplate_expand_hosts(&temp_list,&reject_list,hosts);
            if(result!=OK){
                  xodtemplate_free_hostlist(temp_list);
                  xodtemplate_free_hostlist(reject_list);
                  return NULL;
                    }

            /* remove rejects (if any) from the list (no duplicate entries exist in either list) */
            /* NOTE: rejects from this list also affect hosts generated from processing hostgroup names (see above) */
            for(reject_ptr=reject_list;reject_ptr!=NULL;reject_ptr=reject_ptr->next){
                  for(list_ptr=temp_list;list_ptr!=NULL;list_ptr=list_ptr->next){
                        if(!strcmp(reject_ptr->host_name,list_ptr->host_name)){
                              xodtemplate_remove_hostlist_item(list_ptr,&temp_list);
                              break;
                                  }
                            }
                      }
            xodtemplate_free_hostlist(reject_list);
            reject_list=NULL;
              }

#ifdef DEBUG0
      printf("xodtemplate_expand_hostgroups_and_hosts() end\n");
#endif

      return temp_list;
        }



/* expands hostgroups */
int xodtemplate_expand_hostgroups(xodtemplate_hostlist **list, xodtemplate_hostlist **reject_list, char *hostgroups){
      char *hostgroup_names;
      char *temp_ptr;
      xodtemplate_hostgroup *temp_hostgroup;
      regex_t preg;
      int found_match=TRUE;
      int reject_item=FALSE;
      int use_regexp=FALSE;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_expand_hostgroups() start\n");
#endif

      if(list==NULL || hostgroups==NULL)
            return ERROR;

      /* allocate memory for hostgroup name list */
      hostgroup_names=strdup(hostgroups);
      if(hostgroup_names==NULL)
            return ERROR;

      for(temp_ptr=strtok(hostgroup_names,",");temp_ptr;temp_ptr=strtok(NULL,",")){

            found_match=FALSE;
            reject_item=FALSE;
            
            /* strip trailing spaces */
            strip(temp_ptr);

            /* should we use regular expression matching? */
            if(use_regexp_matches==TRUE && (use_true_regexp_matching==TRUE || strstr(temp_ptr,"*") || strstr(temp_ptr,"?")))
                  use_regexp=TRUE;
            else
                  use_regexp=FALSE;

            /* use regular expression matching */
            if(use_regexp==TRUE){

                  /* compile regular expression */
                  if(regcomp(&preg,temp_ptr,0)){
                        free(hostgroup_names);
                        return ERROR;
                            }
                  
                  /* test match against all hostgroup names */
                  for(temp_hostgroup=xodtemplate_hostgroup_list;temp_hostgroup!=NULL;temp_hostgroup=temp_hostgroup->next){

                        if(temp_hostgroup->hostgroup_name==NULL)
                              continue;

                        /* skip this hostgroup if it did not match the expression */
                        if(regexec(&preg,temp_hostgroup->hostgroup_name,0,NULL,0))
                              continue;

                        found_match=TRUE;

                        /* dont' add hostgroups that shouldn't be registered */
                        if(temp_hostgroup->register_object==FALSE)
                              continue;

                        /* add hostgroup members to list */
                        xodtemplate_add_hostgroup_members_to_hostlist(list,temp_hostgroup);
                            } 

                  /* free memory allocated to compiled regexp */
                  regfree(&preg);
                    }
            
            /* use standard matching... */
            else{

                  /* return a list of all hostgroups */
                  if(!strcmp(temp_ptr,"*")){

                        found_match=TRUE;

                        for(temp_hostgroup=xodtemplate_hostgroup_list;temp_hostgroup!=NULL;temp_hostgroup=temp_hostgroup->next){    

                              /* dont' add hostgroups that shouldn't be registered */
                              if(temp_hostgroup->register_object==FALSE)
                                    continue;

                              /* add hostgroup to list */
                              xodtemplate_add_hostgroup_members_to_hostlist(list,temp_hostgroup);
                                }
                          }

                  /* else this is just a single hostgroup... */
                  else{
                  
                        /* this hostgroup should be excluded (rejected) */
                        if(temp_ptr[0]=='!'){
                              reject_item=TRUE;
                              temp_ptr++;
                              }

                        /* find the hostgroup */
                        temp_hostgroup=xodtemplate_find_real_hostgroup(temp_ptr);
                        if(temp_hostgroup!=NULL){

                              found_match=TRUE;

                              /* add hostgroup members to proper list */
                              xodtemplate_add_hostgroup_members_to_hostlist((reject_item==TRUE)?reject_list:list,temp_hostgroup);
                                }
                          }
                    }

            if(found_match==FALSE){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not find any hostgroup matching '%s'\n",temp_ptr);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  break;
                      }
              }

      /* free memory */
      free(hostgroup_names);

#ifdef DEBUG0
      printf("xodtemplate_expand_hostgroups() end\n");
#endif

      if(found_match==FALSE)
            return ERROR;

      return OK;
        }



/* expands hosts */
int xodtemplate_expand_hosts(xodtemplate_hostlist **list, xodtemplate_hostlist **reject_list,char *hosts){
      char *host_names;
      char *temp_ptr;
      xodtemplate_host *temp_host;
      regex_t preg;
      int found_match=TRUE;
      int reject_item=FALSE;
      int use_regexp=FALSE;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_expand_hosts() start\n");
#endif

      if(list==NULL || hosts==NULL)
            return ERROR;

      host_names=strdup(hosts);
      if(host_names==NULL)
            return ERROR;

      /* expand each host name */
      for(temp_ptr=strtok(host_names,",");temp_ptr;temp_ptr=strtok(NULL,",")){

            found_match=FALSE;
            reject_item=FALSE;

            /* strip trailing spaces */
            strip(temp_ptr);

            /* should we use regular expression matching? */
            if(use_regexp_matches==TRUE && (use_true_regexp_matching==TRUE || strstr(temp_ptr,"*") || strstr(temp_ptr,"?")))
                  use_regexp=TRUE;

            /* use regular expression matching */
            if(use_regexp==TRUE){

                  /* compile regular expression */
                  if(regcomp(&preg,temp_ptr,0)){
                        free(host_names);
                        return ERROR;
                            }
                  
                  /* test match against all hosts */
                  for(temp_host=xodtemplate_host_list;temp_host!=NULL;temp_host=temp_host->next){

                        if(temp_host->host_name==NULL)
                              continue;

                        /* skip this host if it did not match the expression */
                        if(regexec(&preg,temp_host->host_name,0,NULL,0))
                              continue;

                        found_match=TRUE;

                        /* dont' add hosts that shouldn't be registered */
                        if(temp_host->register_object==FALSE)
                              continue;

                        /* add host to list */
                        xodtemplate_add_host_to_hostlist(list,temp_host->host_name);
                            } 

                  /* free memory allocated to compiled regexp */
                  regfree(&preg);
                    }
            
            /* use standard matching... */
            else{

                  /* return a list of all hosts */
                  if(!strcmp(temp_ptr,"*")){

                        found_match=TRUE;

                        for(temp_host=xodtemplate_host_list;temp_host!=NULL;temp_host=temp_host->next){

                              if(temp_host->host_name==NULL)
                                    continue;

                              /* dont' add hosts that shouldn't be registered */
                              if(temp_host->register_object==FALSE)
                                    continue;

                              /* add host to list */
                              xodtemplate_add_host_to_hostlist(list,temp_host->host_name);
                                }
                          }

                  /* else this is just a single host... */
                  else{

                        /* this host should be excluded (rejected) */
                        if(temp_ptr[0]=='!'){
                              reject_item=TRUE;
                              temp_ptr++;
                                  }

                        /* find the host */
                        temp_host=xodtemplate_find_real_host(temp_ptr);
                        if(temp_host!=NULL){

                              found_match=TRUE;

                              /* add host to list */
                              xodtemplate_add_host_to_hostlist((reject_item==TRUE)?reject_list:list,temp_ptr);
                                }
                          }
                    }

            if(found_match==FALSE){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not find any host matching '%s'\n",temp_ptr);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  break;
                      }
              }

      /* free memory */
      free(host_names);

#ifdef DEBUG0
      printf("xodtemplate_expand_hosts() end\n");
#endif

      if(found_match==FALSE)
            return ERROR;

      return OK;
        }


/* adds members of a hostgroups to the list of expanded (accepted) or rejected hosts */
int xodtemplate_add_hostgroup_members_to_hostlist(xodtemplate_hostlist **list, xodtemplate_hostgroup *temp_hostgroup){
      char *group_members;
      char *member_name;
      char *member_ptr;

      if(list==NULL || temp_hostgroup==NULL)
            return ERROR;

      /* skip hostgroups with no defined members */
      if(temp_hostgroup->members==NULL)
            return OK;

      /* save a copy of the members */
      group_members=strdup(temp_hostgroup->members);
      if(group_members==NULL)
            return ERROR;

      /* process all hosts that belong to the hostgroup */
      /* NOTE: members of the group have already have been expanded by xodtemplate_recombobulate_hostgroups(), so we don't need to do it here */
      member_ptr=group_members;
      for(member_name=my_strsep(&member_ptr,",");member_name!=NULL;member_name=my_strsep(&member_ptr,",")){

            /* strip trailing spaces from member name */
            strip(member_name);

            /* add host to the list */
            xodtemplate_add_host_to_hostlist(list,member_name);
              }

      free(group_members);

      return OK;
        }


/* adds a host entry to the list of expanded (accepted) or rejected hosts */
int xodtemplate_add_host_to_hostlist(xodtemplate_hostlist **list, char *host_name){
      xodtemplate_hostlist *temp_item;
      xodtemplate_hostlist *new_item;

      if(list==NULL || host_name==NULL)
            return ERROR;

      /* skip this host if its already in the list */
      for(temp_item=*list;temp_item;temp_item=temp_item->next)
            if(!strcmp(temp_item->host_name,host_name))
                  break;
      if(temp_item)
            return OK;

      /* allocate memory for a new list item */
      new_item=(xodtemplate_hostlist *)malloc(sizeof(xodtemplate_hostlist));
      if(new_item==NULL)
            return ERROR;

      /* save the host name */
      new_item->host_name=strdup(host_name);
      if(new_item->host_name==NULL){
            free(new_item);
            return ERROR;
              }

      /* add new item to head of list */
      new_item->next=*list;
      *list=new_item;

      return OK;
        }


/* expands a comma-delimited list of servicegroups and/or service descriptions */
xodtemplate_servicelist *xodtemplate_expand_servicegroups_and_services(char *servicegroups,char *host_name,char *services){
      xodtemplate_servicelist *temp_list=NULL;
      xodtemplate_servicelist *reject_list=NULL;
      xodtemplate_servicelist *list_ptr=NULL;
      xodtemplate_servicelist *reject_ptr=NULL;
      int result;

#ifdef DEBUG0
      printf("xodtemplate_expand_servicegroups_and_services() start\n");
#endif

      /* process list of servicegroups... */
      if(servicegroups!=NULL){

            /* expand services */
            result=xodtemplate_expand_servicegroups(&temp_list,&reject_list,servicegroups);
            if(result!=OK){
                  xodtemplate_free_servicelist(temp_list);
                  xodtemplate_free_servicelist(reject_list);
                  return NULL;
                    }

            /* remove rejects (if any) from the list (no duplicate entries exist in either list) */
            for(reject_ptr=reject_list;reject_ptr!=NULL;reject_ptr=reject_ptr->next){
                  for(list_ptr=temp_list;list_ptr!=NULL;list_ptr=list_ptr->next){
                        if(!strcmp(reject_ptr->host_name,list_ptr->host_name) && !strcmp(reject_ptr->service_description,list_ptr->service_description)){
                              xodtemplate_remove_servicelist_item(list_ptr,&temp_list);
                              break;
                                  }
                            }
                      }
            xodtemplate_free_servicelist(reject_list);
            reject_list=NULL;
              }

      /* process service names */
      if(host_name!=NULL && services!=NULL){

            /* expand services */
            result=xodtemplate_expand_services(&temp_list,&reject_list,host_name,services);
            if(result!=OK){
                  xodtemplate_free_servicelist(temp_list);
                  xodtemplate_free_servicelist(reject_list);
                  return NULL;
                    }

            /* remove rejects (if any) from the list (no duplicate entries exist in either list) */
            /* NOTE: rejects from this list also affect hosts generated from processing hostgroup names (see above) */
            for(reject_ptr=reject_list;reject_ptr!=NULL;reject_ptr=reject_ptr->next){
                  for(list_ptr=temp_list;list_ptr!=NULL;list_ptr=list_ptr->next){
                        if(!strcmp(reject_ptr->host_name,list_ptr->host_name) && !strcmp(reject_ptr->service_description,list_ptr->service_description)){
                              xodtemplate_remove_servicelist_item(list_ptr,&temp_list);
                              break;
                                  }
                            }
                      }
            xodtemplate_free_servicelist(reject_list);
            reject_list=NULL;
              }

#ifdef DEBUG0
      printf("xodtemplate_expand_servicegroups_and_services() end\n");
#endif

      return temp_list;
        }


/* expands servicegroups */
int xodtemplate_expand_servicegroups(xodtemplate_servicelist **list, xodtemplate_servicelist **reject_list, char *servicegroups){
      xodtemplate_servicegroup  *temp_servicegroup;
      regex_t preg;
      char *servicegroup_names;
      char *temp_ptr;
      int found_match=TRUE;
      int reject_item=FALSE;
      int use_regexp=FALSE;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_expand_servicegroups() start\n");
#endif

      if(list==NULL || servicegroups==NULL)
            return ERROR;

      /* allocate memory for servicegroup name list */
      servicegroup_names=strdup(servicegroups);
      if(servicegroup_names==NULL)
            return ERROR;

      /* expand each servicegroup */
      for(temp_ptr=strtok(servicegroup_names,",");temp_ptr;temp_ptr=strtok(NULL,",")){

            found_match=FALSE;
            reject_item=FALSE;
            
            /* strip trailing spaces */
            strip(temp_ptr);

            /* should we use regular expression matching? */
            if(use_regexp_matches==TRUE && (use_true_regexp_matching==TRUE || strstr(temp_ptr,"*") || strstr(temp_ptr,"?")))
                  use_regexp=TRUE;
            else
                  use_regexp=FALSE;

            /* use regular expression matching */
            if(use_regexp==TRUE){

                  /* compile regular expression */
                  if(regcomp(&preg,temp_ptr,0)){
                        free(servicegroup_names);
                        return ERROR;
                            }
                  
                  /* test match against all servicegroup names */
                  for(temp_servicegroup=xodtemplate_servicegroup_list;temp_servicegroup!=NULL;temp_servicegroup=temp_servicegroup->next){

                        if(temp_servicegroup->servicegroup_name==NULL)
                              continue;

                        /* skip this servicegroup if it did not match the expression */
                        if(regexec(&preg,temp_servicegroup->servicegroup_name,0,NULL,0))
                              continue;

                        found_match=TRUE;

                        /* dont' add servicegroups that shouldn't be registered */
                        if(temp_servicegroup->register_object==FALSE)
                              continue;

                        /* add servicegroup members to list */
                        xodtemplate_add_servicegroup_members_to_servicelist(list,temp_servicegroup);
                          }

                  /* free memory allocated to compiled regexp */
                  regfree(&preg);
                    }
            
            /* use standard matching... */
            else{

                  /* return a list of all servicegroups */
                  if(!strcmp(temp_ptr,"*")){

                        found_match=TRUE;

                        for(temp_servicegroup=xodtemplate_servicegroup_list;temp_servicegroup!=NULL;temp_servicegroup=temp_servicegroup->next){ 

                              /* dont' add servicegroups that shouldn't be registered */
                              if(temp_servicegroup->register_object==FALSE)
                                    continue;

                              /* add servicegroup to list */
                              xodtemplate_add_servicegroup_members_to_servicelist(list,temp_servicegroup);
                                }
                          }

                  /* else this is just a single servicegroup... */
                  else{
                  
                        /* this servicegroup should be excluded (rejected) */
                        if(temp_ptr[0]=='!'){
                              reject_item=TRUE;
                              temp_ptr++;
                                    }

                        /* find the servicegroup */
                        temp_servicegroup=xodtemplate_find_real_servicegroup(temp_ptr);
                        if(temp_servicegroup!=NULL){

                              found_match=TRUE;

                              /* add servicegroup members to list */
                              xodtemplate_add_servicegroup_members_to_servicelist((reject_item==TRUE)?reject_list:list,temp_servicegroup);
                                }
                          }
                    }

            /* we didn't find a matching servicegroup */
            if(found_match==FALSE){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not find any servicegroup matching '%s'\n",temp_ptr);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  break;
                    }
              }

      /* free memory */
      free(servicegroup_names);

#ifdef DEBUG0
      printf("xodtemplate_expand_servicegroups() end\n");
#endif

      if(found_match==FALSE)
            return ERROR;

      return OK;
        }


/* expands services (host name is not expanded) */
int xodtemplate_expand_services(xodtemplate_servicelist **list, xodtemplate_servicelist **reject_list, char *host_name, char *services){
      char *service_names;
      char *temp_ptr;
      xodtemplate_service *temp_service;
      regex_t preg;
      regex_t preg2;
      int found_match=TRUE;
      int reject_item=FALSE;
      int use_regexp_host=FALSE;
      int use_regexp_service=FALSE;
#ifdef NSCORE
      char temp_buffer[MAX_XODTEMPLATE_INPUT_BUFFER];
#endif

#ifdef DEBUG0
      printf("xodtemplate_expand_services() start\n");
#endif

      if(list==NULL || host_name==NULL || services==NULL)
            return ERROR;

      /* should we use regular expression matching for the host name? */
      if(use_regexp_matches==TRUE && (use_true_regexp_matching==TRUE || strstr(host_name,"*") || strstr(host_name,"?")))
            use_regexp_host=TRUE;

      /* compile regular expression for host name */
      if(use_regexp_host==TRUE){
            if(regcomp(&preg2,host_name,0))
                  return ERROR;
              }

      service_names=strdup(services);
      if(service_names==NULL){
            if(use_regexp_host==TRUE)
                  regfree(&preg2);
            return ERROR;
              }

      /* expand each service description */
      for(temp_ptr=strtok(service_names,",");temp_ptr;temp_ptr=strtok(NULL,",")){

            found_match=FALSE;
            reject_item=FALSE;

            /* strip trailing spaces */
            strip(temp_ptr);

            /* should we use regular expression matching for the service description? */
            if(use_regexp_matches==TRUE && (use_true_regexp_matching==TRUE || strstr(temp_ptr,"*") || strstr(temp_ptr,"?")))
                  use_regexp_service=TRUE;
            else
                  use_regexp_service=FALSE;

            /* compile regular expression for service description */
            if(use_regexp_service==TRUE){
                  if(regcomp(&preg,temp_ptr,0)){
                        if(use_regexp_host==TRUE)
                              regfree(&preg2);
                        free(service_names);
                        return ERROR;
                          }
                  }

            /* use regular expression matching */
            if(use_regexp_host==TRUE || use_regexp_service==TRUE){

                  /* test match against all services */
                  for(temp_service=xodtemplate_service_list;temp_service!=NULL;temp_service=temp_service->next){

                        if(temp_service->host_name==NULL || temp_service->service_description==NULL)
                              continue;

                        /* skip this service if it doesn't match the host name expression */
                        if(use_regexp_host==TRUE){
                              if(regexec(&preg2,temp_service->host_name,0,NULL,0))
                                    continue;
                                }
                        else{
                              if(strcmp(temp_service->host_name,host_name))
                                    continue;
                                }

                        /* skip this service if it doesn't match the service description expression */
                        if(use_regexp_service==TRUE){
                              if(regexec(&preg,temp_service->service_description,0,NULL,0))
                                    continue;
                                }
                        else{
                              if(strcmp(temp_service->service_description,temp_ptr))
                                    continue;
                                }

                        found_match=TRUE;

                        /* dont' add services that shouldn't be registered */
                        if(temp_service->register_object==FALSE)
                              continue;

                        /* add service to the list */
                        xodtemplate_add_service_to_servicelist(list,host_name,temp_service->service_description);
                          }

                  /* free memory allocated to compiled regexp */
                  if(use_regexp_service==TRUE)
                        regfree(&preg);
                    }

            /* use standard matching... */
            else{

                  /* return a list of all services on the host */
                  if(!strcmp(temp_ptr,"*")){

                        found_match=TRUE;

                        for(temp_service=xodtemplate_service_list;temp_service!=NULL;temp_service=temp_service->next){

                              if(temp_service->host_name==NULL || temp_service->service_description==NULL)
                                    continue;

                              if(strcmp(temp_service->host_name,host_name))
                                    continue;

                              /* dont' add services that shouldn't be registered */
                              if(temp_service->register_object==FALSE)
                                    continue;

                              /* add service to the list */
                              xodtemplate_add_service_to_servicelist(list,host_name,temp_service->service_description);
                                }
                          }

                  /* else this is just a single service... */
                  else{

                        /* this service should be excluded (rejected) */
                        if(temp_ptr[0]=='!'){
                              reject_item=TRUE;
                              temp_ptr++;
                                    }

                        /* find the service */
                        temp_service=xodtemplate_find_real_service(host_name,temp_ptr);
                        if(temp_service!=NULL){

                              found_match=TRUE;

                              /* add service to the list */
                              xodtemplate_add_service_to_servicelist((reject_item==TRUE)?reject_list:list,host_name,temp_service->service_description);
                                }
                          }
                    }

            /* we didn't find a match */
            if(found_match==FALSE){
#ifdef NSCORE
                  snprintf(temp_buffer,sizeof(temp_buffer)-1,"Error: Could not find a service matching host name '%s' and description '%s'\n",host_name,temp_ptr);
                  temp_buffer[sizeof(temp_buffer)-1]='\x0';
                  write_to_logs_and_console(temp_buffer,NSLOG_CONFIG_ERROR,TRUE);
#endif
                  break;
                      }
              }

      if(use_regexp_host==TRUE)
            regfree(&preg2);
      free(service_names);

#ifdef DEBUG0
      printf("xodtemplate_expand_services() end\n");
#endif

      if(found_match==FALSE)
            return ERROR;

      return OK;
        }


/* adds members of a servicegroups to the list of expanded services */
int xodtemplate_add_servicegroup_members_to_servicelist(xodtemplate_servicelist **list, xodtemplate_servicegroup *temp_servicegroup){
      char *group_members;
      char *member_name;
      char *host_name;
      char *member_ptr;

      if(list==NULL || temp_servicegroup==NULL)
            return ERROR;

      /* skip servicegroups with no defined members */
      if(temp_servicegroup->members==NULL)
            return OK;

      /* save a copy of the members */
      group_members=strdup(temp_servicegroup->members);
      if(group_members==NULL)
            return ERROR;

      /* process all services that belong to the servicegroup */
      /* NOTE: members of the group have already have been expanded by xodtemplate_recombobulate_servicegroups(), so we don't need to do it here */
      member_ptr=group_members;
      host_name=NULL;
      for(member_name=my_strsep(&member_ptr,",");member_name!=NULL;member_name=my_strsep(&member_ptr,",")){

            /* strip trailing spaces from member name */
            strip(member_name);

            /* host name */
            if(host_name==NULL){
                  host_name=strdup(member_name);
                  if(host_name==NULL){
                        free(group_members);
                        return ERROR;
                          }
                    }

            /* service description */
            else{
                        
                  /* add service to the list */
                  xodtemplate_add_service_to_servicelist(list,host_name,member_name);

                  free(host_name);
                  host_name=NULL;
                    }
              }

      free(group_members);

      return OK;
        }


/* adds a service entry to the list of expanded services */
int xodtemplate_add_service_to_servicelist(xodtemplate_servicelist **list, char *host_name, char *description){
      xodtemplate_servicelist *temp_item;
      xodtemplate_servicelist *new_item;

      if(list==NULL || host_name==NULL || description==NULL)
            return ERROR;

      /* skip this service if its already in the list */
      for(temp_item=*list;temp_item;temp_item=temp_item->next)
            if(!strcmp(temp_item->host_name,host_name) && !strcmp(temp_item->service_description,description))
                  break;
      if(temp_item)
            return OK;

      /* allocate memory for a new list item */
      new_item=(xodtemplate_servicelist *)malloc(sizeof(xodtemplate_servicelist));
      if(new_item==NULL)
            return ERROR;

      /* save the host name and service description */
      new_item->host_name=strdup(host_name);
      new_item->service_description=strdup(description);
      if(new_item->host_name==NULL || new_item->service_description==NULL){
            free(new_item);
            return ERROR;
              }

      /* add new item to head of list */
      new_item->next=*list;
      *list=new_item;

      return OK;
        }


/* returns the name of a numbered config file */
char *xodtemplate_config_file_name(int config_file){

      if(config_file<=xodtemplate_current_config_file)
            return xodtemplate_config_files[config_file-1];

      return "?";
        }

#endif



Generated by  Doxygen 1.6.0   Back to index