diff --git a/src/include/switch_caller.h b/src/include/switch_caller.h
index 1d5e3372c2..43a3df89c8 100644
--- a/src/include/switch_caller.h
+++ b/src/include/switch_caller.h
@@ -99,6 +99,7 @@ SWITCH_BEGIN_EXTERN_C
 	switch_caller_profile_flag_t flags;
 	struct switch_caller_profile *originator_caller_profile;
 	struct switch_caller_profile *originatee_caller_profile;
+	struct switch_caller_profile *hunt_caller_profile;
 	struct switch_channel_timetable *times;
 	struct switch_caller_extension *caller_extension;
 	switch_memory_pool_t *pool;
diff --git a/src/include/switch_channel.h b/src/include/switch_channel.h
index e6fbe25f85..1764c7b17e 100644
--- a/src/include/switch_channel.h
+++ b/src/include/switch_channel.h
@@ -189,6 +189,8 @@ SWITCH_DECLARE(switch_caller_profile_t *) switch_channel_get_caller_profile(swit
 */
 SWITCH_DECLARE(void) switch_channel_set_originator_caller_profile(switch_channel_t *channel, switch_caller_profile_t *caller_profile);
 
+SWITCH_DECLARE(void) switch_channel_set_hunt_caller_profile(switch_channel_t *channel, switch_caller_profile_t *caller_profile);
+
 /*!
   \brief Retrive the given channel's originator caller profile
   \param channel channel to retrive the profile from
diff --git a/src/switch_channel.c b/src/switch_channel.c
index 000632e9e6..ff706c8511 100644
--- a/src/switch_channel.c
+++ b/src/switch_channel.c
@@ -1483,6 +1483,19 @@ SWITCH_DECLARE(void) switch_channel_set_originator_caller_profile(switch_channel
 	switch_mutex_unlock(channel->profile_mutex);
 }
 
+SWITCH_DECLARE(void) switch_channel_set_hunt_caller_profile(switch_channel_t *channel, switch_caller_profile_t *caller_profile)
+{
+	switch_assert(channel != NULL);
+	switch_assert(channel->caller_profile != NULL);
+
+	switch_mutex_lock(channel->profile_mutex);
+	channel->caller_profile->hunt_caller_profile = NULL;
+	if (channel->caller_profile && caller_profile) {
+		channel->caller_profile->hunt_caller_profile = caller_profile;
+	}
+	switch_mutex_unlock(channel->profile_mutex);
+}
+
 SWITCH_DECLARE(void) switch_channel_set_originatee_caller_profile(switch_channel_t *channel, switch_caller_profile_t *caller_profile)
 {
 	switch_assert(channel != NULL);
diff --git a/src/switch_core_session.c b/src/switch_core_session.c
index a9a95470a6..c226164a27 100644
--- a/src/switch_core_session.c
+++ b/src/switch_core_session.c
@@ -1526,6 +1526,7 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_execute_exten(switch_core_se
 
 	dpstr = switch_core_session_strdup(session, new_profile->dialplan);
 
+	switch_channel_set_hunt_caller_profile(channel, new_profile);
 	argc = switch_separate_string(dpstr, ',', dp, (sizeof(dp) / sizeof(dp[0])));
 	for (x = 0; x < argc; x++) {
 		char *dpname = dp[x];
@@ -1581,6 +1582,8 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_execute_exten(switch_core_se
 	}
 
   done:
+	switch_channel_set_hunt_caller_profile(channel, NULL);
+
 	session->stack_count--;
 	return status;
 }