blob: 36005d5dec5d803c6137dac21c63e5387cd6d245 [file] [log] [blame]
Norman James42c1be82015-10-22 14:34:26 -05001#!/usr/bin/python -u
Norman Jamesf066e872015-10-07 15:29:51 -05002
3import sys
4import gobject
5import dbus
6import dbus.service
7import dbus.mainloop.glib
Norman James0b73e7d2016-01-19 14:03:50 -06008import subprocess
Norman James408920d2015-10-08 07:02:45 -05009import Openbmc
10if (len(sys.argv) < 2):
11 print "Usage: download_manager.py [system name]"
12 exit(1)
13System = __import__(sys.argv[1])
Norman Jamesf066e872015-10-07 15:29:51 -050014
15
16DBUS_NAME = 'org.openbmc.managers.Download'
17OBJ_NAME = '/org/openbmc/managers/Download'
18TFTP_PORT = 69
Norman Jamesf066e872015-10-07 15:29:51 -050019
20class DownloadManagerObject(dbus.service.Object):
21 def __init__(self,bus,name):
22 dbus.service.Object.__init__(self,bus,name)
Norman Jamesf066e872015-10-07 15:29:51 -050023 bus.add_signal_receiver(self.DownloadHandler,
Norman James8585b212016-01-29 08:08:30 -060024 dbus_interface = "org.openbmc.Flash",
25 signal_name = "Download", path_keyword = "path")
26 bus.add_signal_receiver(self.TftpDownloadHandler,
27 signal_name = "TftpDownload", path_keyword = "path")
28
Norman Jamesf066e872015-10-07 15:29:51 -050029
Norman James18998182015-10-11 21:54:53 -050030 @dbus.service.signal(DBUS_NAME,signature='ss')
31 def DownloadComplete(self,outfile,filename):
Norman Jamesf066e872015-10-07 15:29:51 -050032 print "Download Complete: "+outfile
33 return outfile
34
Norman James18998182015-10-11 21:54:53 -050035 @dbus.service.signal(DBUS_NAME,signature='s')
36 def DownloadError(self,filename):
Norman Jamesf066e872015-10-07 15:29:51 -050037 pass
38
Norman James8585b212016-01-29 08:08:30 -060039 def TftpDownloadHandler(self,ip,filename,path = None):
40 try:
41 filename = str(filename)
42 print "Downloading: "+filename+" from "+ip
43 outfile = System.FLASH_DOWNLOAD_PATH+"/"+filename
44 rc = subprocess.call(["tftp", "-l",outfile,"-r",filename,"-g",ip])
45 if (rc == 0):
46 self.DownloadComplete(outfile,filename)
47 else:
48 self.DownloadError(filename)
49
50
51 except Exception as e:
52 print "ERROR DownloadManager: "+str(e)
53 self.DownloadError(filename)
54
55
56 ## TODO: this needs to be deprecated. Shouldn't call flash interface from here
Norman James166acf42015-10-22 07:11:51 -050057 def DownloadHandler(self,url,filename,path = None):
Norman Jamesf066e872015-10-07 15:29:51 -050058 try:
59 filename = str(filename)
Norman Jamesf066e872015-10-07 15:29:51 -050060 print "Downloading: "+filename+" from "+url
Norman James408920d2015-10-08 07:02:45 -050061 outfile = System.FLASH_DOWNLOAD_PATH+"/"+filename
Norman James8af7d4a2016-01-06 14:09:08 -060062 subprocess.call(["tftp", "-l",outfile,"-r",filename,"-g",url])
Norman James166acf42015-10-22 07:11:51 -050063 obj = bus.get_object("org.openbmc.control.Flash",path)
64 intf = dbus.Interface(obj,"org.openbmc.Flash")
65 intf.update(outfile)
Norman James8af7d4a2016-01-06 14:09:08 -060066
Norman Jamesf066e872015-10-07 15:29:51 -050067 except Exception as e:
68 print "ERROR DownloadManager: "+str(e)
Norman James166acf42015-10-22 07:11:51 -050069 obj = bus.get_object("org.openbmc.control.Flash",path)
70 intf = dbus.Interface(obj,"org.openbmc.Flash")
71 intf.error("Download Error: "+filename)
Norman Jamesf066e872015-10-07 15:29:51 -050072
73
74if __name__ == '__main__':
75 dbus.mainloop.glib.DBusGMainLoop(set_as_default=True)
Norman James5e792e32015-10-07 17:36:17 -050076 bus = Openbmc.getDBus()
Norman Jamesf066e872015-10-07 15:29:51 -050077 name = dbus.service.BusName(DBUS_NAME, bus)
78 obj = DownloadManagerObject(bus, OBJ_NAME)
79 mainloop = gobject.MainLoop()
80
81 print "Running Download Manager"
82 mainloop.run()
83