blob: ba502da3dc6c6e7fc5f149e619dcefac6844d9c6 [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
Brad Bishop84e73b52016-05-12 15:57:52 -04009from obmc.dbuslib.bindings import get_dbus
10
Norman James408920d2015-10-08 07:02:45 -050011if (len(sys.argv) < 2):
12 print "Usage: download_manager.py [system name]"
13 exit(1)
14System = __import__(sys.argv[1])
Norman Jamesf066e872015-10-07 15:29:51 -050015
16
17DBUS_NAME = 'org.openbmc.managers.Download'
18OBJ_NAME = '/org/openbmc/managers/Download'
19TFTP_PORT = 69
Norman Jamesf066e872015-10-07 15:29:51 -050020
21class DownloadManagerObject(dbus.service.Object):
22 def __init__(self,bus,name):
23 dbus.service.Object.__init__(self,bus,name)
Norman Jamesf066e872015-10-07 15:29:51 -050024 bus.add_signal_receiver(self.DownloadHandler,
Norman James8585b212016-01-29 08:08:30 -060025 dbus_interface = "org.openbmc.Flash",
26 signal_name = "Download", path_keyword = "path")
27 bus.add_signal_receiver(self.TftpDownloadHandler,
28 signal_name = "TftpDownload", path_keyword = "path")
29
Norman Jamesf066e872015-10-07 15:29:51 -050030
Norman James18998182015-10-11 21:54:53 -050031 @dbus.service.signal(DBUS_NAME,signature='ss')
32 def DownloadComplete(self,outfile,filename):
Norman Jamesf066e872015-10-07 15:29:51 -050033 print "Download Complete: "+outfile
34 return outfile
35
Norman James18998182015-10-11 21:54:53 -050036 @dbus.service.signal(DBUS_NAME,signature='s')
37 def DownloadError(self,filename):
Norman Jamesf066e872015-10-07 15:29:51 -050038 pass
39
Norman James8585b212016-01-29 08:08:30 -060040 def TftpDownloadHandler(self,ip,filename,path = None):
41 try:
42 filename = str(filename)
43 print "Downloading: "+filename+" from "+ip
44 outfile = System.FLASH_DOWNLOAD_PATH+"/"+filename
45 rc = subprocess.call(["tftp", "-l",outfile,"-r",filename,"-g",ip])
46 if (rc == 0):
47 self.DownloadComplete(outfile,filename)
48 else:
49 self.DownloadError(filename)
50
51
52 except Exception as e:
53 print "ERROR DownloadManager: "+str(e)
54 self.DownloadError(filename)
55
56
57 ## TODO: this needs to be deprecated. Shouldn't call flash interface from here
Norman James166acf42015-10-22 07:11:51 -050058 def DownloadHandler(self,url,filename,path = None):
Norman Jamesf066e872015-10-07 15:29:51 -050059 try:
60 filename = str(filename)
Norman Jamesf066e872015-10-07 15:29:51 -050061 print "Downloading: "+filename+" from "+url
Norman James408920d2015-10-08 07:02:45 -050062 outfile = System.FLASH_DOWNLOAD_PATH+"/"+filename
Norman James8af7d4a2016-01-06 14:09:08 -060063 subprocess.call(["tftp", "-l",outfile,"-r",filename,"-g",url])
Norman James166acf42015-10-22 07:11:51 -050064 obj = bus.get_object("org.openbmc.control.Flash",path)
65 intf = dbus.Interface(obj,"org.openbmc.Flash")
66 intf.update(outfile)
Norman James8af7d4a2016-01-06 14:09:08 -060067
Norman Jamesf066e872015-10-07 15:29:51 -050068 except Exception as e:
69 print "ERROR DownloadManager: "+str(e)
Norman James166acf42015-10-22 07:11:51 -050070 obj = bus.get_object("org.openbmc.control.Flash",path)
71 intf = dbus.Interface(obj,"org.openbmc.Flash")
72 intf.error("Download Error: "+filename)
Norman Jamesf066e872015-10-07 15:29:51 -050073
74
75if __name__ == '__main__':
76 dbus.mainloop.glib.DBusGMainLoop(set_as_default=True)
Brad Bishop84e73b52016-05-12 15:57:52 -040077 bus = get_dbus()
Norman Jamesf066e872015-10-07 15:29:51 -050078 name = dbus.service.BusName(DBUS_NAME, bus)
79 obj = DownloadManagerObject(bus, OBJ_NAME)
80 mainloop = gobject.MainLoop()
81
82 print "Running Download Manager"
83 mainloop.run()
84