Commit 0167a187 authored by Chris McDonough's avatar Chris McDonough

Provide sane error responses when a Zope port is already in use.

parent 4457f487
...@@ -241,6 +241,8 @@ if swhome != 'INSERT_SOFTWARE_HOME': ...@@ -241,6 +241,8 @@ if swhome != 'INSERT_SOFTWARE_HOME':
import os, sys, getopt, codecs, string import os, sys, getopt, codecs, string
import socket
from types import StringType, IntType from types import StringType, IntType
# workaround to allow unicode encoding conversions in DTML # workaround to allow unicode encoding conversions in DTML
dummy = codecs.lookup('iso-8859-1') dummy = codecs.lookup('iso-8859-1')
...@@ -624,16 +626,28 @@ try: ...@@ -624,16 +626,28 @@ try:
zLOG.LOG('z2', zLOG.BLATHER, 'Using access log file %s' % LOG_PATH) zLOG.LOG('z2', zLOG.BLATHER, 'Using access log file %s' % LOG_PATH)
sys.__lg = lg sys.__lg = lg
port_err=('\n\nZope wants to use %(socktype)s port %(port)s for its '
'%(protocol)s service, but it is already in use by another '
'application on this machine. Either shut the application down '
'which is using this port, or start Zope with a different '
'%(protocol)s port via the "%(switch)s" command-line switch.\n')
# HTTP Server # HTTP Server
if HTTP_PORT: if HTTP_PORT:
if isinstance(HTTP_PORT, IntType): HTTP_PORT=((IP_ADDRESS, HTTP_PORT),) if isinstance(HTTP_PORT, IntType): HTTP_PORT=((IP_ADDRESS, HTTP_PORT),)
for address, port in HTTP_PORT: for address, port in HTTP_PORT:
try:
hs = zhttp_server( hs = zhttp_server(
ip=address, ip=address,
port=port, port=port,
resolver=rs, resolver=rs,
logger_object=lg) logger_object=lg)
except socket.error, why:
if why[0] == 98: # address in use
raise port_err % {'port':port,
'socktype':'TCP',
'protocol':'HTTP',
'switch':'-w'}
# Handler for a published module. zhttp_handler takes 3 arguments: # Handler for a published module. zhttp_handler takes 3 arguments:
# The name of the module to publish, and optionally the URI base # The name of the module to publish, and optionally the URI base
# which is basically the SCRIPT_NAME, and optionally a dictionary # which is basically the SCRIPT_NAME, and optionally a dictionary
...@@ -655,11 +669,18 @@ try: ...@@ -655,11 +669,18 @@ try:
if isinstance(WEBDAV_SOURCE_PORT, IntType): if isinstance(WEBDAV_SOURCE_PORT, IntType):
WEBDAV_SOURCE_PORT=((IP_ADDRESS, WEBDAV_SOURCE_PORT),) WEBDAV_SOURCE_PORT=((IP_ADDRESS, WEBDAV_SOURCE_PORT),)
for address, port in WEBDAV_SOURCE_PORT: for address, port in WEBDAV_SOURCE_PORT:
try:
hs = zhttp_server( hs = zhttp_server(
ip=address, ip=address,
port=port, port=port,
resolver=rs, resolver=rs,
logger_object=lg) logger_object=lg)
except socket.error, why:
if why[0] == 98: # address in use
raise port_err % {'port':port,
'socktype':'TCP',
'protocol':'WebDAV source',
'switch':'-W'}
# Handler for a published module. zhttp_handler takes 3 arguments: # Handler for a published module. zhttp_handler takes 3 arguments:
# The name of the module to publish, and optionally the URI base # The name of the module to publish, and optionally the URI base
...@@ -689,12 +710,19 @@ try: ...@@ -689,12 +710,19 @@ try:
if FTP_PORT: if FTP_PORT:
if isinstance(FTP_PORT, IntType): FTP_PORT=((IP_ADDRESS, FTP_PORT),) if isinstance(FTP_PORT, IntType): FTP_PORT=((IP_ADDRESS, FTP_PORT),)
for address, port in FTP_PORT: for address, port in FTP_PORT:
try:
FTPServer( FTPServer(
module=MODULE, module=MODULE,
ip=address, ip=address,
port=port, port=port,
resolver=rs, resolver=rs,
logger_object=lg) logger_object=lg)
except socket.error, why:
if why[0] == 98: # address in use
raise port_err % {'port':port,
'socktype':'TCP',
'protocol':'FTP',
'switch':'-f'}
# PCGI Server # PCGI Server
if PCGI_FILE and not READ_ONLY: if PCGI_FILE and not READ_ONLY:
...@@ -716,12 +744,19 @@ try: ...@@ -716,12 +744,19 @@ try:
fcgiPort = int(FCGI_PORT) fcgiPort = int(FCGI_PORT)
except ValueError: except ValueError:
fcgiPath = FCGI_PORT fcgiPath = FCGI_PORT
try:
zfcgi = FCGIServer(module=MODULE, zfcgi = FCGIServer(module=MODULE,
ip=IP_ADDRESS, ip=IP_ADDRESS,
port=fcgiPort, port=fcgiPort,
socket_file=fcgiPath, socket_file=fcgiPath,
resolver=rs, resolver=rs,
logger_object=lg) logger_object=lg)
except socket.error, why:
if why[0] == 98: # address in use
raise port_err % {'port':fcgiPort,
'socktype':'TCP',
'protocol':'FastCGI',
'switch':'-F'}
# Monitor Server # Monitor Server
...@@ -737,16 +772,30 @@ try: ...@@ -737,16 +772,30 @@ try:
if isinstance(MONITOR_PORT, IntType): if isinstance(MONITOR_PORT, IntType):
MONITOR_PORT=((IP_ADDRESS, MONITOR_PORT),) MONITOR_PORT=((IP_ADDRESS, MONITOR_PORT),)
for address, port in MONITOR_PORT: for address, port in MONITOR_PORT:
try:
monitor=secure_monitor_server( monitor=secure_monitor_server(
password=pw, password=pw,
hostname=address, hostname=address,
port=port) port=port)
except socket.error, why:
if why[0] == 98: # address in use
raise port_err % {'port':port,
'socktype':'TCP',
'protocol':'monitor server',
'switch':'-m'}
if ICP_PORT: if ICP_PORT:
if isinstance(ICP_PORT, IntType): ICP_PORT=((IP_ADDRESS, ICP_PORT),) if isinstance(ICP_PORT, IntType): ICP_PORT=((IP_ADDRESS, ICP_PORT),)
from ZServer.ICPServer import ICPServer from ZServer.ICPServer import ICPServer
for address, port in ICP_PORT: for address, port in ICP_PORT:
try:
ICPServer(address,port) ICPServer(address,port)
except socket.error, why:
if why[0] == 98: # address in use
raise port_err % {'port':port,
'socktype':'UDP',
'protocol':'ICP',
'switch':'--icp'}
if not READ_ONLY: if not READ_ONLY:
if os.path.exists(PID_FILE): os.unlink(PID_FILE) if os.path.exists(PID_FILE): os.unlink(PID_FILE)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment