/*
 * 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.
 */

#ifndef AXIS2_ARCH_FILE_DATA_H
#define AXIS2_ARCH_FILE_DATA_H

/** @defgroup axis2_arch_file_data Arch File Data
 * @ingroup axis2_deployment
 * @{
 */

/**
 * @file axis2_arch_file_data.h
 * @brief Axis2 Arch File Data interface. arch_file_data construct contain 
 * deployment information retrieved from a module or service configuration file.
 */
#include <axis2_const.h>
#include <axutil_error.h>
#include <axis2_defines.h>
#include <axutil_env.h>
#include <axutil_allocator.h>
#include <axutil_qname.h>
#include <axis2_conf.h>
#include <axutil_array_list.h>
#include <axutil_dir_handler.h>
#include <axutil_file.h>

#ifdef __cplusplus
extern "C"
{
#endif

    struct axis2_conf;

    /** Type name for struct axis2_arch_fila_data */
    typedef struct axis2_arch_file_data axis2_arch_file_data_t;

    /**
     * De-allocate memory
     * @param arch_file_data pointer to arch_file_data
     * @param env pointer to environment struct
     * @return void
     */
    AXIS2_EXTERN void AXIS2_CALL
    axis2_arch_file_data_free(
        axis2_arch_file_data_t * arch_file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     */
    AXIS2_EXTERN axis2_char_t *AXIS2_CALL
    axis2_arch_file_data_get_msg_recv(
        const axis2_arch_file_data_t * file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     * @param msg_recv pointer to message receiver
     * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE
     */
    AXIS2_EXTERN axis2_status_t AXIS2_CALL
    axis2_arch_file_data_set_msg_recv(
        axis2_arch_file_data_t * file_data,
        const axutil_env_t * env,
        axis2_char_t * msg_recv);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     * @return the name of the contained file.
     */
    AXIS2_EXTERN axis2_char_t *AXIS2_CALL
    axis2_arch_file_data_get_name(
        const axis2_arch_file_data_t * file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     * @return the service name. If contained file is not null this is the
     * file name. else this is the name property
     */
    AXIS2_EXTERN axis2_char_t *AXIS2_CALL
    axis2_arch_file_data_get_svc_name(
        const axis2_arch_file_data_t * file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     */
    AXIS2_EXTERN int AXIS2_CALL
    axis2_arch_file_data_get_type(
        const axis2_arch_file_data_t * file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     */
    AXIS2_EXTERN axutil_file_t *AXIS2_CALL
    axis2_arch_file_data_get_file(
        const axis2_arch_file_data_t * file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     */
    AXIS2_EXTERN axis2_char_t *AXIS2_CALL

    axis2_arch_file_data_get_module_name(
        const axis2_arch_file_data_t * file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     * @param module_name pointer to module_name
     * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE
     */
    AXIS2_EXTERN axis2_status_t AXIS2_CALL

    axis2_arch_file_data_set_module_name(
        axis2_arch_file_data_t * file_data,
        const axutil_env_t * env,
        axis2_char_t * module_name);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     */
    AXIS2_EXTERN axis2_char_t *AXIS2_CALL

    axis2_arch_file_data_get_module_dll_name(
        const axis2_arch_file_data_t * file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE
     */
    AXIS2_EXTERN axis2_status_t AXIS2_CALL

    axis2_arch_file_data_set_module_dll_name(
        axis2_arch_file_data_t * file_data,
        const axutil_env_t * env,
        axis2_char_t * module_dll_name);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE
     */
    AXIS2_EXTERN axis2_status_t AXIS2_CALL
    axis2_arch_file_data_add_svc(
        axis2_arch_file_data_t * file_data,
        const axutil_env_t * env,
        struct axis2_svc *svc_desc);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     */
    AXIS2_EXTERN struct axis2_svc *AXIS2_CALL
                axis2_arch_file_data_get_svc(
                    const axis2_arch_file_data_t * file_data,
                    const axutil_env_t * env,
                    axis2_char_t * svc_name);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     */
    AXIS2_EXTERN axutil_hash_t *AXIS2_CALL
    axis2_arch_file_data_get_svc_map(
        const axis2_arch_file_data_t * file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     */
    AXIS2_EXTERN axutil_array_list_t *AXIS2_CALL

    axis2_arch_file_data_get_deployable_svcs(
        const axis2_arch_file_data_t * file_data,
        const axutil_env_t * env);

    /**
     * @param file_data pointer to arch_file_data
     * @param env pointer to environment struct
     * @param deployable_svcs pointer to deployable services
     * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE
     */
    AXIS2_EXTERN axis2_status_t AXIS2_CALL

    axis2_arch_file_data_set_deployable_svcs(
        axis2_arch_file_data_t * file_data,
        const axutil_env_t * env,
        axutil_array_list_t * deployable_svcs);

    /**
     * Creates arch file data struct
     * @param env pointer to environment struct
     * @return pointer to newly created arch file data
     */
    AXIS2_EXTERN axis2_arch_file_data_t *AXIS2_CALL

    axis2_arch_file_data_create(
        const axutil_env_t * env);

    /**
     * Creates arch file data struct
     * @param env pointer to environment struct
     * @param type type
     * @param file folder name of service or module
     * @return pointer to newly created arch file data
     */
    AXIS2_EXTERN axis2_arch_file_data_t *AXIS2_CALL

    axis2_arch_file_data_create_with_type_and_file(
        const axutil_env_t * env,
        int type,
        axutil_file_t * file);

    /**
     * Creates arch file data struct
     * @param env pointer to environment struct
     * @param type type
     * @param name pointer to name
     * @return pointer to newly created arch file data
     */
    AXIS2_EXTERN axis2_arch_file_data_t *AXIS2_CALL

    axis2_arch_file_data_create_with_type_and_name(
        const axutil_env_t * env,
        int type,
        const axis2_char_t * name);

    /** @} */

#ifdef __cplusplus
}
#endif
#endif                          /* AXIS2_ARCH_FILE_DATA_H */