diff options
Diffstat (limited to 'channels')
-rw-r--r-- | channels/chan_sip.c | 42 |
1 files changed, 11 insertions, 31 deletions
diff --git a/channels/chan_sip.c b/channels/chan_sip.c index 610ba24e2..a3b8af2e5 100644 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -10561,10 +10561,7 @@ static int handle_request_invite(struct sip_pvt *p, struct sip_request *req, int transmit_fake_auth_response(p, req, p->randdata, sizeof(p->randdata), 1); } else { ast_log(LOG_NOTICE, "Failed to authenticate user %s\n", get_header(req, "From")); - if (ignore) - transmit_response(p, "403 Forbidden", req); - else - transmit_response_reliable(p, "403 Forbidden", req, 1); + transmit_response_reliable(p, "403 Forbidden", req, 1); } ast_set_flag(p, SIP_NEEDDESTROY); p->theirtag[0] = '\0'; /* Forget their to-tag, we'll get a new one */ @@ -10593,10 +10590,7 @@ static int handle_request_invite(struct sip_pvt *p, struct sip_request *req, int if (res) { if (res < 0) { ast_log(LOG_NOTICE, "Failed to place call for user %s, too many calls\n", p->username); - if (ignore) - transmit_response(p, "480 Temporarily Unavailable (Call limit)", req); - else - transmit_response_reliable(p, "480 Temporarily Unavailable (Call limit) ", req, 1); + transmit_response_reliable(p, "480 Temporarily Unavailable (Call limit) ", req, 1); ast_set_flag(p, SIP_NEEDDESTROY); } return 0; @@ -10609,20 +10603,13 @@ static int handle_request_invite(struct sip_pvt *p, struct sip_request *req, int build_contact(p); if (gotdest) { - if (gotdest < 0) { - if (ignore) - transmit_response(p, "404 Not Found", req); - else - transmit_response_reliable(p, "404 Not Found", req, 1); - update_call_counter(p, DEC_CALL_LIMIT); - } else { - if (ignore) - transmit_response(p, "484 Address Incomplete", req); - else - transmit_response_reliable(p, "484 Address Incomplete", req, 1); - update_call_counter(p, DEC_CALL_LIMIT); - } + if (gotdest < 0) + transmit_response_reliable(p, "404 Not Found", req, 1); + else + transmit_response_reliable(p, "484 Address Incomplete", req, 1); + update_call_counter(p, DEC_CALL_LIMIT); ast_set_flag(p, SIP_NEEDDESTROY); + return 0; } else { /* If no extension was specified, use the s one */ if (ast_strlen_zero(p->exten)) @@ -10728,19 +10715,12 @@ static int handle_request_invite(struct sip_pvt *p, struct sip_request *req, int } else { if (p && !ast_test_flag(p, SIP_NEEDDESTROY) && !ignore) { if (!p->jointcapability) { - if (ignore) - transmit_response(p, "488 Not Acceptable Here (codec error)", req); - else - transmit_response_reliable(p, "488 Not Acceptable Here (codec error)", req, 1); - ast_set_flag(p, SIP_NEEDDESTROY); + transmit_response_reliable(p, "488 Not Acceptable Here (codec error)", req, 1); } else { ast_log(LOG_NOTICE, "Unable to create/find channel\n"); - if (ignore) - transmit_response(p, "503 Unavailable", req); - else - transmit_response_reliable(p, "503 Unavailable", req, 1); - ast_set_flag(p, SIP_NEEDDESTROY); + transmit_response_reliable(p, "503 Unavailable", req, 1); } + ast_set_flag(p, SIP_NEEDDESTROY); } } return res; |