summaryrefslogtreecommitdiff
path: root/UpdateManager
diff options
context:
space:
mode:
authorMichael Vogt <michael.vogt@ubuntu.com>2006-02-24 20:43:26 +0100
committerMichael Vogt <michael.vogt@ubuntu.com>2006-02-24 20:43:26 +0100
commit15c800a63e03039f55f06540f49975d1663be25a (patch)
treea9b3109d694ad0933ae14a7e6f2e2c95e171f9ab /UpdateManager
parenta06fbb1dcf05c9b21dc30a011048e556e037a33d (diff)
downloadpython-apt-15c800a63e03039f55f06540f49975d1663be25a.tar.gz
* move the fetcher code out into UpdateManager/DistUpgradeFetcher.py
* add authentication
Diffstat (limited to 'UpdateManager')
-rw-r--r--UpdateManager/DistUpgradeFetcher.py197
-rw-r--r--UpdateManager/MetaRelease.py4
-rw-r--r--UpdateManager/UpdateManager.py118
3 files changed, 203 insertions, 116 deletions
diff --git a/UpdateManager/DistUpgradeFetcher.py b/UpdateManager/DistUpgradeFetcher.py
new file mode 100644
index 00000000..7af32865
--- /dev/null
+++ b/UpdateManager/DistUpgradeFetcher.py
@@ -0,0 +1,197 @@
+# DistUpgradeFetcher.py
+#
+# Copyright (c) 2006 Canonical
+#
+# Author: Michael Vogt <michael.vogt@ubuntu.com>
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License as
+# published by the Free Software Foundation; either version 2 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+# USA
+
+import pygtk
+pygtk.require('2.0')
+import gtk
+import os
+import apt_pkg
+import tarfile
+import urllib2
+import tempfile
+import GnuPGInterface
+from gettext import gettext as _
+
+import GtkProgress
+from ReleaseNotesViewer import ReleaseNotesViewer
+
+
+class DistUpgradeFetcher(object):
+
+ def __init__(self, parent, new_dist):
+ self.parent = parent
+ self.window_main = parent.window_main
+ self.new_dist = new_dist
+
+ def showReleaseNotes(self):
+ # FIXME: care about i18n! (append -$lang or something)
+ if self.new_dist.releaseNotesURI != None:
+ uri = self.new_dist.releaseNotesURI
+ self.window_main.set_sensitive(False)
+ self.window_main.window.set_cursor(gtk.gdk.Cursor(gtk.gdk.WATCH))
+ while gtk.events_pending():
+ gtk.main_iteration()
+
+ # download/display the release notes
+ # FIXME: add some progress reporting here
+ res = gtk.RESPONSE_CANCEL
+ try:
+ release_notes = urllib2.urlopen(uri)
+ notes = release_notes.read()
+ textview_release_notes = ReleaseNotesViewer(notes)
+ textview_release_notes.show()
+ self.parent.scrolled_notes.add(textview_release_notes)
+ self.parent.dialog_release_notes.set_transient_for(self.window_main)
+ res = self.parent.dialog_release_notes.run()
+ self.parent.dialog_release_notes.hide()
+ except urllib2.HTTPError:
+ primary = "<span weight=\"bold\" size=\"larger\">%s</span>" % \
+ _("Could not find the release notes")
+ secondary = _("The server may be overloaded. ")
+ dialog = gtk.MessageDialog(self.window_main,gtk.DIALOG_MODAL,
+ gtk.MESSAGE_ERROR,gtk.BUTTONS_CLOSE,"")
+ dialog.set_title("")
+ dialog.set_markup(primary);
+ dialog.format_secondary_text(secondary);
+ dialog.run()
+ dialog.destroy()
+ except IOError:
+ primary = "<span weight=\"bold\" size=\"larger\">%s</span>" % \
+ _("Could not download the release notes")
+ secondary = _("Please check your internet connection.")
+ dialog = gtk.MessageDialog(self.window_main,gtk.DIALOG_MODAL,
+ gtk.MESSAGE_ERROR,gtk.BUTTONS_CLOSE,"")
+ dialog.set_title("")
+ dialog.set_markup(primary);
+ dialog.format_secondary_text(secondary);
+ dialog.run()
+ dialog.destroy()
+ self.window_main.set_sensitive(True)
+ self.window_main.window.set_cursor(None)
+ # user clicked cancel
+ if res == gtk.RESPONSE_CANCEL:
+ return False
+ return True
+
+ def authenticate(self, file, signature, keyring='/etc/apt/trusted.gpg'):
+ """ authenticated a file against a given signature, if no keyring
+ is given use the apt default keyring
+ """
+ gpg = GnuPGInterface.GnuPG()
+ gpg.options.extra_args = ['--no-default-keyring',
+ '--keyring', keyring]
+ proc = gpg.run(['--verify', signature, file],
+ create_fhs=['status','logger','stderr'])
+ gpgres = proc.handles['status'].read()
+ if "VALIDSIG" in gpgres:
+ return True
+ return False
+
+ def extractDistUpgrader(self):
+ # extract the tarbal
+ print "extracting '%s'" % (self.tmpdir+"/"+os.path.basename(self.uri))
+ tar = tarfile.open(self.tmpdir+"/"+os.path.basename(self.uri),"r")
+ for tarinfo in tar:
+ tar.extract(tarinfo)
+ tar.close()
+ return True
+
+ def verifyDistUprader(self):
+ # FIXME: check a internal dependency file to make sure
+ # that the script will run correctly
+
+ # see if we have a script file that we can run
+ self.script = script = "%s/%s" % (self.tmpdir, self.new_dist.name)
+ if not os.path.exists(script):
+ # no script file found in extracted tarbal
+ primary = "<span weight=\"bold\" size=\"larger\">%s</span>" % \
+ _("Could not run the upgrade tool")
+ secondary = _("This is most likely a bug in the upgrade tool. "
+ "Please report it as a bug")
+ dialog = gtk.MessageDialog(self.window_main,gtk.DIALOG_MODAL,
+ gtk.MESSAGE_ERROR,gtk.BUTTONS_CLOSE,"")
+ dialog.set_title("")
+ dialog.set_markup(primary);
+ dialog.format_secondary_text(secondary);
+ dialog.run()
+ dialog.destroy()
+ return False
+ return True
+
+ def fetchDistUpgrader(self):
+ # now download the tarball with the upgrade script
+ self.tmpdir = tmpdir = tempfile.mkdtemp()
+ os.chdir(tmpdir)
+ if self.new_dist.upgradeTool != None:
+ progress = GtkProgress.GtkFetchProgress(self.parent,
+ _("Downloading the upgrade "
+ "tool"),
+ _("The upgrade tool will "
+ "guide you through the "
+ "upgrade process."))
+ fetcher = apt_pkg.GetAcquire(progress)
+ self.uri = self.new_dist.upgradeTool
+ af = apt_pkg.GetPkgAcqFile(fetcher,self.uri, descr=_("Upgrade tool"))
+ if fetcher.Run() != fetcher.ResultContinue:
+ return False
+ return True
+
+ def runDistUpgrader(self):
+ #print "runing: %s" % script
+ os.execv(script,[])
+
+ def cleanup(self):
+ # cleanup
+ os.chdir("..")
+ # del tmpdir
+ for root, dirs, files in os.walk(self.tmpdir, topdown=False):
+ for name in files:
+ os.remove(os.path.join(root, name))
+ #print "would remove file: %s" % os.path.join(root, name)
+ for name in dirs:
+ os.rmdir(os.path.join(root, name))
+ #print "would remove dir: %s" % os.path.join(root, name)
+ os.rmdir(self.tmpdir)
+
+ def run(self):
+ # see if we have release notes
+ if not self.showReleaseNotes():
+ return
+ if not self.fetchDistUpgrader():
+ print "Fetch failed"
+ return
+ if not self.extractDistUpgrader():
+ print "extract failed"
+ return
+ if not self.verifyDistUprader():
+ print "verify failed"
+ self.cleanup()
+ return
+ #if not self.authenticate(distUpgradeTar, distUpgradeSig):
+ # print "authenticate failed"
+ # self.cleanup()
+ # return
+ self.runDistUpgrader()
+
+
+if __name__ == "__main__":
+ d = DistUpgradeFetcher(None)
+ print d.authenticate('/tmp/Release','/tmp/Release.gpg')
diff --git a/UpdateManager/MetaRelease.py b/UpdateManager/MetaRelease.py
index 0bc8dc05..cd56970f 100644
--- a/UpdateManager/MetaRelease.py
+++ b/UpdateManager/MetaRelease.py
@@ -42,8 +42,8 @@ class Dist(object):
class MetaRelease(gobject.GObject):
# some constants
- METARELEASE_URI = "http://changelogs.ubuntu.com/meta-release"
- #METARELEASE_URI = "http://people.ubuntu.com/~mvo/dist-upgrader/meta-release-test.save"
+ #METARELEASE_URI = "http://changelogs.ubuntu.com/meta-release"
+ METARELEASE_URI = "http://people.ubuntu.com/~mvo/dist-upgrader/meta-release-test.save"
METARELEASE_FILE = "/var/lib/update-manager/meta-release"
__gsignals__ = {
diff --git a/UpdateManager/UpdateManager.py b/UpdateManager/UpdateManager.py
index 22c7a6a5..9aaad85d 100644
--- a/UpdateManager/UpdateManager.py
+++ b/UpdateManager/UpdateManager.py
@@ -1,6 +1,6 @@
# UpdateManager.py
#
-# Copyright (c) 2004,2005 Canonical
+# Copyright (c) 2004-2006 Canonical
# 2004 Michiel Sikkes
# 2005 Martin Willemoes Hansen
#
@@ -48,14 +48,12 @@ import time
import thread
import xml.sax.saxutils
-# dist-upgrade tool
-import tarfile
from gettext import gettext as _
from Common.utils import *
from Common.SimpleGladeApp import SimpleGladeApp
-from ReleaseNotesViewer import ReleaseNotesViewer
+from DistUpgradeFetcher import DistUpgradeFetcher
import GtkProgress
from MetaRelease import Dist, MetaRelease
@@ -629,116 +627,8 @@ class UpdateManager(SimpleGladeApp):
def on_button_dist_upgrade_clicked(self, button):
print "on_button_dist_upgrade_clicked"
-
- # see if we have release notes
-
- # FIXME: care about i18n! (append -$lang or something)
- if self.new_dist.releaseNotesURI != None:
- uri = self.new_dist.releaseNotesURI
- print uri
- self.window_main.set_sensitive(False)
- self.window_main.window.set_cursor(gtk.gdk.Cursor(gtk.gdk.WATCH))
- while gtk.events_pending():
- gtk.main_iteration()
-
- # download/display the release notes
- # FIXME: add some progress reporting here
- res = gtk.RESPONSE_CANCEL
- try:
- release_notes = urllib2.urlopen(uri)
- notes = release_notes.read()
- textview_release_notes = ReleaseNotesViewer(notes)
- textview_release_notes.show()
- self.scrolled_notes.add(textview_release_notes)
- self.dialog_release_notes.set_transient_for(self.window_main)
- res = self.dialog_release_notes.run()
- self.dialog_release_notes.hide()
- except urllib2.HTTPError:
- primary = "<span weight=\"bold\" size=\"larger\">%s</span>" % \
- _("Could not find the release notes")
- secondary = _("The server may be overloaded. ")
- dialog = gtk.MessageDialog(self.window_main,gtk.DIALOG_MODAL,
- gtk.MESSAGE_ERROR,gtk.BUTTONS_CLOSE,"")
- dialog.set_title("")
- dialog.set_markup(primary);
- dialog.format_secondary_text(secondary);
- dialog.run()
- dialog.destroy()
- except IOError:
- primary = "<span weight=\"bold\" size=\"larger\">%s</span>" % \
- _("Could not download the release notes")
- secondary = _("Please check your internet connection.")
- dialog = gtk.MessageDialog(self.window_main,gtk.DIALOG_MODAL,
- gtk.MESSAGE_ERROR,gtk.BUTTONS_CLOSE,"")
- dialog.set_title("")
- dialog.set_markup(primary);
- dialog.format_secondary_text(secondary);
- dialog.run()
- dialog.destroy()
- self.window_main.set_sensitive(True)
- self.window_main.window.set_cursor(None)
- # user clicked cancel
- if res == gtk.RESPONSE_CANCEL:
- return
-
- # now download the tarball with the upgrade script
- tmpdir = tempfile.mkdtemp()
- os.chdir(tmpdir)
- if self.new_dist.upgradeTool != None:
- progress = GtkProgress.GtkFetchProgress(self,
- _("Downloading the upgrade "
- "tool"),
- _("The upgrade tool will "
- "guide you through the "
- "upgrade process."))
- fetcher = apt_pkg.GetAcquire(progress)
- uri = self.new_dist.upgradeTool
- #print "Downloading %s to %s" % (uri, tmpdir)
- af = apt_pkg.GetPkgAcqFile(fetcher,uri,
- descr=_("Upgrade tool"))
- fetcher.Run()
- #print "Done downloading"
-
- # extract the tarbal
- print "extracting"
- tar = tarfile.open(tmpdir+"/"+os.path.basename(uri),"r")
- for tarinfo in tar:
- tar.extract(tarinfo)
- tar.close()
-
- # FIXME: check a internal dependency file to make sure
- # that the script will run correctly
-
- # see if we have a script file that we can run
- script = "%s/%s" % (tmpdir, self.new_dist.name)
- if not os.path.exists(script):
- # no script file found in extracted tarbal
- primary = "<span weight=\"bold\" size=\"larger\">%s</span>" % \
- _("Could not run the upgrade tool")
- secondary = _("This is most likely a bug in the upgrade tool. "
- "Please report it as a bug")
- dialog = gtk.MessageDialog(self.window_main,gtk.DIALOG_MODAL,
- gtk.MESSAGE_ERROR,gtk.BUTTONS_CLOSE,"")
- dialog.set_title("")
- dialog.set_markup(primary);
- dialog.format_secondary_text(secondary);
- dialog.run()
- dialog.destroy()
- else:
- #print "runing: %s" % script
- os.execv(script,[])
-
- # cleanup
- os.chdir("..")
- # del tmpdir
- for root, dirs, files in os.walk(tmpdir, topdown=False):
- for name in files:
- os.remove(os.path.join(root, name))
- #print "would remove file: %s" % os.path.join(root, name)
- for name in dirs:
- os.rmdir(os.path.join(root, name))
- #print "would remove dir: %s" % os.path.join(root, name)
- os.rmdir(tmpdir)
+ fetcher = DistUpgradeFetcher(self, self.new_dist)
+ fetcher.run()
def new_dist_available(self, meta_release, upgradable_to):
print "new_dist_available: %s" % upgradable_to.name