mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-03-13 12:40:17 +00:00
FS-5657 --resolve fix mod_rayo build errors in CentOS 5
This commit is contained in:
parent
fed93fd49e
commit
40c983beeb
@ -10,6 +10,7 @@ LOCAL_OBJS= $(IKS_LA) \
|
|||||||
iks_helpers.o \
|
iks_helpers.o \
|
||||||
nlsml.o \
|
nlsml.o \
|
||||||
rayo_components.o \
|
rayo_components.o \
|
||||||
|
rayo_elements.o \
|
||||||
rayo_input_component.o \
|
rayo_input_component.o \
|
||||||
rayo_output_component.o \
|
rayo_output_component.o \
|
||||||
rayo_prompt_component.o \
|
rayo_prompt_component.o \
|
||||||
@ -21,6 +22,7 @@ LOCAL_SOURCES= \
|
|||||||
iks_helpers.c \
|
iks_helpers.c \
|
||||||
nlsml.c \
|
nlsml.c \
|
||||||
rayo_components.c \
|
rayo_components.c \
|
||||||
|
rayo_elements.c \
|
||||||
rayo_input_component.c \
|
rayo_input_component.c \
|
||||||
rayo_output_component.c \
|
rayo_output_component.c \
|
||||||
rayo_prompt_component.c \
|
rayo_prompt_component.c \
|
||||||
|
@ -305,6 +305,93 @@ int value_matches(const char *value, const char *rule)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate boolean
|
||||||
|
* @param value
|
||||||
|
* @return SWTICH_TRUE if boolean
|
||||||
|
*/
|
||||||
|
int iks_attrib_is_bool(const char *value)
|
||||||
|
{
|
||||||
|
if (value && *value && (!strcasecmp("true", value) || !strcasecmp("false", value))) {
|
||||||
|
return SWITCH_TRUE;
|
||||||
|
}
|
||||||
|
return SWITCH_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate integer
|
||||||
|
* @param value
|
||||||
|
* @return SWTICH_TRUE if not negative
|
||||||
|
*/
|
||||||
|
int iks_attrib_is_not_negative(const char *value)
|
||||||
|
{
|
||||||
|
if (value && *value && switch_is_number(value)) {
|
||||||
|
int value_i = atoi(value);
|
||||||
|
if (value_i >= 0) {
|
||||||
|
return SWITCH_TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SWITCH_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate integer
|
||||||
|
* @param value
|
||||||
|
* @return SWTICH_TRUE if positive
|
||||||
|
*/
|
||||||
|
int iks_attrib_is_positive(const char *value)
|
||||||
|
{
|
||||||
|
if (value && *value && switch_is_number(value)) {
|
||||||
|
int value_i = atoi(value);
|
||||||
|
if (value_i > 0) {
|
||||||
|
return SWITCH_TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SWITCH_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate integer
|
||||||
|
* @param value
|
||||||
|
* @return SWTICH_TRUE if positive or -1
|
||||||
|
*/
|
||||||
|
int iks_attrib_is_positive_or_neg_one(const char *value)
|
||||||
|
{
|
||||||
|
if (value && *value && switch_is_number(value)) {
|
||||||
|
int value_i = atoi(value);
|
||||||
|
if (value_i == -1 || value_i > 0) {
|
||||||
|
return SWITCH_TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SWITCH_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate string
|
||||||
|
* @param value
|
||||||
|
* @return SWTICH_TRUE
|
||||||
|
*/
|
||||||
|
int iks_attrib_is_any(const char *value)
|
||||||
|
{
|
||||||
|
return SWITCH_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate decimal
|
||||||
|
* @param value
|
||||||
|
* @return SWTICH_TRUE if 0.0 <= x <= 1.0
|
||||||
|
*/
|
||||||
|
int iks_attrib_is_decimal_between_zero_and_one(const char *value)
|
||||||
|
{
|
||||||
|
if (value && *value && switch_is_number(value)) {
|
||||||
|
double value_d = atof(value);
|
||||||
|
if (value_d >= 0.0 || value_d <= 1.0) {
|
||||||
|
return SWITCH_TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SWITCH_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
#define IKS_SHA256_HEX_DIGEST_LENGTH ((SHA256_DIGEST_LENGTH * 2) + 1)
|
#define IKS_SHA256_HEX_DIGEST_LENGTH ((SHA256_DIGEST_LENGTH * 2) + 1)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -73,101 +73,20 @@ extern char *iks_server_dialback_key(const char *secret, const char *receiving_s
|
|||||||
/** A function to validate attribute value */
|
/** A function to validate attribute value */
|
||||||
typedef int (*iks_attrib_validation_function)(const char *);
|
typedef int (*iks_attrib_validation_function)(const char *);
|
||||||
|
|
||||||
#define ELEMENT(name) inline int VALIDATE_##name(iks *node) { int result = 1; if (!node) return 0;
|
#define ELEMENT_DECL(name) extern int VALIDATE_##name(iks *node);
|
||||||
|
#define ELEMENT(name) int VALIDATE_##name(iks *node) { int result = 1; if (!node) return 0;
|
||||||
#define ATTRIB(name, def, rule) result &= iks_attrib_is_##rule(iks_find_attrib_default(node, #name, #def));
|
#define ATTRIB(name, def, rule) result &= iks_attrib_is_##rule(iks_find_attrib_default(node, #name, #def));
|
||||||
#define STRING_ATTRIB(name, def, rule) result &= value_matches(iks_find_attrib_default(node, #name, #def), rule);
|
#define STRING_ATTRIB(name, def, rule) result &= value_matches(iks_find_attrib_default(node, #name, #def), rule);
|
||||||
#define ELEMENT_END return result; }
|
#define ELEMENT_END return result; }
|
||||||
|
|
||||||
extern int value_matches(const char *value, const char *rule);
|
extern int value_matches(const char *value, const char *rule);
|
||||||
|
|
||||||
#define ATTRIB_RULE(rule) inline int iks_attrib_is_ ## rule (const char *value)
|
extern int iks_attrib_is_bool(const char *value);
|
||||||
|
extern int iks_attrib_is_not_negative(const char *value);
|
||||||
/**
|
extern int iks_attrib_is_positive(const char *value);
|
||||||
* Validate boolean
|
extern int iks_attrib_is_positive_or_neg_one(const char *value);
|
||||||
* @param value
|
extern int iks_attrib_is_any(const char *value);
|
||||||
* @return SWTICH_TRUE if boolean
|
extern int iks_attrib_is_decimal_between_zero_and_one(const char *value);
|
||||||
*/
|
|
||||||
ATTRIB_RULE(bool)
|
|
||||||
{
|
|
||||||
if (value && *value && (!strcasecmp("true", value) || !strcasecmp("false", value))) {
|
|
||||||
return SWITCH_TRUE;
|
|
||||||
}
|
|
||||||
return SWITCH_FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Validate integer
|
|
||||||
* @param value
|
|
||||||
* @return SWTICH_TRUE if not negative
|
|
||||||
*/
|
|
||||||
ATTRIB_RULE(not_negative)
|
|
||||||
{
|
|
||||||
if (value && *value && switch_is_number(value)) {
|
|
||||||
int value_i = atoi(value);
|
|
||||||
if (value_i >= 0) {
|
|
||||||
return SWITCH_TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return SWITCH_FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Validate integer
|
|
||||||
* @param value
|
|
||||||
* @return SWTICH_TRUE if positive
|
|
||||||
*/
|
|
||||||
ATTRIB_RULE(positive)
|
|
||||||
{
|
|
||||||
if (value && *value && switch_is_number(value)) {
|
|
||||||
int value_i = atoi(value);
|
|
||||||
if (value_i > 0) {
|
|
||||||
return SWITCH_TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return SWITCH_FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Validate integer
|
|
||||||
* @param value
|
|
||||||
* @return SWTICH_TRUE if positive or -1
|
|
||||||
*/
|
|
||||||
ATTRIB_RULE(positive_or_neg_one)
|
|
||||||
{
|
|
||||||
if (value && *value && switch_is_number(value)) {
|
|
||||||
int value_i = atoi(value);
|
|
||||||
if (value_i == -1 || value_i > 0) {
|
|
||||||
return SWITCH_TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return SWITCH_FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Validate string
|
|
||||||
* @param value
|
|
||||||
* @return SWTICH_TRUE
|
|
||||||
*/
|
|
||||||
ATTRIB_RULE(any)
|
|
||||||
{
|
|
||||||
return SWITCH_TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Validate decimal
|
|
||||||
* @param value
|
|
||||||
* @return SWTICH_TRUE if 0.0 <= x <= 1.0
|
|
||||||
*/
|
|
||||||
ATTRIB_RULE(decimal_between_zero_and_one)
|
|
||||||
{
|
|
||||||
if (value && *value && switch_is_number(value)) {
|
|
||||||
double value_d = atof(value);
|
|
||||||
if (value_d >= 0.0 || value_d <= 1.0) {
|
|
||||||
return SWITCH_TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return SWITCH_FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
117
src/mod/event_handlers/mod_rayo/rayo_elements.c
Normal file
117
src/mod/event_handlers/mod_rayo/rayo_elements.c
Normal file
@ -0,0 +1,117 @@
|
|||||||
|
/*
|
||||||
|
* mod_rayo for FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
|
||||||
|
* Copyright (C) 2013, Grasshopper
|
||||||
|
*
|
||||||
|
* Version: MPL 1.1
|
||||||
|
*
|
||||||
|
* The contents of this file are subject to the Mozilla Public License Version
|
||||||
|
* 1.1 (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.mozilla.org/MPL/
|
||||||
|
*
|
||||||
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
||||||
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
||||||
|
* for the specific language governing rights and limitations under the
|
||||||
|
* License.
|
||||||
|
*
|
||||||
|
* The Original Code is mod_rayo for FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
|
||||||
|
*
|
||||||
|
* The Initial Developer of the Original Code is Grasshopper
|
||||||
|
* Portions created by the Initial Developer are Copyright (C)
|
||||||
|
* the Initial Developer. All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Contributor(s):
|
||||||
|
* Chris Rienzo <chris.rienzo@grasshopper.com>
|
||||||
|
*
|
||||||
|
* rayo_elements.c -- Rayo XML element definition
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#include "rayo_elements.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <input> component validation
|
||||||
|
*/
|
||||||
|
ELEMENT(RAYO_INPUT)
|
||||||
|
STRING_ATTRIB(mode, any, "any,dtmf,voice")
|
||||||
|
ATTRIB(terminator,, any)
|
||||||
|
ATTRIB(recognizer,, any)
|
||||||
|
ATTRIB(language, en-US, any)
|
||||||
|
ATTRIB(initial-timeout, -1, positive_or_neg_one)
|
||||||
|
ATTRIB(inter-digit-timeout, -1, positive_or_neg_one)
|
||||||
|
ATTRIB(sensitivity, 0.5, decimal_between_zero_and_one)
|
||||||
|
ATTRIB(min-confidence, 0, decimal_between_zero_and_one)
|
||||||
|
ATTRIB(max-silence, -1, positive_or_neg_one)
|
||||||
|
/* for now, only NLSML */
|
||||||
|
STRING_ATTRIB(match-content-type, application/nlsml+xml, "application/nlsml+xml")
|
||||||
|
/* internal attribs for prompt support */
|
||||||
|
ATTRIB(barge-event, false, bool)
|
||||||
|
ATTRIB(start-timers, true, bool)
|
||||||
|
ELEMENT_END
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <output> component validation
|
||||||
|
*/
|
||||||
|
ELEMENT(RAYO_OUTPUT)
|
||||||
|
ATTRIB(start-offset, 0, not_negative)
|
||||||
|
ATTRIB(start-paused, false, bool)
|
||||||
|
ATTRIB(repeat-interval, 0, not_negative)
|
||||||
|
ATTRIB(repeat-times, 1, not_negative)
|
||||||
|
ATTRIB(max-time, -1, positive_or_neg_one)
|
||||||
|
ATTRIB(renderer,, any)
|
||||||
|
ATTRIB(voice,, any)
|
||||||
|
ELEMENT_END
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <output><seek> validation
|
||||||
|
*/
|
||||||
|
ELEMENT(RAYO_OUTPUT_SEEK)
|
||||||
|
STRING_ATTRIB(direction,, "forward,back")
|
||||||
|
ATTRIB(amount,-1, positive)
|
||||||
|
ELEMENT_END
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <prompt> component validation
|
||||||
|
*/
|
||||||
|
ELEMENT(RAYO_PROMPT)
|
||||||
|
ATTRIB(barge-in, true, bool)
|
||||||
|
ELEMENT_END
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <record> component validation
|
||||||
|
*/
|
||||||
|
ELEMENT(RAYO_RECORD)
|
||||||
|
ATTRIB(format, mp3, any)
|
||||||
|
ATTRIB(start-beep, false, bool)
|
||||||
|
ATTRIB(stop-beep, false, bool)
|
||||||
|
ATTRIB(start-paused, false, bool)
|
||||||
|
ATTRIB(max-duration, -1, positive_or_neg_one)
|
||||||
|
ATTRIB(initial-timeout, -1, positive_or_neg_one)
|
||||||
|
ATTRIB(final-timeout, -1, positive_or_neg_one)
|
||||||
|
STRING_ATTRIB(direction, duplex, "duplex,send,recv")
|
||||||
|
ATTRIB(mix, false, bool)
|
||||||
|
ELEMENT_END
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <join> command validation
|
||||||
|
*/
|
||||||
|
ELEMENT(RAYO_JOIN)
|
||||||
|
/* for now, only allow duplex
|
||||||
|
STRING_ATTRIB(direction, duplex, "send,recv,duplex"); */
|
||||||
|
STRING_ATTRIB(direction, duplex, "duplex")
|
||||||
|
STRING_ATTRIB(media, bridge, "bridge,direct")
|
||||||
|
ATTRIB(call-uri,, any)
|
||||||
|
ATTRIB(mixer-name,, any)
|
||||||
|
ELEMENT_END
|
||||||
|
|
||||||
|
|
||||||
|
/* For Emacs:
|
||||||
|
* Local Variables:
|
||||||
|
* mode:c
|
||||||
|
* indent-tabs-mode:t
|
||||||
|
* tab-width:4
|
||||||
|
* c-basic-offset:4
|
||||||
|
* End:
|
||||||
|
* For VIM:
|
||||||
|
* vim:set softtabstop=4 shiftwidth=4 tabstop=4 noet
|
||||||
|
*/
|
||||||
|
|
@ -23,7 +23,7 @@
|
|||||||
* Contributor(s):
|
* Contributor(s):
|
||||||
* Chris Rienzo <chris.rienzo@grasshopper.com>
|
* Chris Rienzo <chris.rienzo@grasshopper.com>
|
||||||
*
|
*
|
||||||
* rayo_elements.h -- Rayo XML element definition
|
* rayo_elements.h -- Rayo XML elements
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
#ifndef RAYO_ELEMENTS_H
|
#ifndef RAYO_ELEMENTS_H
|
||||||
@ -31,80 +31,12 @@
|
|||||||
|
|
||||||
#include "iks_helpers.h"
|
#include "iks_helpers.h"
|
||||||
|
|
||||||
/**
|
ELEMENT_DECL(RAYO_INPUT)
|
||||||
* <input> component validation
|
ELEMENT_DECL(RAYO_OUTPUT)
|
||||||
*/
|
ELEMENT_DECL(RAYO_OUTPUT_SEEK)
|
||||||
ELEMENT(RAYO_INPUT)
|
ELEMENT_DECL(RAYO_PROMPT)
|
||||||
STRING_ATTRIB(mode, any, "any,dtmf,voice")
|
ELEMENT_DECL(RAYO_RECORD)
|
||||||
ATTRIB(terminator,, any)
|
ELEMENT_DECL(RAYO_JOIN)
|
||||||
ATTRIB(recognizer,, any)
|
|
||||||
ATTRIB(language, en-US, any)
|
|
||||||
ATTRIB(initial-timeout, -1, positive_or_neg_one)
|
|
||||||
ATTRIB(inter-digit-timeout, -1, positive_or_neg_one)
|
|
||||||
ATTRIB(sensitivity, 0.5, decimal_between_zero_and_one)
|
|
||||||
ATTRIB(min-confidence, 0, decimal_between_zero_and_one)
|
|
||||||
ATTRIB(max-silence, -1, positive_or_neg_one)
|
|
||||||
/* for now, only NLSML */
|
|
||||||
STRING_ATTRIB(match-content-type, application/nlsml+xml, "application/nlsml+xml")
|
|
||||||
/* internal attribs for prompt support */
|
|
||||||
ATTRIB(barge-event, false, bool)
|
|
||||||
ATTRIB(start-timers, true, bool)
|
|
||||||
ELEMENT_END
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <output> component validation
|
|
||||||
*/
|
|
||||||
ELEMENT(RAYO_OUTPUT)
|
|
||||||
ATTRIB(start-offset, 0, not_negative)
|
|
||||||
ATTRIB(start-paused, false, bool)
|
|
||||||
ATTRIB(repeat-interval, 0, not_negative)
|
|
||||||
ATTRIB(repeat-times, 1, not_negative)
|
|
||||||
ATTRIB(max-time, -1, positive_or_neg_one)
|
|
||||||
ATTRIB(renderer,, any)
|
|
||||||
ATTRIB(voice,, any)
|
|
||||||
ELEMENT_END
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <output><seek> validation
|
|
||||||
*/
|
|
||||||
ELEMENT(RAYO_OUTPUT_SEEK)
|
|
||||||
STRING_ATTRIB(direction,, "forward,back")
|
|
||||||
ATTRIB(amount,-1, positive)
|
|
||||||
ELEMENT_END
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <prompt> component validation
|
|
||||||
*/
|
|
||||||
ELEMENT(RAYO_PROMPT)
|
|
||||||
ATTRIB(barge-in, true, bool)
|
|
||||||
ELEMENT_END
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <record> component validation
|
|
||||||
*/
|
|
||||||
ELEMENT(RAYO_RECORD)
|
|
||||||
ATTRIB(format, mp3, any)
|
|
||||||
ATTRIB(start-beep, false, bool)
|
|
||||||
ATTRIB(stop-beep, false, bool)
|
|
||||||
ATTRIB(start-paused, false, bool)
|
|
||||||
ATTRIB(max-duration, -1, positive_or_neg_one)
|
|
||||||
ATTRIB(initial-timeout, -1, positive_or_neg_one)
|
|
||||||
ATTRIB(final-timeout, -1, positive_or_neg_one)
|
|
||||||
STRING_ATTRIB(direction, duplex, "duplex,send,recv")
|
|
||||||
ATTRIB(mix, false, bool)
|
|
||||||
ELEMENT_END
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <join> command validation
|
|
||||||
*/
|
|
||||||
ELEMENT(RAYO_JOIN)
|
|
||||||
/* for now, only allow duplex
|
|
||||||
STRING_ATTRIB(direction, duplex, "send,recv,duplex"); */
|
|
||||||
STRING_ATTRIB(direction, duplex, "duplex")
|
|
||||||
STRING_ATTRIB(media, bridge, "bridge,direct")
|
|
||||||
ATTRIB(call-uri,, any)
|
|
||||||
ATTRIB(mixer-name,, any)
|
|
||||||
ELEMENT_END
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user