aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVadim Yanitskiy <axilirator@gmail.com>2018-12-27 08:15:00 +0700
committerVadim Yanitskiy <axilirator@gmail.com>2018-12-27 16:12:49 +0100
commit5e4069cac7b9d07a56298edeeab994e5724e1437 (patch)
tree9a4e7294fe61006982f37c4f46d8316d71076cea
parent4bd7bdb9588c5a09f00c56d152f13a9799875721 (diff)
SS/USSD: add IUSEs to enable / disable UMTS
-rw-r--r--src/hlr_ussd.c60
-rw-r--r--src/hlr_vty.c6
2 files changed, 64 insertions, 2 deletions
diff --git a/src/hlr_ussd.c b/src/hlr_ussd.c
index 753e48b..0eab395 100644
--- a/src/hlr_ussd.c
+++ b/src/hlr_ussd.c
@@ -356,6 +356,58 @@ static int handle_ussd_get_ran(struct osmo_gsup_conn *conn, struct ss_session *s
return rc;
}
+static int handle_ussd_umts_on(struct osmo_gsup_conn *conn, struct ss_session *ss,
+ const struct osmo_gsup_message *gsup,
+ const struct ss_request *req)
+{
+ struct hlr_subscriber subscr;
+ int rc;
+
+ rc = db_subscr_get_by_imsi(g_hlr->dbc, ss->imsi, &subscr);
+ switch (rc) {
+ case 0:
+ hlr_subscr_rat_flag(g_hlr, &subscr, OSMO_RAT_UTRAN_IU, true);
+ rc = ss_tx_ussd_7bit(ss, true, req->invoke_id,
+ "Enabled UTRAN-Iu (3G)");
+ break;
+ case -ENOENT:
+ rc = ss_tx_error(ss, true, GSM0480_ERR_CODE_UNKNOWN_SUBSCRIBER);
+ break;
+ case -EIO:
+ default:
+ rc = ss_tx_error(ss, true, GSM0480_ERR_CODE_SYSTEM_FAILURE);
+ break;
+ }
+
+ return rc;
+}
+
+static int handle_ussd_umts_off(struct osmo_gsup_conn *conn, struct ss_session *ss,
+ const struct osmo_gsup_message *gsup,
+ const struct ss_request *req)
+{
+ struct hlr_subscriber subscr;
+ int rc;
+
+ rc = db_subscr_get_by_imsi(g_hlr->dbc, ss->imsi, &subscr);
+ switch (rc) {
+ case 0:
+ hlr_subscr_rat_flag(g_hlr, &subscr, OSMO_RAT_UTRAN_IU, false);
+ rc = ss_tx_ussd_7bit(ss, true, req->invoke_id,
+ "Disabled UTRAN-Iu (3G)");
+ break;
+ case -ENOENT:
+ rc = ss_tx_error(ss, true, GSM0480_ERR_CODE_UNKNOWN_SUBSCRIBER);
+ break;
+ case -EIO:
+ default:
+ rc = ss_tx_error(ss, true, GSM0480_ERR_CODE_SYSTEM_FAILURE);
+ break;
+ }
+
+ return rc;
+}
+
static const struct hlr_iuse hlr_iuses[] = {
{
.name = "own-msisdn",
@@ -369,6 +421,14 @@ static const struct hlr_iuse hlr_iuses[] = {
.name = "get-ran",
.handle_ussd = handle_ussd_get_ran,
},
+ {
+ .name = "umts-on",
+ .handle_ussd = handle_ussd_umts_on,
+ },
+ {
+ .name = "umts-off",
+ .handle_ussd = handle_ussd_umts_off,
+ },
};
const struct hlr_iuse *iuse_find(const char *name)
diff --git a/src/hlr_vty.c b/src/hlr_vty.c
index 9ecf8a3..c373d3a 100644
--- a/src/hlr_vty.c
+++ b/src/hlr_vty.c
@@ -133,11 +133,13 @@ DEFUN(cfg_hlr_gsup_bind_ip,
#define UROUTE_STR "Routing Configuration\n"
#define PREFIX_STR "Prefix-Matching Route\n" "USSD Prefix\n"
-#define INT_CHOICE "(own-msisdn|own-imsi|get-ran)"
+#define INT_CHOICE "(own-msisdn|own-imsi|get-ran|umts-on|umts-off)"
#define INT_STR "Internal USSD Handler\n" \
"Respond with subscribers' own MSISDN\n" \
"Respond with subscribers' own IMSI\n" \
- "Respond with available RAN types\n"
+ "Respond with available RAN types\n" \
+ "Enable UMTS service\n" \
+ "Disable UMTS service\n"
#define EXT_STR "External USSD Handler\n" \
"Name of External USSD Handler (IPA CCM ID)\n"