#!/usr/bin/python2 -u # ------------------------------------------------------------------------ # THIS file used to be named alpina.py, from the node installer. Since then # the installer has been expanded to include all the functions of the boot # manager as well, hence the new name for this file. # ------------------------------------------------------------------------ # Copyright (c) 2003 Intel Corporation # All rights reserved. # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # * Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # * Redistributions in binary form must reproduce the above # copyright notice, this list of conditions and the following # disclaimer in the documentation and/or other materials provided # with the distribution. # * Neither the name of the Intel Corporation nor the names of its # contributors may be used to endorse or promote products derived # from this software without specific prior written permission. # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE INTEL OR # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR # PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF # LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS # SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # EXPORT LAWS: THIS LICENSE ADDS NO RESTRICTIONS TO THE EXPORT LAWS OF # YOUR JURISDICTION. It is licensee's responsibility to comply with any # export regulations applicable in licensee's jurisdiction. Under # CURRENT (May 2000) U.S. export regulations this software is eligible # for export from the U.S. and can be downloaded by or otherwise # exported or reexported worldwide EXCEPT to U.S. embargoed destinations # which include Cuba, Iraq, Libya, North Korea, Iran, Syria, Sudan, # Afghanistan and any other country to which the U.S. has embargoed # goods and services. import string import sys, os, traceback from time import gmtime, strftime from gzip import GzipFile from steps import * from Exceptions import * import notify_messages # all output is written to this file LOG_FILE= "/tmp/bm.log" CURL_PATH= "curl" UPLOAD_LOG_URL = "http://boot.planet-lab.org/alpina-logs/upload.php" # the new contents of PATH when the boot manager is running BIN_PATH= ('/usr/local/bin', '/usr/local/sbin', '/bin', '/sbin', '/usr/bin', '/usr/sbin', '/usr/local/planetlab/bin') class log: def __init__( self, OutputFilePath= None ): if OutputFilePath: try: self.OutputFilePath= OutputFilePath self.OutputFile= GzipFile( OutputFilePath, "w", 9 ) except: print( "Unable to open output file for log, continuing" ) self.OutputFile= None # for upload os.system( "ifconfig eth0 > /tmp/ifconfig" ) def LogEntry( self, str, inc_newline= 1, display_screen= 1 ): if self.OutputFile: self.OutputFile.write( str ) if display_screen: sys.stdout.write( str ) if inc_newline: if display_screen: sys.stdout.write( "\n" ) if self.OutputFile: self.OutputFile.write( "\n" ) if self.OutputFile: self.OutputFile.flush() def write( self, str ): """ make log behave like a writable file object (for traceback prints) """ self.LogEntry( str, 0, 1 ) def Upload( self ): """ upload the contents of the log to the server """ if self.OutputFile is not None: self.LogEntry( "Uploading logs to %s" % UPLOAD_LOG_URL ) self.OutputFile.close() self.OutputFile= None curl_cmd= "%s -s --connect-timeout 60 --max-time 600 " \ "--form log=@%s --form ifconfig=\