blob: f251dc065de3e656e7ec2e13f11669674fd4f0b2 [file] [log] [blame]
/** @file
A brief file description
@section license License
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.
*/
/*****************************************************************************
* Filename: NetworkUtilsRemote.h
* Purpose: This file contains functions used by remote api client to
* marshal requests to TM and unmarshal replies from TM.
* Also contains functions used to store information specific
* to a remote client connection.
* Created: 8/9/00
* Created by: lant
*
***************************************************************************/
#ifndef _NETWORK_UTILS_H_
#define _NETWORK_UTILS_H_
#include "ink_defs.h"
#include "ink_mutex.h"
#include "mgmtapi.h"
#include "NetworkUtilsDefs.h"
#include "EventCallback.h"
#ifdef __cplusplus
extern "C"
{
#endif /* __cplusplus */
const int DEFAULT_STACK_SIZE = 1048576; // 1MB stack
/**********************************************************************
* Socket Helper Functions
**********************************************************************/
void set_socket_paths(const char *path);
int socket_test(int fd);
/* The following functions are specific for a client connection; uses
* the client connection information stored in the variables in
* NetworkUtilsRemote.cc
*/
TSError ts_connect(); /* TODO: update documenation, Renamed due to conflict with connect() in <sys/socket.h> on some platforms*/
TSError disconnect();
TSError reconnect();
TSError reconnect_loop(int num_attempts);
TSError connect_and_send(const char *msg, int msg_len);
void *socket_test_thread(void *arg);
/*****************************************************************************
* Marshalling (create requests)
*****************************************************************************/
TSError send_request(int fd, OpType op);
TSError send_request_name(int fd, OpType op, const char *name);
TSError send_request_name_value(int fd, OpType op, const char *name, const char *value);
TSError send_request_bool(int fd, OpType op, bool flag);
TSError send_file_read_request(int fd, TSFileNameT file);
TSError send_file_write_request(int fd, TSFileNameT file, int ver, int size, char *text);
TSError send_record_get_request(int fd, const char *rec_name);
TSError send_record_match_request(int fd, const char *rec_regex);
TSError send_proxy_state_set_request(int fd, TSProxyStateT state, TSCacheClearT clear);
TSError send_register_all_callbacks(int fd, CallbackTable * cb_table);
TSError send_unregister_all_callbacks(int fd, CallbackTable * cb_table);
TSError send_diags_msg(int fd, TSDiagsT mode, const char *diag_msg);
/*****************************************************************************
* Un-marshalling (parse responses)
*****************************************************************************/
TSError parse_reply(int fd);
TSError parse_reply_list(int fd, char **list);
TSError parse_file_read_reply(int fd, int *version, int *size, char **text);
TSError parse_record_get_reply(int fd, TSRecordT * rec_type, void **rec_val, char **rec_name);
TSError parse_record_set_reply(int fd, TSActionNeedT * action_need);
TSError parse_proxy_state_get_reply(int fd, TSProxyStateT * state);
TSError parse_event_active_reply(int fd, bool * is_active);
TSError parse_event_notification(int fd, TSEvent * event);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif