blob: 1c839a5ee39f6393bf0cd85c010c24770230e3e9 [file] [log] [blame]
b.liud440f9f2025-04-18 10:44:31 +08001#include "lynq_qser_sms.h"
2#include "mbtk_type.h"
3#include "mbtk_pdu_sms.h"
4#include "lynq_sms.h"
5#include "mbtk_log.h"
6#include "mbtk_ril_api.h"
7
8
9
10#include <stdio.h>
11#include <stdlib.h>
12
13
14#define TELEPHONE_NUM_MAX 16
15#define MSM_NUMBER_MAX 2048+1
16#define RES_NUM_MIN 128
17
18#define HAL_SMS_CONTENT_LEN 1024
19
20
21#define QSER_RESULT_SUCCESS 0
22#define QSER_RESULT_FAIL -1
23
24#define DSC_to_msg(DSC) (DSC == 0 ? "Bit7" : (DSC == 1 ? "Bit8" : "UCS2"))
25
26static mbtk_ril_handle* qser_info_handle;
27static const uint qser_h_sms = 0x5F6F7F8F;
28
29
30static char sms_center_address[128] = {0};
31
32typedef struct
33{
34 QSER_SMS_RxMsgHandlerFunc_t handlerPtr;
35 void* contextPtr;
36} lynq_sms_cb_func;
37
38static lynq_sms_cb_func lynq_sms_func_cb_handle;
39
40void lynq_sms_state_change_cb(const void* data, int data_len)
41{
42 LOGV("sms_state_change_cb()----------start\n");
43 mbtk_ril_sms_state_info_t *ptr = (mbtk_ril_sms_state_info_t *)data;
44 //LOGD("3sms_state_change_cb() : %s\n", ptr->pdu);
45
46 QSER_SMS_Msg_t tmp_data;
47
48 memset(&tmp_data,0x00, sizeof(QSER_SMS_Msg_t));
49
50 char smsc[MDAPI_MAX_PDU_SIZE] = {0};
51 char received_pdu[MDAPI_MAX_PDU_SIZE] = {0};
52 char msg[MDAPI_MAX_PDU_SIZE] = {0};
53 char num[MDAPI_MAX_PDU_SIZE] = {0};
54 char date[32] = {0};
55 int charset = 0;
56 int ret = -1;
57 int curr_pack = 1;
58 int total_pack = 1;
59 if(ptr == NULL)
60 {
61 LOGE("ptr is null");
62 }
63 LOGE("ptr: %s\n,data_len = %d\n", (char *)ptr->pdu, data_len);
64 if(data_len > MDAPI_MAX_PDU_SIZE)
65 {
66 strncpy(received_pdu, (const char *)ptr->pdu, MDAPI_MAX_PDU_SIZE-1);
67 }
68 else
69 {
70 strncpy(received_pdu, (const char *)ptr->pdu, data_len);
71 }
72 ret = smsPduDecode((const char *)received_pdu, data_len, num, smsc, msg, &charset, &curr_pack, &total_pack,date);
73 if(ret != 0)
74 {
75 LOGE("smsPduDecode fail ret: %d\n",ret);
76 return ;
77 }
78
79 LOGE("[EVENT][MT_SMS]PDU decode:smsc: %s\n, phone number: %s\ncharset: %d\n msg_len: %d\n message content: %s\n curr_pack: %d\n total_pack: %d\n date: %s", smsc, num, charset, strlen(msg), msg, curr_pack, total_pack, date);
80
81 tmp_data.format = charset;
82 memcpy(tmp_data.src_addr, num, strlen(num));
83 tmp_data.sms_data_len = strlen(msg);
84 memcpy(tmp_data.sms_data, msg, strlen(msg));
85
86 if(total_pack > 1 && curr_pack < total_pack)
87 {
88 tmp_data.user_data_head_valid = TRUE;
89 tmp_data.user_data_head.total_segments = total_pack;
90 tmp_data.user_data_head.seg_number = curr_pack;
91 lynq_sms_func_cb_handle.handlerPtr(&tmp_data, &curr_pack);
92 }
93 else
94 {
95 tmp_data.user_data_head_valid = FALSE;
96 tmp_data.user_data_head.total_segments = total_pack;
97 tmp_data.user_data_head.seg_number = curr_pack;
98 lynq_sms_func_cb_handle.handlerPtr(&tmp_data, NULL);
99 }
100
101}
102
103
104int qser_sms_client_init(sms_client_handle_type *ph_sms)//out
105{
106 //UNUSED(ph_voice);
107 if(ph_sms == NULL)
108 {
109 LOGE("[qser_sms] ph_sms is NULL.");
110 return QSER_RESULT_FAIL;
111 }
112
113 if(NULL == qser_info_handle)
114 {
115 qser_info_handle = mbtk_ril_open(MBTK_AT_PORT_DEF);
116 if(NULL == qser_info_handle)
117 {
118 LOGE("[qser_sms] qser_info_handle get fail.");
119 return QSER_RESULT_FAIL;
120 }
121 }
122 else
123 {
124 LOGE("[qser_sms] qser_info_handle has init.");
125 *ph_sms = qser_h_sms;
126 return QSER_RESULT_FAIL;
127 }
128 *ph_sms = qser_h_sms;
129
130 LOGE("[qser_sms] qser_info_handle get success.");
131
132
133 return QSER_RESULT_SUCCESS;
134
135}
136
137
138int qser_sms_client_deinit(sms_client_handle_type h_sms)//in
139{
140 if(h_sms != qser_h_sms)
141 {
142 LOGE("[qser_sms] h_sms is error.");
143 return QSER_RESULT_FAIL;
144 }
145
146 if(qser_info_handle)
147 {
148 int ret = mbtk_ril_close(MBTK_AT_PORT_DEF);;
149 if(ret)
150 {
151 LOGE("[qser_sms] mbtk_info_handle_free() fail.");
152 return QSER_RESULT_FAIL;
153 }
154 else
155 {
156 qser_info_handle = NULL;
157 lynq_sms_func_cb_handle.handlerPtr = NULL;
158 }
159 }
160 else
161 {
162 LOGE("[qser_sms] handle not inited.");
163 return QSER_RESULT_FAIL;
164 }
165
166 return QSER_RESULT_SUCCESS;
167}
168
169
170int qser_sms_send_sms(sms_client_handle_type h_sms, QSER_sms_info_t *pt_sms_info)//in in 发送短信的内容、目的号码
171{
172 if(h_sms != qser_h_sms)
173 {
174 LOGE("[qser_sms] h_sms is error.");
175 return QSER_RESULT_FAIL;
176 }
177
178 if (pt_sms_info == NULL)
179 {
180 LOGE("QSER_sms_info_t NULL");
181 return -1;
182 }
183
184 if(qser_info_handle == NULL)
185 {
186 LOGE("qser_sms_send_sms qser_info_handle NULL");
187 return -1;
188 }
189
190 int8 *phone_num = NULL;
191 int8 *msg = NULL;
192 int32 msg_len;
193
194 char cmgs[MSM_NUMBER_MAX] = {0};
195 char resp[RES_NUM_MIN] = {0};
196
197 char smscPDU[30] = {0};
198 char **pdu = NULL;
199 char smsc[4] = {0};
200 char msg_e_b[HAL_SMS_CONTENT_LEN] = {0};// +1 for end of string.*2:A char array contains two elements of a string for each value
201
202 int char_set = 0;
203 int lsms_flag = 0;
204 int err = 0;
205 int i = 0;
206
207 msg = (int8 *)pt_sms_info->sms_data;
208
209 msg_len = strlen(pt_sms_info->sms_data);
210
211 phone_num = (int8 *)pt_sms_info->src_addr;
212
213 lsms_flag = pt_sms_info->user_data_head_valid;
214
215 if(strcmp((char*)msg,"") == 0 || msg[0] == '\0')
216 {
217 LOGE("qser_sms_send_sms msg [%s]",msg);
218 return -1;
219 }
220
221 if(strcmp((char*)phone_num,"") == 0 || phone_num[0] == '\0')
222 {
223 LOGE("qser_sms_send_sms phone_num [%s]",phone_num);
224 return -1;
225 }
226
227 if (pt_sms_info->format == 0)//7
228 char_set = 0;
229 else if (pt_sms_info->format == 1)//8
230 char_set = 1;
231 else if (pt_sms_info->format == 2)//UCS2
232 char_set = 2;
233 else
234 {
235 LOGE("qser_sms_send_sms format error");
236 return -1;
237 }
238
239
240 //设置存储器
241/*
242 if (pt_sms_info->storage == 0)
243 {
244 strcpy(mem, "SM");
245 }
246 else if (pt_sms_info->storage == 1)
247 {
248 strcpy(mem, "ME");
249 }
250 else
251 {
252 LOGE("qser_sms_deletefromstorage storage is no Support");
253 return -1;
254 }
255
256 memset(resp, 0, sizeof(resp));
257 err = mbtk_sms_cpms_set(qser_info_handle, mem, resp);
258 if(err) {
259 LOGE("Error : %d", err);
260 } else {
261 LOGI("cpms set success. resp:%s", resp);
262 }
263*/
264
265
266
267 kal_int32 msg_num = 0;
268 kal_int32 pdu_msg_len = 0;
269 kal_int32 status = MDAPI_RET_ERROR;
270 kal_int32 index = 0;
271
272 if(char_set == 1) //8bit
273 {
274 ArrayToStr((unsigned char *)msg, (unsigned int)msg_len, msg_e_b);
275 status = _mdapi_sms_get_msg_num(msg_e_b, char_set, &msg_num, &pdu_msg_len);
276 }
277 else //7bit usc2
278 {
279 status = _mdapi_sms_get_msg_num((char *)msg, char_set, &msg_num, &pdu_msg_len);
280 }
281
282 LOGE("msg_len = [%d] ,msg_num=[%d]",msg_len, msg_num);
283 if(status == MDAPI_RET_ERROR)
284 {
285 LOGE("get message number failed");
286 return QSER_RESULT_FAIL;
287 }
288 else
289 {
290 if (lsms_flag == TRUE || lsms_flag == FALSE)
291 {
292 if (lsms_flag == FALSE && msg_num > 1)
293 {
294 LOGE("msg_num %d user head need for true",msg_num);
295 return QSER_RESULT_FAIL;
296 }
297 else if (lsms_flag == TRUE && msg_num > 4)
298 {
299 LOGE("Only 4 long SMS messages are supported");
300 return QSER_RESULT_FAIL;
301 }
302 }
303 else
304 {
305 LOGE("1:TRUE long sms 0:FALSE short message set user head error:%d",lsms_flag);
306 return QSER_RESULT_FAIL;
307 }
308
309
310 //allocate memery for **pdu
311 pdu = (char **)malloc(sizeof(char *) * msg_num);
312 if(pdu == NULL)
313 {
314 LOGE("allocate memory for pdu failed");
315 return QSER_RESULT_FAIL;
316 }
317 else
318 {
319 for(index = 0; index < msg_num; index++)
320 {
321 pdu[index] = (char *)malloc(sizeof(char)*MAX_PDU_SIZE);
322 if(pdu[index] == NULL)
323 {
324 for(i = 0; i < index; i++)
325 {
326 free(pdu[i]);
327 pdu[i] = NULL;
328 }
329 free(pdu);
330 pdu = NULL;
331 LOGE("allocate memory for pdu[%d] failed",index);
332 return QSER_RESULT_FAIL;
333 }
334 else
335 {
336 memset(pdu[index], 0, MAX_PDU_SIZE);
337 LOGE("pdu[%d} init value is: %s ",index, pdu[index]);
338 }
339 }
340 }
341 }
342
343 //allocate memory for **pdu success
344 if(index == msg_num)
345 {
346 if(char_set == 1)//8bit
347 {
348 smsPduEncode(smsc, (char *)phone_num, msg_e_b, char_set, smscPDU, pdu);
349 }
350 else
351 {
352 smsPduEncode(smsc, (char *)phone_num, (char *)msg, char_set, smscPDU, pdu);
353 }
354
355 for(index = 0; index < msg_num; index++)
356 {
357 char pdu_data[MAX_PDU_SIZE] = {0};
358 char *p = pdu_data;
359
360 LOGE("index:%d",index);
361 LOGE("smscPDU: %s, pdu: %s",smscPDU, pdu[index]);
362 sprintf(p, "%s",smscPDU);
363 LOGE("pdu_data:%s\n", pdu_data);
364 int sc = strlen(pdu_data);
365 sprintf(p+strlen(p), "%s", pdu[index]);
366 LOGE("pdu_data:%s", pdu_data);
367
368 int t = strlen(pdu_data);
369 sprintf(cmgs, "%d,%s", (t-sc)/2, pdu_data);
370 LOGE("cmgs:%s\n", cmgs);
371 memset(resp, 0, sizeof(resp));
372
373 err = mbtk_sms_cmgf_set(qser_info_handle, 0);
374 if(err)
375 {
376 LOGE("cmgf set error : %d", err);
377 for(index = 0; index < msg_num; index++){
378 free(pdu[index]);
379 pdu[index] = NULL;
380 }
381 free(pdu);
382 pdu = NULL;
383 return QSER_RESULT_FAIL;
384 }
385 else
386 {
387 LOGD("cmgf set success");
388 }
389
390 err = mbtk_sms_cmgs_set(qser_info_handle, cmgs, resp);
391 if(err)
392 {
393 LOGE("cmgs send fail (%d)",err);
394 for(index = 0; index < msg_num; index++){
395 free(pdu[index]);
396 pdu[index] = NULL;
397 }
398 free(pdu);
399 pdu = NULL;
400 return QSER_RESULT_FAIL;
401 }
402 else
403 {
404 LOGD("cmgs send success, resp:%s", resp);
405 }
406
407 }
408 }
409
410 for(index = 0; index < msg_num; index++){
411 free(pdu[index]);
412 pdu[index] = NULL;
413 }
414 free(pdu);
415 pdu = NULL;
416
417 return 0;
418}
419
420//注册接收新短信
421int qser_sms_addrxmsghandler(QSER_SMS_RxMsgHandlerFunc_t handlerPtr, void* contextPtr)//in sms电话状态回调函数 in 主要是获取 上报 的内容
422{
423 //UNUSED(handlerPtr);
424 //UNUSED(contextPtr);
425
426 if(qser_info_handle == NULL)
427 {
428 LOGE("qser_sms_addrxmsghandler qser_info_handle NULL");
429 return -1;
430 }
431
432 int err = mbtk_sms_cnmi_set(qser_info_handle);
433 if(err)
434 {
435 LOGE("set cnmi fail (%d)",err);
436 return -1;
437 }
438
439 lynq_sms_func_cb_handle.handlerPtr = handlerPtr;
440 lynq_sms_func_cb_handle.contextPtr = contextPtr;
441
442 err = mbtk_sms_state_change_cb_reg(lynq_sms_state_change_cb);
443 if(err)
444 {
445 LOGE("mbtk_sms_state_change_cb_reg fail (%d)",err);
446 return -1;
447 }
448
449 return 0;
450}
451
452//删除短信
453int qser_sms_deletefromstorage(sms_client_handle_type h_sms, QSER_sms_storage_info_t *pt_sms_storage)//in in 删除短信的信息
454{
455 //UNUSED(h_sms);
456 //UNUSED(pt_sms_storage);
457 char cmgd[128] = {0};
458 int err = 0;
459
460 if(h_sms != qser_h_sms)
461 {
462 LOGE("[qser_sms] h_sms is error.");
463 return QSER_RESULT_FAIL;
464 }
465
466 if(pt_sms_storage == NULL)
467 {
468 LOGE("qser_sms_deletefromstorage pt_sms_storage NULL");
469 return -1;
470 }
471
472 if(qser_info_handle == NULL)
473 {
474 LOGE("qser_sms_deletefromstorage qser_info_handle NULL");
475 return -1;
476 }
477/*
478 t_storage = pt_sms_storage->storage; //设置存储器
479
480 if (t_storage == 0)
481 {
482 strncpy(mem, "SM", 2);
483 }
484 else if (t_storage == 1)
485 {
486 strncpy(mem, "ME", 2);
487 }
488 else
489 {
490 LOGE("qser_sms_deletefromstorage storage is no Support");
491 return -1;
492 }
493
494 memset(resp, 0, sizeof(resp));
495 err = mbtk_sms_cpms_set(qser_info_handle, mem, resp);
496 if(err) {
497 LOGE("Error : %d", err);
498 } else {
499 LOGI("cpms set success. resp:%s", resp);
500 }
501*/
502 uint32_t id_x = 0; //若后面其他产品是int类型则用宏控制
503 id_x = pt_sms_storage->storage_idx;//获取idx的值
504
505 if(id_x == -1) //delete all
506 {
507 memcpy(cmgd, "0,4", strlen("0,4"));
508 }
509 else
510 {
511 sprintf(cmgd,"%d",id_x);
512 }
513
514 LOGI("cmgd:%s", cmgd);
515
516 err = mbtk_sms_cmgd_set(qser_info_handle, cmgd);
517 if(err)
518 {
519 LOGE("qser_sms_deletefromstorage Error : %d", err);
520 return -1;
521 }
522 else
523 {
524 LOGI("qser_sms_deletefromstorage set success");
525 }
526
527 return 0;
528}
529
530//获取短信中心号码
531int qser_sms_getsmscenteraddress( sms_client_handle_type h_sms,QSER_sms_service_center_cfg_t *set_sca_cfg)//in out
532{
533 //UNUSED(h_sms);
534 //UNUSED(set_sca_cfg);
535 char sms_center_addree[254] = {0};
536 int len_t;
537 char *p1, *p2 ,*substr;
538
539 if(h_sms != qser_h_sms)
540 {
541 LOGE("[qser_sms] h_sms is error.");
542 return QSER_RESULT_FAIL;
543 }
544
545 if (set_sca_cfg == NULL)
546 {
547 LOGE("QSER_sms_service_center_cfg_t NULL");
548 return -1;
549 }
550
551 if(qser_info_handle == NULL)
552 {
553 LOGE("qser_sms_getsmscenteraddress qser_info_handle NULL");
554 return -1;
555 }
556
557 int err = mbtk_sms_csca_get(qser_info_handle, sms_center_addree);
558 if(sms_center_addree[0] == '\0')
559 {
560 LOGE("qser_sms_getsmscenteraddress Error : %d", err);
561 return -1;
562 }
563 else
564 {
565 p1 = strchr(sms_center_addree, '\"');
566 p2 = strrchr(sms_center_addree, '\"');
567 if (p1 && p2 && p2 > p1)
568 {
569 len_t = p2 - p1 - 1;
570 char substr_t[len_t + 1];
571 strncpy(substr_t, p1 + 1, len_t);
572 substr_t[len_t] = '\0';
573
574 substr = substr_t;
575
576 memcpy(set_sca_cfg->service_center_addr, substr, strlen(substr));
577 memcpy(sms_center_address, substr, strlen(substr));
578
579 LOGI("qser_sms_getsmscenteraddress success");
580 }
581 else
582 {
583 LOGE("String inside double quotes not found");
584 return -1;
585 }
586 }
587
588 return 0;
589}
590
591//设置短信中心号码
592int qser_sms_setsmscenteraddress( sms_client_handle_type h_sms, QSER_sms_service_center_cfg_t *get_sca_cfg)//in in
593{
594 //UNUSED(h_sms);
595 //UNUSED(get_sca_cfg);
596 char *destNum = NULL;
597
598 if(h_sms != qser_h_sms)
599 {
600 LOGE("[qser_sms] h_sms is error.");
601 return QSER_RESULT_FAIL;
602 }
603
604 if(qser_info_handle == NULL)
605 {
606 LOGE("qser_sms_setsmscenteraddress qser_info_handle NULL");
607 return -1;
608 }
609
610 if(get_sca_cfg == NULL)
611 {
612 LOGE("qser_sms_setsmscenteraddress get_sca_cfg NULL");
613 return -1;
614 }
615
616 destNum = get_sca_cfg->service_center_addr;
617
618 //printf("1destNum:%s\n", destNum);
619 memset(sms_center_address, 0, sizeof(sms_center_address));
620 memcpy(sms_center_address, destNum, strlen(destNum));
621
622 if (destNum == NULL)
623 {
624 LOGE("qser_sms_setsmscenteraddress destNum NULL");
625 return -1;
626 }
627
628 int err = mbtk_sms_csca_set(qser_info_handle, destNum);
629 if(err)
630 {
631 LOGE("Error : %d", err);
632 return -1;
633 }
634 else
635 {
636 // memset(sms_center_address, 0, sizeof(sms_center_address));
637 // memcpy(sms_center_address, destNum, strlen(destNum));
638 //printf("destNum:%s\n", destNum);
639 LOGI("qser_sms_setsmscenteraddress success");
640 }
641
642 return 0;
643}
644
645
646//显示删除列表
647int qser_sms_deletefromstoragelist( sms_client_handle_type h_sms, char* del_list)//in out
648{
649 //UNUSED(h_sms);
650 //UNUSED(get_sca_cfg);
651
652 if(h_sms != qser_h_sms)
653 {
654 LOGE("[qser_sms] h_sms is error.");
655 return QSER_RESULT_FAIL;
656 }
657
658 if(qser_info_handle == NULL)
659 {
660 LOGE("qser_sms_deletefromstoragelist qser_info_handle NULL");
661 return -1;
662 }
663
664 int err = mbtk_sms_cmgd_get(qser_info_handle, del_list);
665 if(err > 0 && err != 300)//MBTK_INFO_ERR_SUCCESS
666 {
667 LOGE("Error : %d", err);
668 return -1;
669 }
670
671 return 0;
672}
673