Software /
code /
prosody
Comparison
core/portmanager.lua @ 7950:f91e7ec9654e
Merge 0.10->trunk
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Mon, 06 Mar 2017 01:14:32 +0100 |
parent | 7947:24170d74b00b |
child | 8555:4f0f5b49bb03 |
comparison
equal
deleted
inserted
replaced
7946:c92102fe409b | 7950:f91e7ec9654e |
---|---|
101 for port in bind_ports do | 101 for port in bind_ports do |
102 local port_number = tonumber(port); | 102 local port_number = tonumber(port); |
103 if not port_number then | 103 if not port_number then |
104 log("error", "Invalid port number specified for service '%s': %s", service_info.name, tostring(port)); | 104 log("error", "Invalid port number specified for service '%s': %s", service_info.name, tostring(port)); |
105 elseif #active_services:search(nil, interface, port_number) > 0 then | 105 elseif #active_services:search(nil, interface, port_number) > 0 then |
106 log("error", "Multiple services configured to listen on the same port ([%s]:%d): %s, %s", interface, port, active_services:search(nil, interface, port)[1][1].service.name or "<unnamed>", service_name or "<unnamed>"); | 106 log("error", "Multiple services configured to listen on the same port ([%s]:%d): %s, %s", interface, port, |
107 active_services:search(nil, interface, port)[1][1].service.name or "<unnamed>", service_name or "<unnamed>"); | |
107 else | 108 else |
108 local err; | 109 local err; |
109 -- Create SSL context for this service/port | 110 -- Create SSL context for this service/port |
110 if service_info.encryption == "ssl" then | 111 if service_info.encryption == "ssl" then |
111 local global_ssl_config = config.get("*", "ssl") or {}; | 112 local global_ssl_config = config.get("*", "ssl") or {}; |
116 prefix_ssl_config, | 117 prefix_ssl_config, |
117 service_info.ssl_config or {}, | 118 service_info.ssl_config or {}, |
118 global_ssl_config[interface], | 119 global_ssl_config[interface], |
119 global_ssl_config[port]); | 120 global_ssl_config[port]); |
120 if not ssl then | 121 if not ssl then |
121 log("error", "Error binding encrypted port for %s: %s", service_info.name, error_to_friendly_message(service_name, port_number, err) or "unknown error"); | 122 log("error", "Error binding encrypted port for %s: %s", service_info.name, |
123 error_to_friendly_message(service_name, port_number, err) or "unknown error"); | |
122 end | 124 end |
123 end | 125 end |
124 if not err then | 126 if not err then |
125 -- Start listening on interface+port | 127 -- Start listening on interface+port |
126 local handler, err = server.addserver(interface, port_number, listener, mode, ssl); | 128 local handler, err = server.addserver(interface, port_number, listener, mode, ssl); |
127 if not handler then | 129 if not handler then |
128 log("error", "Failed to open server port %d on %s, %s", port_number, interface, error_to_friendly_message(service_name, port_number, err)); | 130 log("error", "Failed to open server port %d on %s, %s", port_number, interface, |
131 error_to_friendly_message(service_name, port_number, err)); | |
129 else | 132 else |
130 table.insert(hooked_ports, "["..interface.."]:"..port_number); | 133 table.insert(hooked_ports, "["..interface.."]:"..port_number); |
131 log("debug", "Added listening service %s to [%s]:%d", service_name, interface, port_number); | 134 log("debug", "Added listening service %s to [%s]:%d", service_name, interface, port_number); |
132 active_services:add(service_name, interface, port_number, { | 135 active_services:add(service_name, interface, port_number, { |
133 server = handler; | 136 server = handler; |
136 end | 139 end |
137 end | 140 end |
138 end | 141 end |
139 end | 142 end |
140 end | 143 end |
141 log("info", "Activated service '%s' on %s", service_name, #hooked_ports == 0 and "no ports" or table.concat(hooked_ports, ", ")); | 144 log("info", "Activated service '%s' on %s", service_name, |
145 #hooked_ports == 0 and "no ports" or table.concat(hooked_ports, ", ")); | |
142 return true; | 146 return true; |
143 end | 147 end |
144 | 148 |
145 local close; -- forward declaration | 149 local close; -- forward declaration |
146 | 150 |