summaryrefslogtreecommitdiffstats
path: root/mdkapplet-enterprise-update-helper
diff options
context:
space:
mode:
authorThierry Vignaud <tv@mandriva.org>2009-06-03 13:36:48 +0000
committerThierry Vignaud <tv@mandriva.org>2009-06-03 13:36:48 +0000
commit1fae4dc9acb44bbbc144b8dc966dbf1c436b0b1f (patch)
tree625ef69e50b00a0739fed20a36620b98e8e2e08d /mdkapplet-enterprise-update-helper
parent7a487499fb4b15c3bc3aa72264f8b68335ad1639 (diff)
downloadmgaonline-1fae4dc9acb44bbbc144b8dc966dbf1c436b0b1f.tar
mgaonline-1fae4dc9acb44bbbc144b8dc966dbf1c436b0b1f.tar.gz
mgaonline-1fae4dc9acb44bbbc144b8dc966dbf1c436b0b1f.tar.bz2
mgaonline-1fae4dc9acb44bbbc144b8dc966dbf1c436b0b1f.tar.xz
mgaonline-1fae4dc9acb44bbbc144b8dc966dbf1c436b0b1f.zip
add a wrapper in order to add update media from authenticated server on MES5
Diffstat (limited to 'mdkapplet-enterprise-update-helper')
-rwxr-xr-xmdkapplet-enterprise-update-helper171
1 files changed, 171 insertions, 0 deletions
diff --git a/mdkapplet-enterprise-update-helper b/mdkapplet-enterprise-update-helper
new file mode 100755
index 00000000..66731f29
--- /dev/null
+++ b/mdkapplet-enterprise-update-helper
@@ -0,0 +1,171 @@
+#!/usr/bin/perl
+################################################################################
+# Mandriva Online #
+# #
+# Copyright (C) 2009 Mandriva #
+# #
+# Thierry Vignaud <tvignaud at mandriva dot com> #
+# #
+# This program is free software; you can redistribute it and/or modify #
+# it under the terms of the GNU General Public License Version 2 as #
+# published by the Free Software Foundation. #
+# #
+# 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. #
+################################################################################
+
+use strict;
+use lib qw(/usr/lib/libDrakX /usr/lib/libDrakX/drakfirsttime);
+use standalone; # for explanations
+use common;
+use run_program;
+use feature 'state';
+
+BEGIN { unshift @::textdomains, 'mdkonline' }
+
+use mygtk2 qw(gtknew); #- do not import gtkadd which conflicts with ugtk2 version
+use ugtk2 qw(:all);
+use urpm::cfg;
+use mdkonline;
+use mdkapplet_gui;
+use interactive;
+
+use XML::Simple;
+use URI::Escape;
+use LWP::UserAgent;
+use HTTP::Request::Common;
+use HTTP::Request;
+
+my $version;
+foreach my $opt (@ARGV) {
+ if ($opt =~ /--(rpm-root|urpmi-root)=(.*)/) {
+ $::rpmdrake_options{$1}[0] = $2;
+ } else {
+ $version = $opt;
+ }
+}
+$version or die "usage: mdkapplet-restricted-helper <distrib_version>\n";
+
+get_restricted_authentication();
+
+ugtk2::exit(0);
+
+
+sub get_restricted_authentication() {
+ my $w = ugtk2->new(N("Adding an additional package medium"), width => $width + 20);
+ my ($password_w, $email_w, $password);
+
+ $password_w = gtknew('Entry');
+ $password_w->set_visibility(0);
+ $w->{real_window}->signal_connect(destroy => sub { $password = $password_w->get_text });
+ require interactive::gtk;
+
+ my $res =
+ fill_n_run_portable_dialog(
+ $w,
+ [
+ get_banner(N("Adding an additional package medium")),
+ gtknew('Label_Left', text => N("Please fill in your account ID to add an additional package medium"),
+ @common),
+ gtknew('HButtonBox', layout => 'start', children_tight => [
+ interactive::gtk::add_padding(
+ new_link_button('https://my.mandriva.com/info', N("More information on your user account")))
+ ]),
+ gtknew('Table', col_spacings => 5, row_spacings => 5, children => [
+ [ N("Your email"), $email_w = gtknew('Entry') ],
+ [ N("Your password"), $password_w ],
+ ]),
+ gtknew('HButtonBox', layout => 'start', children_tight => [
+ interactive::gtk::add_padding(
+ new_link_button('https://my.mandriva.com/reset/password/', N("Forgotten password")))
+ ]),
+ create_okcancel($w, N("Next"), N("Cancel")),
+ ]);
+
+ my $email = $email_w->get_text;
+ if ($res) {
+ if ($email && $password) {
+ add_enterprise_update_medium($email, $password);
+ } else {
+ interactive->vnew->ask_warn(N("Error"), N("Password and email cannot be empty."));
+ goto &get_restricted_authentication;
+ }
+ } else {
+ ugtk2::exit(0);
+ }
+}
+
+sub get_from {
+ my ($link, $header) = @_;
+
+ my $ua = LWP::UserAgent->new;
+ $ua->agent("mdkapplet (mdkonline-$mdkonlin::version)");
+ $ua->env_proxy;
+
+ my $response = $ua->request(POST $link, $header);
+ $response;
+}
+
+my $error;
+sub add_enterprise_update_medium {
+ my ($email, $password) = @_;
+
+ my $res = get_from("https://my.mandriva.com/rest/authenticate", [ 'username', $email, 'password', $password,
+ 'return', 'userdata' ]);
+ my $ref = XML::Simple->new->XMLin($res->{_content});
+
+ if ($ref->{code} != 0) {
+ my $in = interactive->vnew;
+ $in->ask_warn(N("Error"), N("An error occurred") . "\n" . $ref->{message});
+ goto &get_restricted_authentication;
+ } elsif ($ref->{data}{'can-access-restricted-repositories'} ne 'YES') {
+ no_rigths_dialog();
+ } else {
+ $error = 0;
+ my $arch = urpm::cfg::get_arch();
+ actually_add_enterprise_update_medium($ref, $password, $arch)
+ or adding_media_failed();
+ if (!$error) {
+ #interactive->vnew->ask_okcancel(N("Error"), N("An error occurred while adding medium"));
+ my $w = ugtk2->new(N("Successfully added media %s.", 'Restricted'), grab => 1);
+ $w->_ask_okcancel(N("Successfully added media %s.", 'Restricted'), N("Ok"), undef);
+ ugtk2::main($w);
+ }
+ }
+}
+
+sub no_rigths_dialog() {
+ my $w = ugtk2->new(N("Adding an additional package medium"), width => $width + 20);
+
+ fill_n_run_portable_dialog(
+ $w,
+ [
+ get_banner(N("Adding an additional package medium")),
+ gtknew('Label_Left', text => N("Your Mandriva account does not have Powerpack download subscription enabled."),
+ @common),
+ gtknew('HButtonBox', layout => 'start', children_tight => [
+ interactive::gtk::add_padding(
+ new_link_button('https://my.mandriva.com/powerpack/', N("More Information")))
+ ]),
+ create_okcancel($w, N("Close"), undef),
+ ]);
+}
+
+sub adding_media_failed {
+ $error = 1;
+ interactive->vnew->ask_warn(N("Error"), N("An error occurred while adding medium"));
+ goto &get_restricted_authentication;
+}
+
+sub actually_add_enterprise_update_medium {
+ my ($ref, $password, $arch) = @_;
+ my @options = ({ sensitive_arguments => 1 }, 'urpmi.addmedia', '--xml-info', 'always');
+ my $uri = "https://" . uri_escape($ref->{data}{email}) . ":$password\@download.mandriva.com/$version/rpms/$arch/";
+ run_program::raw(@options, '--update', '--distrib', $uri);
+}