mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-30 19:43:47 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python
 | |
| # Copyright (C) 2012 Zulip, Inc.
 | |
| #
 | |
| # Permission is hereby granted, free of charge, to any person
 | |
| # obtaining a copy of this software and associated documentation files
 | |
| # (the "Software"), to deal in the Software without restriction,
 | |
| # including without limitation the rights to use, copy, modify, merge,
 | |
| # publish, distribute, sublicense, and/or sell copies of the Software,
 | |
| # and to permit persons to whom the Software is furnished to do so,
 | |
| # subject to the following conditions:
 | |
| #
 | |
| # The above copyright notice and this permission notice shall be
 | |
| # included in all copies or substantial portions of the Software.
 | |
| #
 | |
| # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 | |
| # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 | |
| # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 | |
| # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
 | |
| # BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
 | |
| # ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
 | |
| # CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 | |
| # SOFTWARE.
 | |
| 
 | |
| import sys
 | |
| import subprocess
 | |
| import os
 | |
| import traceback
 | |
| import signal
 | |
| 
 | |
| from zephyr_mirror_backend import parse_args
 | |
| 
 | |
| def die(signal, frame):
 | |
|     # We actually want to exit, so run os._exit (so as not to be caught and restarted)
 | |
|     os._exit(1)
 | |
| 
 | |
| signal.signal(signal.SIGINT, die)
 | |
| 
 | |
| (options, args) = parse_args()
 | |
| 
 | |
| sys.path[:0] = [os.path.join(options.root_path, 'api')]
 | |
| from zulip import RandomExponentialBackoff
 | |
| 
 | |
| args = [os.path.join(options.root_path, "user_root", "zephyr_mirror_backend.py")]
 | |
| args.extend(sys.argv[1:])
 | |
| 
 | |
| if options.sync_subscriptions:
 | |
|     subprocess.call(args)
 | |
|     sys.exit(0)
 | |
| 
 | |
| if options.forward_class_messages and not options.noshard:
 | |
|     sys.path.append("/home/zulip/zulip")
 | |
|     if options.on_startup_command is not None:
 | |
|         subprocess.call([options.on_startup_command])
 | |
|     from zerver.lib.parallel import run_parallel
 | |
|     print "Starting parallel zephyr class mirroring bot"
 | |
|     jobs = list("0123456789abcdef")
 | |
|     def run_job(shard):
 | |
|         subprocess.call(args + ["--shard=%s" % (shard,)])
 | |
|         return 0
 | |
|     for (status, job) in run_parallel(run_job, jobs, threads=16):
 | |
|         print "A mirroring shard died!"
 | |
|         pass
 | |
|     sys.exit(0)
 | |
| 
 | |
| backoff = RandomExponentialBackoff(timeout_success_equivalent=300)
 | |
| while backoff.keep_going():
 | |
|     print "Starting zephyr mirroring bot"
 | |
|     try:
 | |
|         subprocess.call(args)
 | |
|     except:
 | |
|         traceback.print_exc()
 | |
|     backoff.fail()
 | |
| 
 | |
| print ""
 | |
| print ""
 | |
| print "ERROR: The Zephyr mirroring bot is unable to continue mirroring Zephyrs."
 | |
| print "This is often caused by failing to maintain unexpired Kerberos tickets"
 | |
| print "or AFS tokens.  See https://zulip.com/zephyr for documentation on how to"
 | |
| print "maintain unexpired Kerberos tickets and AFS tokens."
 | |
| print ""
 | |
| sys.exit(1)
 |