blob: 50d00b83e7990806d929f0f266deb0c81868d443 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <axutil_dir_handler.h>
#include <axutil_file.h>
#include <platforms/axutil_platform_auto_sense.h>
#include <axutil_string.h>
#ifndef S_ISDIR
# define S_ISDIR(m) ((m & S_IFMT) == S_IFDIR)
#endif
#ifdef AXIS2_ARCHIVE_ENABLED
#include <minizip/axis2_archive_extract.h>
#endif
extern int AXIS2_ALPHASORT(
);
#ifdef IS_MACOSX
int dir_select(
struct dirent *entry);
int file_select(
struct dirent *entry);
#else
int dir_select(
const struct dirent *entry);
int file_select(
const struct dirent *entry);
#endif
/**
* List the dll files in the given service or module folder path
* @param pathname path to your service or module directory
* @return array list of dll file names
*/
AXIS2_EXTERN axutil_array_list_t *AXIS2_CALL
axutil_dir_handler_list_services_or_modules_in_dir(
const axutil_env_t *env,
const axis2_char_t *pathname)
{
axutil_array_list_t *file_list = NULL;
struct stat *buf = NULL;
int count = 1;
int i = 0;
struct dirent **files = NULL;
/*int file_select(
);*/
/* Removed un-wanted redefinition leading to warnings on
* Windows. If this is the desired behaviour, please look
* into the file_select function definition below and comment
* out the code if neccessary.
*/
axis2_status_t status = AXIS2_FAILURE;
AXIS2_ENV_CHECK(env, NULL);
file_list = axutil_array_list_create(env, 100);
count = AXIS2_SCANDIR(pathname, &files, file_select, AXIS2_ALPHASORT);
/* If no files found, make a non-selectable menu item */
if(count <= 0)
{
axutil_array_list_free(file_list, env);
AXIS2_LOG_DEBUG(env->log, AXIS2_LOG_SI, "No files in the path %s.", pathname);
return NULL;
}
for(i = 1; i < (count + 1); ++i)
{
axis2_char_t *fname = NULL;
axutil_file_t *arch_file = NULL;
axis2_char_t *path = NULL;
axis2_char_t *temp_path = NULL;
fname = files[i - 1]->d_name;
arch_file = (axutil_file_t *)axutil_file_create(env);
if(!arch_file)
{
int size = 0;
int j = 0;
axutil_file_t *del_file = NULL;
size = axutil_array_list_size(file_list, env);
for(j = 0; j < size; j++)
{
del_file = axutil_array_list_get(file_list, env, j);
axutil_file_free(del_file, env);
}
axutil_array_list_free(file_list, env);
AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE);
return NULL;
}
axutil_file_set_name(arch_file, env, fname);
temp_path = axutil_stracat(env, pathname, AXIS2_PATH_SEP_STR);
path = axutil_stracat(env, temp_path, fname);
AXIS2_FREE(env->allocator, temp_path);
if(!path)
{
int size = 0;
int j = 0;
axutil_file_t *del_file = NULL;
axutil_file_free(arch_file, env);
size = axutil_array_list_size(file_list, env);
for(j = 0; j < size; j++)
{
del_file = axutil_array_list_get(file_list, env, j);
axutil_file_free(del_file, env);
}
axutil_array_list_free(file_list, env);
AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE);
return NULL;
}
axutil_file_set_path(arch_file, env, path);
buf = AXIS2_MALLOC(env->allocator, sizeof(struct stat));
if(!buf)
{
int size = 0;
int j = 0;
axutil_file_t *del_file = NULL;
AXIS2_FREE(env->allocator, path);
axutil_file_free(arch_file, env);
size = axutil_array_list_size(file_list, env);
for(j = 0; j < size; j++)
{
del_file = axutil_array_list_get(file_list, env, j);
axutil_file_free(del_file, env);
}
axutil_array_list_free(file_list, env);
AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE);
return NULL;
}
stat(path, buf);
axutil_file_set_timestamp(arch_file, env, (time_t)buf->st_ctime);
status = axutil_array_list_add(file_list, env, arch_file);
if(AXIS2_SUCCESS != status)
{
int size = 0;
int j = 0;
axutil_file_t *del_file = NULL;
axutil_file_free(arch_file, env);
AXIS2_FREE(env->allocator, path);
AXIS2_FREE(env->allocator, buf);
size = axutil_array_list_size(file_list, env);
for(j = 0; j < size; j++)
{
del_file = axutil_array_list_get(file_list, env, j);
axutil_file_free(del_file, env);
}
axutil_array_list_free(file_list, env);
return NULL;
}
AXIS2_FREE(env->allocator, path);
AXIS2_FREE(env->allocator, buf);
}
return file_list;
}
/**
* List services or modules directories in the services or modules folder
* respectively
* @param pathname path your modules or services folder
* @return array list of contents of services or modules folder
*/
AXIS2_EXTERN axutil_array_list_t *AXIS2_CALL
axutil_dir_handler_list_service_or_module_dirs(
const axutil_env_t *env,
const axis2_char_t *pathname)
{
axutil_array_list_t *file_list = NULL;
struct stat *buf = NULL;
int count = 1;
int i = 0;
struct dirent **files = NULL;
char cwd[500];
int chdir_result = 0;
/**FIXME:
* This magic number 500 was selected as a temporary solution. It has to be
* replaced with dynamic memory allocation. This will be done once the use of
* errno after getwcd() on Windows is figured out.
*/
axis2_status_t status = AXIS2_FAILURE;
if(!AXIS2_GETCWD(cwd, 500))
{
/* if we can't identify working directory, it will be a critical failure */
AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Cannot identify working directory");
exit(1);
}
/* pathname is path of services directory or modules directory. */
chdir_result = AXIS2_CHDIR(pathname);
if(chdir_result == -1)
{
/* we could not be able to find the path given. However, this will not be a problem
* because services and modules are optional.
*/
AXIS2_LOG_INFO(env->log, "Cannot find path %s.", pathname);
return NULL;
}
#ifdef AXIS2_ARCHIVE_ENABLED
axis2_archive_extract();
#endif
count = AXIS2_SCANDIR(pathname, &files, dir_select, AXIS2_ALPHASORT);
chdir_result = AXIS2_CHDIR(cwd);
if(chdir_result == -1)
{
/* we are changing back to working directory. If we can't change, this will be critical*/
AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Cannot change directory to working directory");
exit(1);
}
/* If no files found, make a non-selectable menu item */
if(count <= 0)
{
AXIS2_LOG_INFO(env->log, "No files in the path %s.", pathname);
return NULL;
}
file_list = axutil_array_list_create(env, 0);
if(!file_list)
{
AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Cannot create file list.");
AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE);
return NULL;
}
for(i = 1; i < (count + 1); ++i)
{
axis2_char_t *fname = NULL;
axutil_file_t *arch_file = NULL;
axis2_char_t *path = NULL;
axis2_char_t *temp_path = NULL;
fname = files[i - 1]->d_name;
arch_file = (axutil_file_t *)axutil_file_create(env);
if(!arch_file)
{
int size = 0;
int j = 0;
axutil_file_t *del_file = NULL;
size = axutil_array_list_size(file_list, env);
for(j = 0; j < size; j++)
{
del_file = axutil_array_list_get(file_list, env, j);
axutil_file_free(del_file, env);
}
axutil_array_list_free(file_list, env);
AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE);
return NULL;
}
axutil_file_set_name(arch_file, env, fname);
temp_path = axutil_stracat(env, pathname, AXIS2_PATH_SEP_STR);
path = axutil_stracat(env, temp_path, fname);
if(!path)
{
int size = 0;
int j = 0;
axutil_file_t *del_file = NULL;
axutil_file_free(arch_file, env);
size = axutil_array_list_size(file_list, env);
for(j = 0; j < size; j++)
{
del_file = axutil_array_list_get(file_list, env, j);
axutil_file_free(del_file, env);
}
axutil_array_list_free(file_list, env);
AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE);
return NULL;
}
axutil_file_set_path(arch_file, env, path);
AXIS2_FREE(env->allocator, temp_path);
buf = AXIS2_MALLOC(env->allocator, sizeof(struct stat));
if(!buf)
{
int size = 0;
int j = 0;
axutil_file_t *del_file = NULL;
axutil_file_free(arch_file, env);
AXIS2_FREE(env->allocator, path);
size = axutil_array_list_size(file_list, env);
for(j = 0; j < size; j++)
{
del_file = axutil_array_list_get(file_list, env, j);
axutil_file_free(del_file, env);
}
axutil_array_list_free(file_list, env);
AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE);
return NULL;
}
stat(path, buf);
axutil_file_set_timestamp(arch_file, env, (time_t)buf->st_ctime);
status = axutil_array_list_add(file_list, env, arch_file);
if(AXIS2_SUCCESS != status)
{
int size = 0;
int j = 0;
axutil_file_t *del_file = NULL;
axutil_file_free(arch_file, env);
AXIS2_FREE(env->allocator, path);
AXIS2_FREE(env->allocator, buf);
size = axutil_array_list_size(file_list, env);
for(j = 0; j < size; j++)
{
del_file = axutil_array_list_get(file_list, env, j);
axutil_file_free(del_file, env);
}
axutil_array_list_free(file_list, env);
return NULL;
}
AXIS2_FREE(env->allocator, path);
AXIS2_FREE(env->allocator, buf);
}
for(i = 0; i < count; i++)
{
free(files[i]);
}
free(files);
return file_list;
}
#ifdef IS_MACOSX
int file_select(struct dirent *entry)
{
#else
int file_select(const struct dirent *entry)
{
#endif
/** FIXME:
* This block of code has been sitting here doing nothing.
* I have made the existing logic use this code portion.
* Have no idea about the side-effects of this modification.
* If this code block is not required, we might as well remove
* it.
*/
axis2_char_t *ptr;
if((strcmp(entry->d_name, ".") == 0) || (strcmp(entry->d_name, "..") == 0))
return (AXIS2_FALSE);
/* Check for filename extensions */
ptr = axutil_rindex(entry->d_name, '.');
if((ptr) && ((strcmp(ptr, AXIS2_LIB_SUFFIX) == 0)))
{
return (AXIS2_TRUE);
}
else
return (AXIS2_FALSE);
}
#ifdef IS_MACOSX
int
dir_select(
struct dirent *entry)
#else
int
dir_select(
const struct dirent *entry)
#endif
{
struct stat stat_p;
if(-1 == stat(entry->d_name, &stat_p))
return (AXIS2_FALSE);
if((entry->d_name[0] == '.') || (!S_ISDIR(stat_p.st_mode)))
{
return (AXIS2_FALSE);
}
return AXIS2_TRUE;
}