message = message_create(p_serial, ACTIVE_EPOINT(p_epointlist), PORT_TO_EPOINT, MESSAGE_FACILITY);
message->param.facilityinfo.len = fac_len;
- memcpy(message->param.facilityinfo.data, fac_ie, fac_len);
+ memcpy(message->param.facilityinfo.data, fac_ie + 1, fac_len);
message_put(message);
}
if (param->threepty.result) {
fac.comp = CompReturnResult;
fac.u.retResult.invokeId = param->threepty.invoke_id;
+ fac.u.retResult.operationValuePresent = 1;
+ if (param->threepty.begin)
+ fac.u.retResult.operationValue = Fac_Begin3PTY;
+ if (param->threepty.end)
+ fac.u.retResult.operationValue = Fac_End3PTY;
}
if (param->threepty.error) {
fac.comp = CompReturnError;
fac.u.retError.invokeId = param->threepty.invoke_id;
fac.u.retError.errorValue = FacError_Gen_InvalidCallState;
}
- fac.u.retResult.operationValuePresent = 1;
- if (param->threepty.begin)
- fac.u.retResult.operationValue = Fac_Begin3PTY;
- if (param->threepty.end)
- fac.u.retResult.operationValue = Fac_End3PTY;
encodeFac(fac_ie, &fac);
/* sending facility */
{
l3_msg *l3m;
int type, plan, present, screen;
- class Endpoint *epoint;
time_t current_time;
/* NT-MODE in setup state we must send PROCEEDING first */
// enc_facility_centrex(&connect->FACILITY, dmsg, (unsigned char *)p_connectinfo.name, 0);
/* date & time */
if (p_m_d_ntmode || p_m_d_tespecial) {
- epoint = find_epoint_id(epoint_id);
time(¤t_time);
enc_ie_date(l3m, current_time, p_settings.no_seconds);
}
void Pdss1::message_release(unsigned int epoint_id, int message_id, union parameter *param)
{
l3_msg *l3m;
- class Endpoint *epoint;
char *p = NULL;
/*
/* send cause */
enc_ie_cause(l3m, (p_m_mISDNport->locally && param->disconnectinfo.location==LOCATION_PRIVATE_LOCAL)?LOCATION_PRIVATE_LOCAL:param->disconnectinfo.location, param->disconnectinfo.cause);
/* send display */
- epoint = find_epoint_id(epoint_id);
if (param->disconnectinfo.display[0])
p = param->disconnectinfo.display;
if (p) if (*p && (p_m_d_ntmode || p_m_d_tespecial))