Commit 17a90f4c authored by Fred Drake's avatar Fred Drake

Oops; did not mean to add this on the trunk!

parent 23aba32e
This diff is collapsed.
This diff is collapsed.
import getopt
def getOptionDescriptions():
""" Temporary implementation """
short, long = getOptions()
n = 0
short_d = {}
long_d = {}
last = 0
n = 0
print short
if short:
while 1:
try:
opt = short[n]
except IndexError:
next = None
try:
next = short[n+1]
except IndexError:
next = None
if next == ':':
short_d[opt] = 1
n = n + 2
else:
if next is None and short.endswith(':'):
short_d[opt] = 1
else:
short_d[opt] = 0
n = n + 1
if next is None:
break
for opt in long:
if opt.endswith('='):
long_d[opt[:-1]] = 1
else:
long_d[opt] = 0
opts = []
short_l = short_d.items()
short_l.sort()
for k, v in short_l:
opts.append(' -%s%s' % (k, (v and ' <value>' or '')))
long_l = long_d.items()
long_l.sort()
for k, v in long_l:
opts.append(' --%s%s' % (k, (v and ' <value>' or '')))
return '\n'.join(opts)
def getOptions():
short = 'Z:t:i:D:a:d:u:L:l:M:E:Xw:W:f:p:F:m:'
long = [
'use-daemon-process=',
'zserver-threads=',
'python-check-interval=',
'debug-mode=',
'ip-address=',
'dns-ip-address=',
'effective-user=',
'locale=',
'access-log=',
'trace-log=',
'event-log=',
'disable-servers',
'http-server=',
'webdav-source-server=',
# XXX need to finish these
# 'ftp-server=',
# 'pcgi-server=',
# 'fcgi-server=',
# 'monitor-server=',
# 'icp-server=',
]
return short, long
class CommandLineOptions:
def __call__(self, cfg, options):
import Zope.Startup.datatypes
import Zope.Startup.handlers
import ZConfig.datatypes
short, long = getOptions()
opts, args = getopt.getopt(options, short, long)
for k, v in opts:
# set up data that servers may rely on
if k in ('-Z', '--use-daemon-process'):
datatype = Zope.Startup.datatypes.use_daemon_process
handler = Zope.Startup.handlers.use_daemon_process
v = datatype(v)
handler(v)
cfg.use_daemon_process = v
elif k in ('-t', '--zserver-threads'):
cfg.zserver_threads = int(v)
elif k in ('-i', '--python-check-interval'):
cfg.python_check_interval = int(v)
elif k in ('-D', '--debug-mode'):
datatype = ZConfig.datatypes.asBoolean
handler = Zope.Startup.handlers.debug_mode
v = datatype(v)
handler(v)
cfg.debug_mode = v
elif k in ('-i', '--ip-address'):
datatype = ZConfig.datatypes.IpaddrOrHostname()
cfg.ip_address = datatype(v)
elif k in ('-d', '--dns-ip-address'):
datatype = ZConfig.datatypes.IpaddrOrHostname()
cfg.dns_ip_address = datatype(v)
elif k in ('-u', '--effective-user'):
cfg.effective_user = v
elif k in ('-L', '--locale'):
datatype = ZConfig.datatypes.check_locale
cfg.locale = datatype(v)
elif k in ('-l', '--access-log'):
cfg.access = default_logger('access', v,
'%(message)s',
'%Y-%m-%dT%H:%M:%S')
elif k in ('-M', '--trace-log'):
cfg.trace = default_logger('trace', v,
'%(message)s',
'%Y-%m-%dT%H:%M:%S')
elif k in ('-E', '--event-log'):
cfg.trace = default_logger('event', v,
'------\n%(asctime)s %(message)s',
'%Y-%m-%dT%H:%M:%S')
elif k in ('-X', '--disable-servers'):
cfg.servers = []
else:
# continue if we've not matched, otherwise
# fall through to the pop statement below
continue
opts.pop(0) # pop non-server data from opts
factory = Zope.Startup.handlers.ServerFactoryFactory(cfg)
for k, v in opts:
# set up server data from what's left in opts,
# using repopulated cfg
if k in ('-w', '--http-server'):
datatype = ZConfig.datatypes.inet_address
host, port = datatype(v)
section = dummy()
section.ports = [(host, port)]
section.force_connection_close = 0
cfg.servers.append(['http_server',
factory.http_server(section)[0]])
if k in ('-W', '--webdav-source-server'):
datatype = ZConfig.datatypes.inet_address
host, port = datatype(v)
section = dummy()
section.ports = [(host, port)]
section.force_connection_close = 0
cfg.servers.append(['webdav_source_server',
factory.webdav_source_server(section)[0]])
class dummy:
# used as a namespace generator
pass
def default_logger(name, file, format, dateformat):
import Zope.Startup.datatypes
logger = dummy()
logger.level = 20
handler = dummy()
handler.file = file
handler.format = format
handler.dateformat = dateformat
handler.level = 20
handlers = [Zope.Startup.datatypes.file_handler(handler)]
return Zope.Startup.datatypes.LoggerWrapper(name, 20, handlers)
import os
from misc.factory import Factory
# generic datatypes
def security_policy_implementation(value):
value = value.upper()
ok = ('PYTHON', 'C')
if value not in ok:
raise ValueError, (
"security_policy_implementation must be one of %s" % ok
)
return value
def use_daemon_process(value):
from ZConfig.datatypes import asBoolean
daemonize = asBoolean(value)
# cannot use daemon process on non-POSIX platforms
if os.name != 'posix':
return False
return daemonize
# log-related datatypes
# (the loghandler datatypes come from the zLOG package)
def logger(section):
return LoggerWrapper(section.getSectionName(),
section.level,
section.handlers)
# database-related datatypes
def mount_point(value):
if value.startswith('/'):
return value
raise ValueError, (
'Invalid mount_point "%s" (must start with a slash)' % value
)
def database(section):
if len(section.storages) > 1:
raise ValueError, ('Current database support limits database '
'instances to a single storage')
if len(section.storages) < 1:
raise ValueError, 'Must name one storage in a database section'
klass = section.db_class
mounts = section.mount_points
dbfactory = Factory(
klass, None,
pool_size=section.pool_size,
cache_size=section.cache_size,
cache_deactivate_after=section.cache_deactivate_after,
version_pool_size=section.version_pool_size,
version_cache_size=section.version_cache_size,
version_cache_deactivate_after=section.version_cache_deactivate_after)
storagefactory = section.storages[0]
return mounts, DBWrapper(dbfactory, storagefactory)
def filestorage(section):
return Factory('ZODB.FileStorage.FileStorage', None, section.path,
create=section.create,
read_only=section.read_only,
stop=section.stop,
quota=section.quota)
def mappingstorage(section):
name = section.name
return Factory('ZODB.MappingStorage.MappingStorage', None, name)
def clientstorage(section):
return Factory('ZEO.ClientStorage.ClientStorage', None, section.addr,
storage=section.storage,
cache_size=section.cache_size,
name=section.name,
client=section.client,
debug=section.debug,
var=section.var,
min_disconnect_poll=section.min_disconnect_poll,
max_disconnect_poll=section.max_disconnect_poll,
wait=section.wait,
read_only=section.read_only,
read_only_fallback=section.read_only_fallback)
_marker = object()
class LoggerWrapper:
"""
A wrapper used to create loggers while delaying actual logger
instance construction. We need to do this because we may
want to reference a logger before actually instantiating it (for example,
to allow the app time to set an effective user).
An instance of this wrapper is a callable which, when called, returns a
logger object.
"""
def __init__(self, name, level, handler_factories):
self.name = name
self.level = level
self.handler_factories = handler_factories
self.resolved = _marker
def __call__(self):
if self.resolved is _marker:
# set the logger up
import logging
logger = logging.getLogger(self.name)
logger.handlers = []
logger.propagate = 0
logger.setLevel(self.level)
for handler_factory in self.handler_factories:
handler = handler_factory()
logger.addHandler(handler)
self.resolved = logger
return self.resolved
class DBWrapper:
"""
A wrapper used to create ZODB databases while delaying the underlying
storage instance construction. We need to do this because we may
want to reference a database before actually instantiating it (for
example, in order to delay database construction until after an
effective user is set or until all configuration parsing is done).
An instance of this wrapper is a callable which, when called, returns a
database object.
"""
def __init__(self, dbfactory, storagefactory):
self.dbfactory = dbfactory
self.storagefactory = storagefactory
self.resolved = _marker
def __call__(self):
if self.resolved is _marker:
args, kw = self.dbfactory.getArgs()
args = [self.storagefactory()] + list(args)
self.dbfactory.setArgs(args, kw)
self.resolved = self.dbfactory()
return self.resolved
This diff is collapsed.
##############################################################################
#
# Copyright (c) 2001, 2002 Zope Corporation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.0 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE
#
##############################################################################
"""
Revision information:
$Id: TextBlockFormatter.py,v 1.2 2003/01/29 20:25:17 fdrake Exp $
"""
import string, math
def format(text, max_width=80, indent=0, trailing_lines_indent_more=0):
text = string.expandtabs(string.replace(text, '\r', ''))
lines = string.split(text, '\n')
aggregate = []
for line in lines:
if len(line) <= max_width-1:
# this line is short enough to output
aggregate.append(line)
else:
lines = splitlongline(line, max_width)
aggregate.extend(lines)
out = []
i = 0
for line in aggregate:
spaces = ' ' * indent
if i != 0 and trailing_lines_indent_more:
spaces = spaces + (' ' * trailing_lines_indent_more)
out.append('%s%s' % (spaces, line))
i = i + 1
return string.join(out, '\n')
def splitword(word, max_width=80, linepos=0):
# some lines may have single words that exceed the max_width
# We want to break apart long words into as many chunks as necessary
if len(word) <= max_width:
return [word]
first_chunk_len = max_width-1-linepos
firstchunk = word[:first_chunk_len]
word = word[first_chunk_len:]
numchunks = int(math.ceil(len(word) / float(max_width-1)))
index = 0
tmp = [firstchunk]
for chunknum in range(numchunks):
chunk = word[index:index+max_width-1]
tmp.append(chunk)
index = index + max_width-1
return tmp
def splitlongline(line, max_width=80):
# split a "long" line defined by max_width into a list of lines
line = string.strip(line)
words = string.split(line, ' ')
wordnum = 0
# iterate over all the words in the line, extending the word list
# necessary for too-long words
aggregate = []
linelen = 0
wordnum = 0
while words:
word = words.pop(0)
if not word: continue
if len(word) > max_width:
new_words = splitword(word, max_width, linelen)
word = new_words[0]
for new_word in new_words[1:]:
words.insert(wordnum, new_word)
wordnum = wordnum + 1
if words:
next_word = words[0]
else:
next_word = None
if next_word is None:
aggregate.append(word)
wordnum = wordnum + 1
continue
maybe_len = linelen + len(word) + len(next_word)
if maybe_len >= max_width-1:
aggregate.append(word)
aggregate.append(None)
linelen = 0
else:
aggregate.append(word)
linelen = linelen + len(word) + 1
wordnum = wordnum + 1
s = ""
last = None
for item in aggregate:
if item is None:
s = '%s\n' % s
elif last is None:
s = '%s%s' % (s, item)
else:
s = '%s %s' % (s, item)
last = item
return string.split(s, '\n')
long = """
To turn a component into a product you must fulfill many contracts. For the most part these contracts are not yet defined in terms of interfaces. Instead you must subclass from base classes that implement the contracts. This makes building products confusing, and this is an area that we are actively working on improving. Hereisalonglinethatshouldbecaughtandbrokenupbytheformatter,hopefullyitllgetsplitupwhenirunitthroughthere."""
long2 = """
Hereisalonglinethatshouldbecaughtandbrokenupbytheformatter,hopefullyitllgetsplitupwhenirunitthroughthere."""
long3 = """
To turn a component into a product you must fulfill many contracts. For the most part these contracts are not yet defined in terms of interfaces.
Instead you must subclass from base classes that implement the contracts. This makes building products confusing, and this is an area that we are
actively working on improving. Hereisalonglinethatshouldbecaughtandbrokenupbytheformatter,hopefullyitllgetsplitupwhenirunitthroughthere."""
if __name__ == '__main__':
print format(long, 60, 10)
print format(long)
print format(long2, 60, 10)
print format(long2)
print format(long3, 60, 10)
print format(long3)
_marker = []
def importer(name):
components = name.split('.')
start = components[0]
g = globals()
package = __import__(start, g, g)
modulenames = [start]
for component in components[1:]:
modulenames.append(component)
try:
package = getattr(package, component)
except AttributeError:
name = '.'.join(modulenames)
package = __import__(name, g, g, component)
return package
class Factory:
"""
A generic wrapper for instance construction and function calling used
to delay construction/call until necessary. The class path is the dotted
name to the class or function, args are the positional args, kw are the
keyword args. If it is specified, 'callback' is a function which will be
called back after constructing an instance or calling a function. It must
take the instance (or the result of the function) as a single argument.
"""
def __init__(self, class_path, callback, *args, **kw):
self.class_path = class_path
self.callback = callback
self.setArgs(list(args), kw)
self.resolved = _marker
def __repr__(self):
return ('<Factory instance for class "%s" with positional args "%s" '
'and keword args "%s"' % (self.class_path, self.args, self.kw))
__str__ = __repr__
def __call__(self):
if self.resolved is _marker:
package = importer(self.class_path)
inst = package(*self.args, **self.kw)
if self.callback:
self.callback(inst)
self.resolved = inst
return self.resolved
def setArgs(self, args, kw):
self.args = args
self.kw = kw
def getArgs(self):
return (self.args, self.kw)
##############################################################################
#
# Copyright (c) 2001, 2002 Zope Corporation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.0 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE
#
##############################################################################
""" Utilities for file locking """
try:
import fcntl
def lock_file(file):
un=file.fileno()
fcntl.flock(un, fcntl.LOCK_EX | fcntl.LOCK_NB)
except:
# Try windows-specific code:
try:
from ZODB.winlock import LockFile
def lock_file(file):
un=file.fileno()
LockFile(un,0,0,1,0) # just lock the first byte, who cares
except:
# we don't understand any kind of locking, forget it
def lock_file(file):
pass
#!/usr/bin/env python
##############################################################################
#
# Copyright (c) 2001 Zope Corporation and Contributors. All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.0 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE
#
##############################################################################
"""Zope user bootstrap system"""
__version__='$Revision: 1.2 $ '[11:-2]
import sys, sha, binascii, random, getopt, getpass, os
try:
from crypt import crypt
except ImportError:
crypt = None
def generate_salt():
"""Generate a salt value for the crypt function."""
salt_choices = ("ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"abcdefghijklmnopqrstuvwxyz"
"0123456789./")
return random.choice(salt_choices)+random.choice(salt_choices)
def generate_passwd(password, encoding):
encoding=encoding.upper()
if encoding == 'SHA':
pw = '{SHA}' + binascii.b2a_base64(sha.new(password).digest())[:-1]
elif encoding == 'CRYPT':
pw = '{CRYPT}' + crypt(password, generate_salt())
elif encoding == 'CLEARTEXT':
pw = password
return pw
def write_generated_password(home, ac_path, username):
pw_choices = ("ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"abcdefghijklmnopqrstuvwxyz"
"0123456789!")
acfile=open(ac_path, 'w')
pw = ''
for i in range(8):
pw = pw + random.choice(pw_choices)
acfile.write('%s:%s' % (username, generate_passwd(pw, 'SHA')))
acfile.close()
os.system('chmod 644 %s' % ac_path)
return pw
def write_access(home, user='', group=''):
ac_path=os.path.join(home, 'access')
if not os.path.exists(ac_path):
print '-'*78
print 'creating default access file'
pw = write_generated_password(home, ac_path, 'emergency')
print """Note:
The emergency user name and password are 'emergency'
and '%s'.
You can change the emergency name and password with the
zpasswd script. To find out more, type:
%s zpasswd.py
""" % (pw, sys.executable)
import do; do.ch(ac_path, user, group)
def write_inituser(home, user='', group=''):
ac_path=os.path.join(home, 'inituser')
if not os.path.exists(ac_path):
print '-'*78
print 'creating default inituser file'
pw = write_generated_password(home, ac_path, 'admin')
print """Note:
The initial user name and password are 'admin'
and '%s'.
You can change the name and password through the web
interface or using the 'zpasswd.py' script.
""" % pw
import do; do.ch(ac_path, user, group)
def main(argv):
short_options = ':u:p:e:d:'
long_options = ['username=',
'password=',
'encoding=',
'domains=']
usage = """Usage: %s [options] filename
If this program is called without command-line options, it will prompt
for all necessary information. The available options are:
-u / --username=
Set the username to be used for the initial user or the emergency user
-p / --password=
Set the password
-e / --encoding=
Set the encryption/encoding rules. Defaults to SHA-1. OPTIONAL
-d / --domains=
Set the domain names that the user user can log in from. Defaults to
any. OPTIONAL.
Filename is required and should be the name of the file to store the
information in (usually "inituser" or "access").
Copyright (C) 1999, 2000 Digital Creations, Inc.
""" % argv[0]
try:
if len(argv) < 2:
raise "CommandLineError"
optlist, args = getopt.getopt(sys.argv[1:], short_options, long_options)
if len(args) != 1:
raise "CommandLineError"
access_file = open(args[0], 'w')
if len(optlist) > 0:
# Set the sane defaults
username = ''
encoding = 'SHA'
domains = ''
for opt in optlist:
if (opt[0] == '-u') or (opt[0] == '--username'):
username = opt[1]
elif (opt[0] == '-p') or (opt[0] == '--password'):
password = opt[1]
elif (opt[0] == '-e') or (opt[0] == '--encoding'):
encoding = opt[1]
elif (opt[0] == '-d') or (opt[0] == '--domains'):
domains = ":" + opt[1]
# Verify that we got what we need
if not username or not password:
raise "CommandLineError"
access_file.write(username + ':' +
generate_passwd(password, encoding) +
domains)
else:
# Run through the prompts
while 1:
username = raw_input("Username: ")
if username != '':
break
while 1:
password = getpass.getpass("Password: ")
verify = getpass.getpass("Verify password: ")
if verify == password:
break
else:
password = verify = ''
print "Password mismatch, please try again..."
while 1:
print """
Please choose a format from:
SHA - SHA-1 hashed password (default)
CRYPT - UNIX-style crypt password
CLEARTEXT - no protection
"""
encoding = raw_input("Encoding: ")
if encoding == '':
encoding = 'SHA'
break
if encoding.upper() in ['SHA', 'CRYPT', 'CLEARTEXT']:
break
domains = raw_input("Domain restrictions: ")
if domains: domains = ":" + domains
access_file.write(username + ":" +
generate_passwd(password, encoding) +
domains)
except "CommandLineError":
sys.stderr.write(usage)
sys.exit(1)
# If called from the command line
if __name__=='__main__': main(sys.argv)
##############################################################################
#
# Copyright (c) 2001 Zope Corporation and Contributors. All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.0 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE
#
##############################################################################
"""
ZServer as a NT service.
The serice starts up and monitors a ZServer process.
Features:
* When you start the service it starts ZServer
* When you stop the serivice it stops ZServer
* It monitors ZServer and restarts it if it exits abnormally
* If ZServer is shutdown from the web, the service stops.
* If ZServer cannot be restarted, the service stops.
Usage:
Installation
The ZServer service should be installed by the Zope Windows
installer. You can manually install, uninstall the service from
the commandline.
ZService.py [options] install|update|remove|start [...]
|stop|restart [...]|debug [...]
Options for 'install' and 'update' commands only:
--username domain\username : The Username the service is to run
under
--password password : The password for the username
--startup [manual|auto|disabled] : How the service starts,
default = manual
Commands
install : Installs the service
update : Updates the service, use this when you change
ZServer.py
remove : Removes the service
start : Starts the service, this can also be done from the
services control panel
stop : Stops the service, this can also be done from the
services control panel
restart : Restarts the service
debug : Runs the service in debug mode
You can view the usage options by running ZServer.py without any
arguments.
Note: you may have to register the Python service program first,
win32\pythonservice.exe /register
Starting Zope
Start Zope by clicking the 'start' button in the services control
panel. You can set Zope to automatically start at boot time by
choosing 'Auto' startup by clicking the 'statup' button.
Stopping Zope
Stop Zope by clicking the 'stop' button in the services control
panel. You can also stop Zope through the web by going to the
Zope control panel and by clicking 'Shutdown'.
Event logging
Zope events are logged to the NT application event log. Use the
event viewer to keep track of Zope events.
Registry Settings
You can change how the service starts ZServer by editing a registry
key.
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\
<Service Name>\Parameters\start
The value of this key is the command which the service uses to
start ZServer. For example:
"C:\Program Files\Zope\bin\python.exe"
"C:\Program Files\Zope\z2.py" -w 8888
TODO:
* Integrate it into the Windows installer.
* Add ZLOG logging in addition to event log logging.
* Make it easier to run multiple Zope services with one Zope install
This script does for NT the same sort of thing zdaemon.py does for UNIX.
Requires Python win32api extensions.
"""
__version__ = '$Revision: 1.2 $'[11:-2]
import sys, os, time, imp, getopt
import win32api
def magic_import(modulename, filename):
# by Mark Hammond
try:
# See if it does import first!
return __import__(modulename)
except ImportError:
pass
# win32 can find the DLL name.
h = win32api.LoadLibrary(filename)
found = win32api.GetModuleFileName(h)
# Python can load the module
mod = imp.load_module(modulename, None, found, ('.dll', 'rb',
imp.C_EXTENSION))
# inject it into the global module list.
sys.modules[modulename] = mod
# And finally inject it into the namespace.
globals()[modulename] = mod
win32api.FreeLibrary(h)
magic_import('pywintypes','pywintypes21.dll')
import win32serviceutil, win32service, win32event, win32process
# servicemanager comes as a builtin if we're running via PythonService.exe,
# but it's not available outside
try:
import servicemanager
except:
pass
class NTService(win32serviceutil.ServiceFramework):
# Some trickery to determine the service name. The WISE
# installer will write an svcname.txt to the ZServer dir
# that we can use to figure out our service name.
restart_min_time=5 # if ZServer restarts before this many
# seconds then we have a problem, and
# need to stop the service.
_svc_name_= 'Zope'
_svc_display_name_ = _svc_name_
def __init__(self, args):
win32serviceutil.ServiceFramework.__init__(self, args)
self.hWaitStop = win32event.CreateEvent(None, 0, 0, None)
def SvcDoRun(self):
self.start_zserver()
while 1:
rc=win32event.WaitForMultipleObjects(
(self.hWaitStop, self.hZServer), 0, win32event.INFINITE)
if rc - win32event.WAIT_OBJECT_0 == 0:
break
else:
self.restart_zserver()
self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING, 5000)
def SvcStop(self):
servicemanager.LogInfoMsg('Stopping Zope.')
try:
self.stop_zserver()
except:
pass
self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
win32event.SetEvent(self.hWaitStop)
def restart_zserver(self):
if time.time() - self.last_start_time < self.restart_min_time:
servicemanager.LogErrorMsg('Zope died and could not be restarted.')
self.SvcStop()
code=win32process.GetExitCodeProcess(self.hZServer)
if code == 0:
# Exited with a normal status code,
# assume that shutdown is intentional.
self.SvcStop()
else:
servicemanager.LogWarningMsg('Restarting Zope.')
self.start_zserver()
def start_zserver(self):
sc=self.get_start_command()
result=win32process.CreateProcess(None, sc,
None, None, 0, 0, None, None, win32process.STARTUPINFO())
self.hZServer=result[0]
self.last_start_time=time.time()
servicemanager.LogInfoMsg('Starting Zope.')
def stop_zserver(self):
try:
win32process.TerminateProcess(self.hZServer,0)
except:
pass
result=win32process.CreateProcess(None, self.get_stop_command(),
None, None, 0, 0, None, None, win32process.STARTUPINFO())
return result
def get_start_command(self):
return win32serviceutil.GetServiceCustomOption(self,'start', None)
def get_stop_command(self):
cmd = win32serviceutil.GetServiceCustomOption(self,'stop', None)
def set_start_command(value):
"sets the ZServer start command if the start command is not already set"
current=win32serviceutil.GetServiceCustomOption(NTService,
'start', None)
if current is None:
win32serviceutil.SetServiceCustomOption(NTService,'start',value)
def set_stop_command(value):
"sets the ZServer start command if the start command is not already set"
current=win32serviceutil.GetServiceCustomOption(NTService,
'stop', None)
if current is None:
win32serviceutil.SetServiceCustomOption(NTService,'stop',value)
if __name__=='__main__':
dn = os.path.dirname
zope_home = dn(dn(dn(dn(sys.argv[0]))))
win32serviceutil.HandleCommandLine(ZServerService)
if 'install' in args:
command='"%s" "%s"' % (sys.executable,
os.path.join(zope_home, 'bin', 'zope.py'))
set_start_command(command)
print "Setting Zope start command to:", command
##############################################################################
#
# Copyright (c) 2003 Zope Corporation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.0 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE.
#
##############################################################################
"""Tests of the Zope.Startup package."""
##############################################################################
#
# Copyright (c) 2003 Zope Corporation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.0 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE.
#
##############################################################################
"""Test that the Zope schema can be loaded."""
import unittest
import Zope.Startup
class StartupTestCase(unittest.TestCase):
def test_load_schema(self):
Zope.Startup.getSchema()
def test_suite():
return unittest.makeSuite(StartupTestCase)
if __name__ == "__main__":
unittest.main(defaultTest="test_suite")
<schema prefix="Zope.Startup.datatypes" handler="root_handler">
<!-- type definitions -->
<import package="zLOG"/>
<abstracttype name="server"/>
<sectiontype name="http-server"
implements="server">
<multikey name="port" attribute="ports" datatype="inet-address"/>
<key name="force-connection-close" datatype="boolean" default="off"/>
</sectiontype>
<sectiontype name="ftp-server"
implements="server">
<multikey name="port" attribute="ports" datatype="inet-address"/>
</sectiontype>
<sectiontype name="webdav-source-server"
implements="server">
<multikey name="port" attribute="ports" datatype="inet-address"/>
<key name="force-connection-close" datatype="boolean" default="off"/>
</sectiontype>
<sectiontype name="pcgi-server"
implements="server">
<key name="file" datatype="existing-file"/>
</sectiontype>
<sectiontype name="fcgi-server"
implements="server">
<key name="port" datatype="inet-address"/>
<key name="file" datatype="existing-dirpath"/>
</sectiontype>
<sectiontype name="monitor-server"
implements="server">
<multikey name="port" attribute="ports" datatype="inet-address"/>
</sectiontype>
<sectiontype name="icp-server"
implements="server">
<multikey name="port" attribute="ports" datatype="inet-address"/>
</sectiontype>
<sectiontype name="logger" datatype=".logger">
<description>
This "logger" type only applies to access and request ("trace")
logging; event logging is handled by the zLOG package, which
provides the loghandler type used here.
</description>
<key name="level" datatype="zLOG.datatypes.logging_level" default="info"/>
<multisection type="loghandler" attribute="handlers" name="*"
required="yes"/>
</sectiontype>
<!-- the types that follow will be replaced by an import from the
ZODB package -->
<abstracttype name="storage"/>
<sectiontype name="filestorage" datatype=".filestorage"
implements="storage">
<key name="path" required="yes"/>
<key name="create" datatype="boolean"/>
<key name="read-only" datatype="boolean"/>
<key name="stop"/>
<key name="quota" datatype="byte-size"/>
</sectiontype>
<sectiontype name="mappingstorage" datatype=".mappingstorage"
implements="storage">
<key name="name" default="Mapping Storage"/>
</sectiontype>
<sectiontype name="clientstorage" datatype=".clientstorage"
implements="storage">
<key name="addr" datatype="inet-address" required="yes"/>
<key name="storage" default="1"/>
<key name="cache-size" datatype="byte-size" default="20MB"/>
<key name="name" default=""/>
<key name="client"/>
<key name="debug" datatype="boolean"/>
<key name="var" datatype="existing-directory"/>
<key name="min-disconnect-poll" datatype="time-interval" default="5S"/>
<key name="max-disconnect-poll" datatype="time-interval" default="300S"/>
<key name="wait" datatype="boolean" default="on"/>
<key name="read-only" datatype="boolean" default="off"/>
<key name="read-only-fallback" datatype="boolean" default="off"/>
</sectiontype>
<sectiontype name="zodb" datatype=".database">
<multisection type="storage" name="*" attribute="storages"/>
<multikey name="mount-point" attribute="mount_points"
datatype=".mount_point"/>
<key name="db-class" default="ZODB.DB"/>
<key name="cache-size" datatype="integer" default="5000"/>
<key name="pool-size" datatype="integer" default="7"/>
<key name="cache-deactivate-after" datatype="time-interval" default="60S"/>
<key name="version-pool-size" datatype="integer" default="3"/>
<key name="version-cache-size" datatype="integer" default="100"/>
<key name="version-cache-deactivate-after" datatype="time-interval"
default="10S"/>
</sectiontype>
<!-- end of type definitions -->
<!-- schema begins -->
<key name="instance-home" datatype="existing-directory"
required="yes" handler="instance_home"/>
<key name="software-home" datatype="existing-directory"
required="yes" handler="software_home"/>
<key name="zope-home" datatype="existing-directory"
handler="zope_home"/>
<key name="client-home" datatype="existing-directory"
handler="client_home"/>
<key name="pid-filename" datatype="existing-dirpath"/>
<key name="lock-filename" datatype="existing-dirpath"/>
<key name="debug-mode" datatype="boolean" default="on"
handler="debug_mode"/>
<key name="effective-user"/>
<key name="enable-product-installation" datatype="boolean" default="on"
handler="enable_product_installation"/>
<key name="locale" datatype="locale" handler="locale"/>
<key name="zserver-threads" datatype="integer" default="4"/>
<key name="python-check-interval" datatype="integer" default="500">
<description>
Value passed to Python's sys.setcheckinterval() function. The
higher this is, the less frequently the Python interpreter
checks for keyboard interrupts. Setting this to higher values
also reduces the frequency of potential thread switches, which
can improve the performance of a busy server.
</description>
</key>
<key name="use-daemon-process" datatype=".use_daemon_process" default="on"
handler="use_daemon_process"/>
<key name="zserver-read-only-mode" datatype="boolean" default="off"
handler="zserver_read_only_mode"/>
<key name="structured-text-header-level" datatype="integer" default="3"
handler="structured_text_header_level"/>
<key name="maximum-security-manager-stack-size" datatype="integer"
default="100" handler="maximum_security_manager_stack_size"/>
<key name="publisher-profile-file" handler="publisher_profile_file"/>
<key name="webdav-source-user-agents"/>
<multikey name="cgi-environment-variable" datatype="key-value"
attribute="cgi_environment_variables"/>
<key name="dns-ip-address" datatype="ipaddr-or-hostname"/>
<key name="ip-address" datatype="ipaddr-or-hostname"/>
<key name="http-realm" default="Zope" handler="http_realm"/>
<key name="automatically-quote-dtml-request-data" datatype="boolean"
default="on" handler="automatically_quote_dtml_request_data"/>
<key name="security-policy-implementation"
datatype=".security_policy_implementation"
default="C" handler="security_policy_implementation"/>
<key name="skip-authentication-checking" datatype="boolean"
default="off" handler="skip_authentication_checking"/>
<key name="skip-ownership-checking" datatype="boolean"
default="off" handler="skip_ownership_checking"/>
<key name="maximum-number-of-session-objects" datatype="integer"
default="1000" handler="maximum_number_of_session_objects"/>
<key name="session-add-notify-script-path"
handler="session_add_notify_script_path"/>
<key name="session-delete-notify-script-path"
handler="session_add_notify_script_path"/>
<key name="session-timeout-minutes" datatype="integer"
default="20" handler="session_timeout_minutes"/>
<key name="suppress-all-access-rules" datatype="boolean"
default="off" handler="suppress_all_access_rules"/>
<key name="suppress-all-site-roots" datatype="boolean"
default="off" handler="suppress_all_site_roots"/>
<key name="database-quota-size" datatype="byte-size"
handler="database_quota_size"/>
<key name="read-only-database" datatype="boolean"
handler="read_only_database"/>
<key name="zeo-client-name"
handler="zeo_client_name"/>
<section type="eventlog" name="*" attribute="eventlog">
<description>
Describes the logging performed by zLOG.LOG() calls.
</description>
</section>
<section type="logger" name="access"/>
<section type="logger" name="trace"/>
<multisection type="server" name="*" attribute="servers"/>
<multisection type="zodb" name="*" attribute="databases"/>
<!-- schema ends -->
</schema>
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