⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 iax2-parser.c

📁 IAX协议客户端源码
💻 C
📖 第 1 页 / 共 2 页
字号:
	outputf(tmp);	if (fh->type == AST_FRAME_IAX)		dump_ies(fh->iedata, datalen);}int iax_ie_append_raw(struct iax_ie_data *ied, unsigned char ie, const void *data, int datalen){	char tmp[256];	if (datalen > ((int)sizeof(ied->buf) - ied->pos)) {		snprintf(tmp, (int)sizeof(tmp), "Out of space for ie '%s' (%d), need %d have %d\n", iax_ie2str(ie), ie, datalen, (int)sizeof(ied->buf) - ied->pos);		errorf(tmp);		return -1;	}	ied->buf[ied->pos++] = ie;	ied->buf[ied->pos++] = datalen;	memcpy(ied->buf + ied->pos, data, datalen);	ied->pos += datalen;	return 0;}int iax_ie_append_addr(struct iax_ie_data *ied, unsigned char ie, struct sockaddr_in *sin){	return iax_ie_append_raw(ied, ie, sin, (int)sizeof(struct sockaddr_in));}int iax_ie_append_int(struct iax_ie_data *ied, unsigned char ie, unsigned int value) {	unsigned int newval;	newval = htonl(value);	return iax_ie_append_raw(ied, ie, &newval, (int)sizeof(newval));}int iax_ie_append_short(struct iax_ie_data *ied, unsigned char ie, unsigned short value) {	unsigned short newval;	newval = htons(value);	return iax_ie_append_raw(ied, ie, &newval, (int)sizeof(newval));}int iax_ie_append_str(struct iax_ie_data *ied, unsigned char ie, const char *str){	return iax_ie_append_raw(ied, ie, str, (int)strlen(str));}int iax_ie_append_byte(struct iax_ie_data *ied, unsigned char ie, unsigned char dat){	return iax_ie_append_raw(ied, ie, &dat, 1);}int iax_ie_append(struct iax_ie_data *ied, unsigned char ie) {	return iax_ie_append_raw(ied, ie, NULL, 0);}void iax_set_output(void (*func)(const char *)){	outputf = func;}void iax_set_error(void (*func)(const char *)){	errorf = func;}int iax_parse_ies(struct iax_ies *ies, unsigned char *data, int datalen){	/* Parse data into information elements */	int len;	int ie;	char tmp[256];	memset(ies, 0, (int)sizeof(struct iax_ies));	ies->msgcount = -1;	ies->firmwarever = -1;	ies->calling_ton = -1;	ies->calling_tns = -1;	ies->calling_pres = -1;	ies->samprate = IAX_RATE_8KHZ;	while(datalen >= 2) {		ie = data[0];		len = data[1];		if (len > datalen - 2) {			errorf("Information element length exceeds message size\n");			return -1;		}		switch(ie) {		case IAX_IE_CALLED_NUMBER:			ies->called_number = (char *) data + 2;			break;		case IAX_IE_CALLING_NUMBER:			ies->calling_number = (char *) data + 2;			break;		case IAX_IE_CALLING_ANI:			ies->calling_ani = (char *) data + 2;			break;		case IAX_IE_CALLING_NAME:			ies->calling_name = (char *) data + 2;			break;		case IAX_IE_CALLED_CONTEXT:			ies->called_context = (char *) data + 2;			break;		case IAX_IE_USERNAME:			ies->username = (char *) data + 2;			break;		case IAX_IE_PASSWORD:			ies->password = (char *) data + 2;			break;		case IAX_IE_CAPABILITY:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expecting capability to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else				ies->capability = ntohl(get_uint32(data + 2));			break;		case IAX_IE_FORMAT:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expecting format to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else				ies->format = ntohl(get_uint32(data + 2));			break;		case IAX_IE_LANGUAGE:			ies->language = (char *) data + 2;			break;		case IAX_IE_CODEC_PREFS:			ies->codec_prefs = (char *) data + 2;			break;		case IAX_IE_VERSION:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp),  "Expecting version to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->version = ntohs(get_uint16(data + 2));			break;		case IAX_IE_ADSICPE:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp), "Expecting adsicpe to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->adsicpe = ntohs(get_uint16(data + 2));			break;		case IAX_IE_SAMPLINGRATE:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp), "Expecting samplingrate to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->samprate = ntohs(get_uint16(data + 2));			break;		case IAX_IE_DNID:			ies->dnid = (char *) data + 2;			break;		case IAX_IE_RDNIS:			ies->rdnis = (char *) data + 2;			break;		case IAX_IE_AUTHMETHODS:			if (len != (int)sizeof(unsigned short))  {				snprintf(tmp, (int)sizeof(tmp), "Expecting authmethods to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->authmethods = ntohs(get_uint16(data + 2));			break;		case IAX_IE_CHALLENGE:			ies->challenge = (char *) data + 2;			break;		case IAX_IE_MD5_RESULT:			ies->md5_result = (char *) data + 2;			break;		case IAX_IE_RSA_RESULT:			ies->rsa_result = (char *) data + 2;			break;		case IAX_IE_APPARENT_ADDR:			ies->apparent_addr = ((struct sockaddr_in *)(data + 2));			break;		case IAX_IE_REFRESH:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp),  "Expecting refresh to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->refresh = ntohs(get_uint16(data + 2));			break;		case IAX_IE_DPSTATUS:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp),  "Expecting dpstatus to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->dpstatus = ntohs(get_uint16(data + 2));			break;		case IAX_IE_CALLNO:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp),  "Expecting callno to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->callno = ntohs(get_uint16(data + 2));			break;		case IAX_IE_CAUSE:			ies->cause = (char *) data + 2;			break;		case IAX_IE_CAUSECODE:			if (len != 1) {				snprintf(tmp, (int)sizeof(tmp), "Expecting causecode to be single byte but was %d\n", len);				errorf(tmp);			} else {				ies->causecode = data[2];			}			break;		case IAX_IE_IAX_UNKNOWN:			if (len == 1)				ies->iax_unknown = data[2];			else {				snprintf(tmp, (int)sizeof(tmp), "Expected single byte Unknown command, but was %d long\n", len);				errorf(tmp);			}			break;		case IAX_IE_MSGCOUNT:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp), "Expecting msgcount to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->msgcount = ntohs(get_uint16(data + 2));				break;		case IAX_IE_AUTOANSWER:			ies->autoanswer = 1;			break;		case IAX_IE_MUSICONHOLD:			ies->musiconhold = 1;			break;		case IAX_IE_TRANSFERID:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expecting transferid to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else				ies->transferid = ntohl(get_uint32(data + 2));			break;		case IAX_IE_DATETIME:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expecting date/time to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else				ies->datetime = ntohl(get_uint32(data + 2));			break;		case IAX_IE_FIRMWAREVER:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp), "Expecting firmwarever to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->firmwarever = ntohs(get_uint16(data + 2));				break;		case IAX_IE_DEVICETYPE:			ies->devicetype = (char *) data + 2;			break;		case IAX_IE_SERVICEIDENT:			ies->serviceident = (char *) data + 2;			break;		case IAX_IE_FWBLOCKDESC:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expected block desc to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else				ies->fwdesc = ntohl(get_uint32(data + 2));			break;		case IAX_IE_FWBLOCKDATA:			ies->fwdata = data + 2;			ies->fwdatalen = len;			break;		case IAX_IE_PROVVER:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expected provisioning version to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else {				ies->provverpres = 1;				ies->provver = ntohl(get_uint32(data + 2));			}			break;		case IAX_IE_CALLINGPRES:			if (len == 1)				ies->calling_pres = data[2];			else {				snprintf(tmp, (int)sizeof(tmp), "Expected single byte callingpres, but was %d long\n", len);				errorf(tmp);			}			break;		case IAX_IE_CALLINGTON:			if (len == 1)				ies->calling_ton = data[2];			else {				snprintf(tmp, (int)sizeof(tmp), "Expected single byte callington, but was %d long\n", len);				errorf(tmp);			}			break;		case IAX_IE_CALLINGTNS:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp), "Expecting callingtns to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else				ies->calling_tns = ntohs(get_uint16(data + 2));				break;		case IAX_IE_RR_JITTER:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expected jitter rr to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else {				ies->rr_jitter = ntohl(get_uint32(data + 2));			}			break;		case IAX_IE_RR_LOSS:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expected loss rr to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else {				ies->rr_loss = ntohl(get_uint32(data + 2));			}			break;		case IAX_IE_RR_PKTS:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expected packets rr to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else {				ies->rr_pkts = ntohl(get_uint32(data + 2));			}			break;		case IAX_IE_RR_DELAY:			if (len != (int)sizeof(unsigned short)) {				snprintf(tmp, (int)sizeof(tmp), "Expected loss rr to be %d bytes long but was %d\n", (int)sizeof(unsigned short), len);				errorf(tmp);			} else {				ies->rr_delay = ntohs(get_uint16(data + 2));			}			break;		case IAX_IE_RR_DROPPED:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expected packets rr to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else {				ies->rr_dropped = ntohl(get_uint32(data + 2));			}			break;		case IAX_IE_RR_OOO:			if (len != (int)sizeof(unsigned int)) {				snprintf(tmp, (int)sizeof(tmp), "Expected packets rr to be %d bytes long but was %d\n", (int)sizeof(unsigned int), len);				errorf(tmp);			} else {				ies->rr_ooo = ntohl(get_uint32(data + 2));			}			break;		default:			snprintf(tmp, (int)sizeof(tmp), "Ignoring unknown information element '%s' (%d) of length %d\n", iax_ie2str(ie), ie, len);			outputf(tmp);		}		/* Overwrite information element with 0, to null terminate previous portion */		data[0] = 0;		datalen -= (len + 2);		data += (len + 2);	}	/* Null-terminate last field */	*data = '\0';	if (datalen) {		errorf("Invalid information element contents, strange boundary\n");		return -1;	}	return 0;}void iax_frame_wrap(struct iax_frame *fr, struct ast_frame *f){	fr->af.frametype = f->frametype;	fr->af.subclass = f->subclass;	fr->af.mallocd = 0;				/* Our frame is static relative to the container */	fr->af.datalen = f->datalen;	fr->af.samples = f->samples;	fr->af.offset = AST_FRIENDLY_OFFSET;	fr->af.src = f->src;	fr->af.data = fr->afdata;	if (fr->af.datalen) 		memcpy(fr->af.data, f->data, fr->af.datalen);}struct iax_frame *iax_frame_new(int direction, int datalen){	struct iax_frame *fr;	fr = (struct iax_frame *)malloc((int)sizeof(struct iax_frame) + datalen);	if (fr) {		fr->direction = direction;		fr->retrans = -1;		frames++;		if (fr->direction == DIRECTION_INGRESS)			iframes++;		else			oframes++;	}	return fr;}void iax_frame_free(struct iax_frame *fr){	/* Note: does not remove from scheduler! */	if (fr->direction == DIRECTION_INGRESS)		iframes--;	else if (fr->direction == DIRECTION_OUTGRESS)		oframes--;	else {		errorf("Attempt to double free frame detected\n");		return;	}	fr->direction = 0;	free(fr);	frames--;}int iax_get_frames(void) { return frames; }int iax_get_iframes(void) { return iframes; }int iax_get_oframes(void) { return oframes; }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -