-
Notifications
You must be signed in to change notification settings - Fork 583
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Rework contact generation, add validation & enforce contact_user even for requests taking Contact from server_address #3317
base: master
Are you sure you want to change the base?
Conversation
If contact_user is set, propagate FROM username to Contact even for requests taking Contact from server_address
Any updates here? No progress has been made in the last 30 days, marking as stale. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are couple of things not right here :
- parsing the generated URI (based on
server_address_pve
) is an unnecessary burn - as script writer you need to be sure you configuration is correct and not to expect OpenSIPS to parse it (for each message) just to be sure you are right - eventually you can do a dummy test at startup, to see if the pve generates a valid URI - the replacement of the username part (if
contact_user
is on) in the generated URI (based onserver_address_pve
) does not look right - you do not actually replace the username part, but build a completely new URI based on the username and socket - so if myserver_address_pve
was pushing some URI params or anything else, it will be lost. Normally you should have here a sctrict username replacement into thelocal_contact
parsed URI - this may be simply done with 3 memcpy's .
Don't agree with the above ... OpenSIPS should validate the server address upon building, in order to avoid sending broken messages ( due to the script writer's fault, indeed ). Can't be validated at startup, since it might contain pvars which can be only evaluated in the SIP message context.
This is indeed an issue - my use case didn't have uri params so I lost track of this. Needs correcting. |
yes, the contact must be correct, but opensips should not continuously check if the configured data is correct or not. Like we do not check if the
LEt me know if you plan to change this, we have only 2 days left to the release |
did not have time to prioritize this, since it's labeled as a bug, maybe we can hotfix & backport later. |
Summary
Rework contact generation, add validation & enforce contact_user even for requests taking Contact from server_address
Details
Due to server_address potentially containing PVARs, validate the server_address before usage
Enforce contact_user modparam even for requests that generate the Contact from server_address
Thanks to Voicenter for reporting it & helping troubleshoot.