diff simtool/pbdump.c @ 19:72a24b8538eb

meaty function of pb-dump moved back into simtool, out of libcommon Upon further reflection, I am not going to keep any of the pb-* commands in the new version of fc-uicc-tool: they are logically incorrect for UICC/USIM anyway, as they access phonebook files via old classic SIM paths, rather than their USIM paths. OTOH, I am going to implement new SMSP commands in fc-simtool, and I do not plan to replicate them in fc-uicc-tool either. Guts of fc-simtool pb-dump belong in simtool/pbdump.c, not in libcommon, just like the guts of the future smsp-dump command will belong in its own respective implementation module.
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 12 Feb 2021 03:33:26 +0000
parents dc565e91069d
children 1861d9fb7751
line wrap: on
line diff
--- a/simtool/pbdump.c	Fri Feb 12 03:21:39 2021 +0000
+++ b/simtool/pbdump.c	Fri Feb 12 03:33:26 2021 +0000
@@ -5,8 +5,59 @@
 #include <sys/types.h>
 #include <stdio.h>
 #include <stdlib.h>
+#include "simresp.h"
 #include "curfile.h"
 
+static
+check_blank_area(dp, endp)
+	u_char *dp, *endp;
+{
+	while (dp < endp)
+		if (*dp++ != 0xFF)
+			return(-1);
+	return(0);
+}
+
+static void
+dump_record(recno, outf)
+	unsigned recno;
+	FILE *outf;
+{
+	int rc;
+	unsigned textlen;
+	u_char *fixp;
+	char digits[21];
+
+	fprintf(outf, "#%u: ", recno);
+	if (sim_resp_data_len > 14) {
+		rc = validate_alpha_field(sim_resp_data,
+					  sim_resp_data_len - 14,
+					  &textlen);
+		if (rc < 0) {
+malformed:		fprintf(outf, "malformed record\n");
+			return;
+		}
+	} else
+		textlen = 0;
+	fixp = sim_resp_data + sim_resp_data_len - 14;
+	if (fixp[0] < 2 || fixp[0] > 11)
+		goto malformed;
+	rc = decode_phone_number(fixp + 2, fixp[0] - 1, digits);
+	if (rc < 0)
+		goto malformed;
+	rc = check_blank_area(fixp + 1 + fixp[0], fixp + 12);
+	if (rc < 0)
+		goto malformed;
+	/* all checks passed */
+	fprintf(outf, "%s,0x%02X ", digits, fixp[1]);
+	if (fixp[12] != 0xFF)
+		fprintf(outf, "CCP=%u ", fixp[12]);
+	if (fixp[13] != 0xFF)
+		fprintf(outf, "EXT=%u ", fixp[13]);
+	print_alpha_field(sim_resp_data, textlen, outf);
+	putc('\n', outf);
+}
+
 cmd_pb_dump(argc, argv)
 	char **argv;
 {
@@ -34,7 +85,7 @@
 		}
 		if (check_simresp_all_blank())
 			continue;
-		dump_phonebook_record(recno, outf);
+		dump_record(recno, outf);
 	}
 	if (argv[2])
 		fclose(outf);
@@ -76,7 +127,7 @@
 			return(rc);
 		if (check_simresp_all_blank())
 			continue;
-		dump_phonebook_record(recno, stdout);
+		dump_record(recno, stdout);
 	}
 	return(0);
 }