1 /*******************************************************
3 * Citadel Dynamic Loading Module
4 * Written by Brian Costello
7 ******************************************************/
13 #include <sys/types.h>
17 #include "dynloader.h"
19 symtab *global_symtab;
21 int DLoader_Exec_Cmd(char *cmdbuf)
26 void (*cmd_ptr)(void *);
28 for (t_sym = global_symtab; ((t_sym) && (strncmp(t_sym->server_cmd, cmdbuf, strlen(t_sym->server_cmd))) ); t_sym=t_sym->next)
33 if (!(fcn_handle = dlopen(t_sym->module_path, RTLD_LAZY)))
36 syslog(LOG_NOTICE, "WARNING: module %s failed to load", t_sym->module_path);
40 cmd_ptr = dlsym(fcn_handle, t_sym->fcn_name);
41 if ((dl_error = dlerror()) != NULL)
43 syslog(LOG_NOTICE, "dlsym error: %s - %s", dl_error, t_sym->module_path);
46 (*cmd_ptr)(&cmdbuf[5]);
48 if ((dl_error = dlerror()) != NULL)
50 syslog(LOG_NOTICE, "dlclose error: %s", dl_error);
54 } /* If symbol found */
59 void add_symbol(char *fcn_name, char *server_cmd, char *info_msg, symtab **first_symtab)
61 symtab *new_symtab, *t_sym, *last_sym;
63 if (!(new_symtab = malloc(sizeof(symtab))))
65 perror("Malloc new symtab");
69 new_symtab->fcn_name = strdup(fcn_name);
70 new_symtab->server_cmd = strdup(server_cmd);
71 new_symtab->info_msg = strdup(info_msg);
72 new_symtab->next = NULL;
75 (*first_symtab) = new_symtab;
79 for (t_sym = (*first_symtab); (t_sym); t_sym = t_sym->next)
81 last_sym->next = new_symtab;
85 void DLoader_Init(char *pathname, symtab **my_symtab)
88 void (*h_init_fcn)(struct DLModule_Info *);
89 void (*h_get_symtab)(symtab **);
96 struct DLModule_Info dl_info;
100 global_symtab = NULL; /* Global symbol table */
102 if ((dir = opendir(pathname))==NULL)
108 while ((dptr=readdir(dir))!= NULL)
110 if (dptr->d_name[0] == '.')
113 filename = strdup(dptr->d_name);
114 snprintf(pathbuf, 512, "%s/%s", pathname, filename);
115 if (!(fcn_handle = dlopen(pathbuf, RTLD_LAZY)))
117 dl_error = dlerror();
118 fprintf(stderr, "DLoader_Init dlopen failed (%s)", dl_error);
122 h_init_fcn = dlsym(fcn_handle, "Dynamic_Module_Init");
123 if ((dl_error = dlerror()) != NULL)
125 fprintf(stderr,"DLoader_Init dlsym failed (%s)", dl_error);
129 (*h_init_fcn)(&dl_info);
131 printf("Loaded module %s v%d.%d\nBy %s (%s)\n", dl_info.module_name,
132 dl_info.major_version,
133 dl_info.minor_version,
134 dl_info.module_author,
135 dl_info.module_author_email);
137 h_get_symtab = dlsym(fcn_handle, "Get_Symtab");
138 if ((dl_error = dlerror()) != NULL)
140 fprintf(stderr,"DLoader_Init dlsym failed for Get_Symtab (%s) on module %s", dl_error, dl_info.module_name);
144 /* Get the symbol table for the current module and link it on */
146 (*h_get_symtab)(&stab);
149 (*my_symtab) = global_symtab = stab;
153 for (t_sym = (*my_symtab) ; t_sym->next; t_sym=t_sym->next);
157 for (t_sym = stab; t_sym; t_sym=t_sym->next)
158 t_sym->module_path = (char *)strdup(pathbuf);
160 if ((dl_error = dlerror()) != NULL)
162 fprintf(stderr,"DLoader_Init dlclose failed (%s)", dl_error);