683 lines
25 KiB
C
683 lines
25 KiB
C
/************************************************************************/
|
|
/* SISCO SOFTWARE MODULE HEADER *****************************************/
|
|
/************************************************************************/
|
|
/* (c) Copyright Systems Integration Specialists Company, Inc., */
|
|
/* 1986 - 2001, All Rights Reserved. */
|
|
/* */
|
|
/* PROPRIETARY AND CONFIDENTIAL */
|
|
/* */
|
|
/* MODULE NAME : rq_getaes.c */
|
|
/* PRODUCT(S) : MMSEASE, MMSEASE-LITE */
|
|
/* */
|
|
/* MODULE DESCRIPTION : */
|
|
/* This module contains the requester portion of get alarm */
|
|
/* enrollment summary. It decodes the get alarm enrollment */
|
|
/* summary response (confirm) & encodes the get alarm enrollment */
|
|
/* summary request. */
|
|
/* */
|
|
/* GLOBAL FUNCTIONS DEFINED IN THIS MODULE : */
|
|
/* */
|
|
/* MODIFICATION LOG : */
|
|
/* Date Who Rev Comments */
|
|
/* -------- --- ------ ------------------------------------------- */
|
|
/* 03/11/04 GLB 06 Remove "thisFileName" */
|
|
/* 12/20/01 JRB 05 Converted to use ASN1R (re-entrant ASN1) */
|
|
/* 04/28/00 JRB 04 Lint cleanup */
|
|
/* 09/13/99 MDE 03 Added SD_CONST modifiers */
|
|
/* 03/23/99 MDE 02 Changes to decode buffer allocation scheme */
|
|
/* 06/15/98 MDE 01 Changes to allow compile under C++ */
|
|
/* 04/02/97 DTL 7.00 MMSEASE 7.0 release. See MODL70.DOC for */
|
|
/* history. */
|
|
/************************************************************************/
|
|
|
|
#include "glbtypes.h"
|
|
#include "sysincs.h"
|
|
|
|
#include "mmsdefs.h"
|
|
#include "mms_pevn.h"
|
|
#include "asn1defs.h"
|
|
|
|
/************************************************************************/
|
|
/* variables global to the DECODE portion : NONE */
|
|
|
|
static GETAES_RESP_INFO *rsp_info;
|
|
|
|
static ALARM_ENROLL_SUMMARY *aes_ptr;
|
|
static ST_INT max_enroll_sums;
|
|
|
|
/************************************************************************/
|
|
/* variables global to the ENCODE portion : NONE */
|
|
|
|
static ST_VOID getaes_aes_list_cstr (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_eename_cstr (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_eename_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_eename_cstr_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_client_app_cstr (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_client_app_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_client_app_cstr_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_get_severity (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_get_cur_state (ASN1_DEC_CTXT *aCtx);
|
|
#ifdef CS_SUPPORT
|
|
static ST_VOID getaes_addl_detail_cstr (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_addl_detail_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_addl_detail_cstr_done (ASN1_DEC_CTXT *aCtx);
|
|
#endif
|
|
static ST_VOID getaes_get_not_lost (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_get_alarm_ack_rule (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_get_ee_state (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_tta_time_cstr (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_tta_time_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_tta_time_cstr_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_aack_time_cstr (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_aack_time_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_aack_time_cstr_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_tti_time_cstr (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_tti_time_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_tti_time_cstr_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_iack_time_cstr (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_iack_time_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_alarm_esum_cstr (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_alarm_esum_cstr_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_aes_list_cstr_done (ASN1_DEC_CTXT *aCtx);
|
|
static ST_VOID getaes_get_more_follows (ASN1_DEC_CTXT *aCtx);
|
|
|
|
|
|
/************************************************************************/
|
|
/************************************************************************/
|
|
/* mms_getaes_rsp */
|
|
/* This function is called from MMSDEC when the opcode for this */
|
|
/* operation is decoded. Setup state machine function pointers, etc. */
|
|
/************************************************************************/
|
|
|
|
ST_VOID mms_getaes_rsp (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
ST_INT rsp_size;
|
|
|
|
MLOG_CDEC0 ("Get Alarm Enrollment Summary Response");
|
|
|
|
#if defined(FIXED_DECBUF)
|
|
max_enroll_sums = m_cl_max_enrollment_summary;
|
|
rsp_size = mmsl_dec_info_size;
|
|
#else
|
|
max_enroll_sums = _mmsdec_msglen/8; /* determine maximum size */
|
|
if (m_cl_max_enrollment_summary && (max_enroll_sums > m_cl_max_enrollment_summary))
|
|
max_enroll_sums = m_cl_max_enrollment_summary;
|
|
rsp_size = sizeof (GETAES_RESP_INFO)
|
|
+ (max_enroll_sums * (sizeof (ALARM_ENROLL_SUMMARY)));
|
|
/* get storage for resp info */
|
|
#endif
|
|
|
|
/* get storage for request information */
|
|
rsp_info = (GETAES_RESP_INFO *) _m_get_dec_buf (aCtx, rsp_size);
|
|
aes_ptr = (ALARM_ENROLL_SUMMARY *) (rsp_info + 1);
|
|
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 0, getaes_aes_list_cstr);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_aes_list_cstr */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* alarm enrollment summary list constructor was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_aes_list_cstr (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_aes_list_cstr");
|
|
|
|
ASN1R_TAG_ADD (aCtx, UNI | CONSTR, SEQ_CODE, getaes_alarm_esum_cstr);
|
|
|
|
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = getaes_aes_list_cstr_done;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_alarm_esum_cstr */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* alarm enrollment summary was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_alarm_esum_cstr (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_alarm_esum_cstr");
|
|
|
|
rsp_info->num_of_alarm_esum++; /* inc alarm enrollment sum cnt */
|
|
|
|
if (rsp_info->num_of_alarm_esum > max_enroll_sums)
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 0, getaes_eename_cstr);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_eename_cstr */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* event enrollment name cstr was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_eename_cstr (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_eename_cstr");
|
|
|
|
_ms_get_mms_objname (aCtx, &aes_ptr->evenroll_name, getaes_eename_done);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_eename_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* event enrollment name has been obtained. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_eename_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_eename_done");
|
|
|
|
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = getaes_eename_cstr_done;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_eename_cstr_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* event enrollment name cstr done has been encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_eename_cstr_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 2, getaes_client_app_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX, 3, getaes_get_severity);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_client_app_cstr */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* client application constructor was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_client_app_cstr (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_client_app_cstr");
|
|
|
|
aes_ptr->client_app_pres = SD_TRUE; /* set client app present */
|
|
|
|
_ms_get_mms_app_ref (aCtx, &aes_ptr->client_app,&aes_ptr->client_app_len,
|
|
getaes_client_app_done);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_client_app_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* client application has been obtained. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_client_app_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
|
|
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = getaes_client_app_cstr_done;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_client_app_cstr_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* client application constructor done was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_client_app_cstr_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
ASN1R_TAG_ADD (aCtx, CTX, 3, getaes_get_severity);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_get_severity */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* severity was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_get_severity (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_get_severity");
|
|
|
|
if (asn1r_get_u8 (aCtx, &aes_ptr->severity)) /* get the severity */
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
|
|
ASN1R_TAG_ADD (aCtx, CTX, 4, getaes_get_cur_state);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_get_cur_state */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* current state was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_get_cur_state (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_get_cur_state");
|
|
|
|
if (asn1r_get_i16 (aCtx, &aes_ptr->cur_state)) /* get current state */
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
else if ((aes_ptr->cur_state < 0) || (aes_ptr->cur_state > 2))
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
|
|
#ifdef CS_SUPPORT
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 5, getaes_addl_detail_cstr);
|
|
#endif
|
|
ASN1R_TAG_ADD (aCtx, CTX, 6, getaes_get_not_lost);
|
|
ASN1R_TAG_ADD (aCtx, CTX, 7, getaes_get_alarm_ack_rule);
|
|
}
|
|
|
|
#ifdef CS_SUPPORT
|
|
/************************************************************************/
|
|
/* getaes_addl_detail_cstr */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* additional detail constructor was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_addl_detail_cstr (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_addl_detail_cstr");
|
|
|
|
aes_ptr->addl_detail_pres = SD_TRUE; /* set flag */
|
|
aes_ptr->addl_detail = aCtx->asn1r_field_ptr;
|
|
aes_ptr->addl_detail_len = aCtx->asn1r_elmnt_len;
|
|
|
|
asn1r_parse_next (aCtx, getaes_addl_detail_done); /* parse the contents */
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_addl_detail_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* additional detail has been obtained. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_addl_detail_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_addl_detail_done");
|
|
|
|
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = getaes_addl_detail_cstr_done;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_addl_detail_cstr_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* additional detail constructor done was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_addl_detail_cstr_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
ASN1R_TAG_ADD (aCtx, CTX, 6, getaes_get_not_lost);
|
|
ASN1R_TAG_ADD (aCtx, CTX, 7, getaes_get_alarm_ack_rule);
|
|
}
|
|
#endif
|
|
|
|
/************************************************************************/
|
|
/* getaes_get_not_lost */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* notification lost was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_get_not_lost (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_get_not_lost");
|
|
|
|
if (asn1r_get_bool (aCtx, &(aes_ptr->not_lost))) /* get notification lost*/
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
|
|
ASN1R_TAG_ADD (aCtx, CTX, 7, getaes_get_alarm_ack_rule);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_get_alarm_ack_rule */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* alarm acknowledgment rule was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_get_alarm_ack_rule (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_get_alarm_ack_rule");
|
|
/* read alarm ack rule */
|
|
if (asn1r_get_i16 (aCtx, &(aes_ptr->alarm_ack_rule)))
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
else if ((aes_ptr->alarm_ack_rule < 0) || (aes_ptr->alarm_ack_rule > 3))
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
|
|
ASN1R_TAG_ADD (aCtx, CTX, 8, getaes_get_ee_state);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 9, getaes_tta_time_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,10, getaes_aack_time_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,11, getaes_tti_time_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,12, getaes_iack_time_cstr);
|
|
|
|
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = getaes_alarm_esum_cstr_done;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_get_ee_state */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* event enrollment state was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_get_ee_state (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_get_ee_state");
|
|
|
|
aes_ptr->ee_state_pres = SD_TRUE; /* set event cond state pres */
|
|
|
|
if (asn1r_get_i16 (aCtx, &aes_ptr->ee_state)) /* get event cond state */
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
else if ((aes_ptr->ee_state < 0) || (aes_ptr->ee_state > 7))
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 9, getaes_tta_time_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,10, getaes_aack_time_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,11, getaes_tti_time_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,12, getaes_iack_time_cstr);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_tta_time_cstr */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* transition to active time cstr was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_tta_time_cstr (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_tta_time_cstr");
|
|
|
|
aes_ptr->tta_time_pres = SD_TRUE; /* set tran to active present */
|
|
|
|
_ms_get_mms_evtime (aCtx, &aes_ptr->tta_time, getaes_tta_time_done);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_tta_time_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* transition to active time has been obtained. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_tta_time_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_tta_time_done");
|
|
|
|
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = getaes_tta_time_cstr_done;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_tta_time_cstr_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* transition to active time cstr done has been encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_tta_time_cstr_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,10, getaes_aack_time_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,11, getaes_tti_time_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,12, getaes_iack_time_cstr);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_aack_time_cstr */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* active acknowledgment time cstr was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_aack_time_cstr (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_aack_time_cstr");
|
|
|
|
aes_ptr->aack_time_pres = SD_TRUE; /* active acknowledgment pres */
|
|
|
|
_ms_get_mms_evtime (aCtx, &aes_ptr->aack_time, getaes_aack_time_done);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_aack_time_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* active acknowledgment time has been obtained. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_aack_time_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_aack_time_done");
|
|
|
|
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = getaes_aack_time_cstr_done;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_aack_time_cstr_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* active acknowledgment time cstr done was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_aack_time_cstr_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,11, getaes_tti_time_cstr);
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,12, getaes_iack_time_cstr);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_tti_time_cstr */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* transition to idle time cstr was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_tti_time_cstr (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_tti_time_cstr");
|
|
|
|
aes_ptr->tti_time_pres = SD_TRUE; /* set tran to idle present */
|
|
|
|
_ms_get_mms_evtime (aCtx, &aes_ptr->tti_time, getaes_tti_time_done);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_tti_time_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* transition to idle time has been obtained. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_tti_time_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_tti_time_done");
|
|
|
|
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = getaes_tti_time_cstr_done;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_tti_time_cstr_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* transition to idle time cstr done was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_tti_time_cstr_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
ASN1R_TAG_ADD (aCtx, CTX | CONSTR,12, getaes_iack_time_cstr);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_iack_time_cstr */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* idle acknowledgment time cstr was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_iack_time_cstr (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_iack_time_cstr");
|
|
|
|
aes_ptr->iack_time_pres = SD_TRUE; /* idle acknowledgment present */
|
|
|
|
_ms_get_mms_evtime (aCtx, &aes_ptr->iack_time, getaes_iack_time_done);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_iack_time_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): */
|
|
/* idle acknowledgment time has been obtained. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_iack_time_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_iack_time_done");
|
|
|
|
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = NULL;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_alarm_esum_cstr_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): alarm */
|
|
/* summary constructor done was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_alarm_esum_cstr_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
aes_ptr++; /* point to where next will go */
|
|
|
|
ASN1R_TAG_ADD (aCtx, UNI | CONSTR, SEQ_CODE, getaes_alarm_esum_cstr);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_aes_list_cstr_done */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): alarm */
|
|
/* summary list constructor done was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_aes_list_cstr_done (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
ST_INT rsp_size;
|
|
/* find actual size for response info */
|
|
rsp_size = sizeof (GETAES_RESP_INFO)
|
|
+ (sizeof (ALARM_ENROLL_SUMMARY) * rsp_info->num_of_alarm_esum);
|
|
|
|
/* give back unused storage */
|
|
_mms_dec_info = (*m_realloc_os_fun) (_mms_dec_info,rsp_size);
|
|
rsp_info = (GETAES_RESP_INFO *) _mms_dec_info;
|
|
|
|
ASN1R_TAG_ADD (aCtx, CTX, 1, getaes_get_more_follows);
|
|
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* getaes_get_more_follows */
|
|
/* decoding get alarm enrollment summary RESPONSE (confirm): more */
|
|
/* follows indicator was encountered. */
|
|
/************************************************************************/
|
|
|
|
static ST_VOID getaes_get_more_follows (ASN1_DEC_CTXT *aCtx)
|
|
{
|
|
MLOG_CDEC0 ("getaes_get_more_follows");
|
|
|
|
if (asn1r_get_bool (aCtx, &rsp_info->more_follows))
|
|
{
|
|
asn1r_set_dec_err (aCtx, RESP_BAD_VALUE);
|
|
return;
|
|
}
|
|
|
|
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
|
|
}
|
|
|
|
|
|
#ifndef MMS_LITE
|
|
/************************************************************************/
|
|
/************************************************************************/
|
|
/* mp_getaes */
|
|
/* This function is called from either the application or the virtual */
|
|
/* machine to ENCODE and send the decoding get alarm enrollment summary */
|
|
/* request. */
|
|
/************************************************************************/
|
|
|
|
MMSREQ_PEND *mp_getaes (ST_INT chan, GETAES_REQ_INFO *info_ptr)
|
|
{
|
|
return (_mms_req_send (MMSOP_GET_ALARM_ESUM,
|
|
M_CAST_MK_FUN (_ms_mk_getaes_req),
|
|
chan,(ST_CHAR *)info_ptr));
|
|
}
|
|
|
|
#else
|
|
/************************************************************************/
|
|
/************************************************************************/
|
|
/* mpl_getaes */
|
|
/* This function is called from either the application or the virtual */
|
|
/* machine to ENCODE the decoding get alarm enrollment summary request. */
|
|
/************************************************************************/
|
|
|
|
ST_RET mpl_getaes (GETAES_REQ_INFO *info_ptr)
|
|
{
|
|
return (_mms_req_fin (MMSOP_GET_ALARM_ESUM,
|
|
M_CAST_MK_FUN (_ms_mk_getaes_req),
|
|
(ST_CHAR *)info_ptr));
|
|
}
|
|
#endif
|
|
|
|
|
|
/************************************************************************/
|
|
/************************************************************************/
|
|
/* _ms_mk_getaes_req */
|
|
/* ENCODE a decoding get alarm enrollment summary REQUEST: */
|
|
/************************************************************************/
|
|
|
|
ST_VOID _ms_mk_getaes_req (ASN1_ENC_CTXT *aCtx, GETAES_REQ_INFO *info)
|
|
{
|
|
if (info->ca_name_pres)
|
|
{
|
|
asn1r_strt_constr (aCtx); /* start ctx tag 5 cstr */
|
|
_ms_wr_mms_objname (aCtx, &info->ca_name); /* write continue after name */
|
|
asn1r_fin_constr (aCtx, 5,CTX,DEF); /* finish ctx tag 5 cstr */
|
|
}
|
|
|
|
if (info->least_sev_filter != 127 || /* not the defaults */
|
|
info->most_sev_filter != 0)
|
|
{
|
|
asn1r_strt_constr (aCtx); /* start ctx tag 3 cstr */
|
|
asn1r_wr_u8 (aCtx, info->least_sev_filter); /* write least severe filter */
|
|
asn1r_fin_prim (aCtx, 1,CTX);
|
|
|
|
asn1r_wr_u8 (aCtx, info->most_sev_filter); /* write most severe filter */
|
|
asn1r_fin_prim (aCtx, 0,CTX);
|
|
asn1r_fin_constr (aCtx, 3,CTX,DEF); /* finish ctx tag 3 cstr */
|
|
}
|
|
|
|
if (info->ack_filter != SD_FALSE)
|
|
{
|
|
asn1r_wr_i16 (aCtx, info->ack_filter); /* write acknowledge filter */
|
|
asn1r_fin_prim (aCtx, 2,CTX);
|
|
}
|
|
|
|
if (!info->act_alarms_only)
|
|
{
|
|
asn1r_wr_bool (aCtx, info->act_alarms_only); /* write active alarms only */
|
|
asn1r_fin_prim (aCtx, 1,CTX);
|
|
}
|
|
|
|
if (!info->enroll_only)
|
|
{
|
|
asn1r_wr_bool (aCtx, info->enroll_only); /* write enrollments only */
|
|
asn1r_fin_prim (aCtx, 0,CTX);
|
|
}
|
|
|
|
/* write the context specific explicit tag for this opcode. */
|
|
asn1r_fin_constr (aCtx, MMSOP_GET_ALARM_ESUM,CTX,DEF); /* tag = opcode, context */
|
|
}
|