X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=tools%2Fuagen.pl;h=ad463d2d8b30e114e2d091303e9baca11eba22a5;hp=1332fe302cb71b1ebfa54665741647ef3aa34ec1;hb=0b547be62a13f8febeb51318addc7bcb767a200a;hpb=fb97558b6a14140b626c13383ea069df1e8571a2 diff --git a/tools/uagen.pl b/tools/uagen.pl index 1332fe30..ad463d2d 100755 --- a/tools/uagen.pl +++ b/tools/uagen.pl @@ -1,24 +1,23 @@ #!/usr/bin/perl ############################################################################################## -# uagen (http://www.fabiankeil.de/sourcecode/uagen/) -# -# $Id: uagen.pl,v 1.14 2011/06/29 18:35:53 fabiankeil Exp $ +# uagen (https://www.fabiankeil.de/sourcecode/uagen/) # # Generates a pseudo-random Firefox user agent and writes it into a Privoxy action file # and optionally into a Mozilla prefs file. For documentation see 'perldoc uagen(.pl)'. # -# Examples (created with v1.0): +# Examples (created with v1.2.2): # -# Mozilla/5.0 (X11; U; NetBSD i386; en-US; rv:1.8.0.2) Gecko/20060421 Firefox/1.5.0.2 -# Mozilla/5.0 (Macintosh; U; Intel Mac OS X; en-CA; rv:1.8.0.2) Gecko/20060425 Firefox/1.5.0.2 -# Mozilla/5.0 (X11; U; SunOS i86pc; no-NO; rv:1.8.0.2) Gecko/20060420 Firefox/1.5.0.2 -# Mozilla/5.0 (X11; U; Linux x86_64; de-AT; rv:1.8.0.2) Gecko/20060422 Firefox/1.5.0.2 -# Mozilla/5.0 (X11; U; NetBSD i386; en-US; rv:1.8.0.2) Gecko/20060415 Firefox/1.5.0.2 -# Mozilla/5.0 (X11; U; OpenBSD sparc64; pl-PL; rv:1.8.0.2) Gecko/20060429 Firefox/1.5.0.2 -# Mozilla/5.0 (X11; U; Linux i686; en-CA; rv:1.8.0.2) Gecko/20060413 Firefox/1.5.0.2 +# Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Firefox/78.0 +# Mozilla/5.0 (Macintosh; PPC Mac OS X; rv:78.0) Gecko/20100101 Firefox/78.0 +# Mozilla/5.0 (X11; NetBSD i386; rv:78.0) Gecko/20100101 Firefox/78.0 +# Mozilla/5.0 (X11; OpenBSD alpha; rv:78.0) Gecko/20100101 Firefox/78.0 +# Mozilla/5.0 (X11; FreeBSD amd64; rv:78.0) Gecko/20100101 Firefox/78.0 +# Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Firefox/78.0 +# Mozilla/5.0 (X11; ElectroBSD amd64; rv:78.0) Gecko/20100101 Firefox/78.0 +# Mozilla/5.0 (X11; FreeBSD i386; rv:78.0) Gecko/20100101 Firefox/78.0 # -# Copyright (c) 2006-2011 Fabian Keil +# Copyright (c) 2006-2021 Fabian Keil # # Permission to use, copy, modify, and distribute this software for any # purpose with or without fee is hereby granted, provided that the above @@ -40,7 +39,7 @@ use Getopt::Long; use constant { - UAGEN_VERSION => 'uagen 1.1', + UAGEN_VERSION => 'uagen 1.2.4', UAGEN_LOGFILE => '/var/log/uagen.log', ACTION_FILE => '/etc/privoxy/user-agent.action', @@ -52,7 +51,7 @@ use constant { SLEEPING_TIME => 5, # As of Firefox 4, the "Gecko token" has been frozen - # http://hacks.mozilla.org/2010/09/final-user-agent-string-for-firefox-4/ + # https://hacks.mozilla.org/2010/09/final-user-agent-string-for-firefox-4/ RANDOMIZE_RELEASE_DATE => 0, # These variables belong together. If you only change one of them, the generated @@ -60,8 +59,8 @@ use constant { # are too lazy to check, but want to change them anyway, take the values you # see in the "Help/About Mozilla Firefox" menu. - BROWSER_VERSION => "5.0", - BROWSER_REVISION => '5.0', + BROWSER_VERSION => "91.0", + BROWSER_REVISION => '91.0', BROWSER_RELEASE_DATE => '20100101', }; @@ -72,7 +71,7 @@ use constant LANGUAGES => qw( ####################################################################################### sub generate_creation_time($) { - my $release_date = $_ = shift; + my $release_date = shift; my ($rel_year, $rel_mon, $rel_day); my ($c_day, $c_mon, $c_year); @@ -81,41 +80,39 @@ sub generate_creation_time($) { $mon += 1; $year += 1900; - unless ( m/\d{6}/ ) { + unless ($release_date =~ m/\d{6}/) { log_error("Invalid release date format: $release_date. Using " . BROWSER_RELEASE_DATE . " instead."); $release_date = BROWSER_RELEASE_DATE; } - $rel_year = substr $release_date, 0, 4; - $rel_mon = substr $release_date, 4, 2; - $rel_day = substr $release_date, 6, 2; + $rel_year = substr($release_date, 0, 4); + $rel_mon = substr($release_date, 4, 2); + $rel_day = substr($release_date, 6, 2); #1, 2, 3, Check. - die "release year in the future" if ( $year < $rel_year ); + die "release year in the future" if ($year < $rel_year); die "release month in the future" - if ( ( $year == $rel_year ) and ( $mon < $rel_mon ) ); + if (($year == $rel_year) and ($mon < $rel_mon)); die "release day in the future" - if ( ( $year == $rel_year ) - and ( $mon == $rel_mon ) - and ( $mday < $rel_day ) ); + if (($year == $rel_year) and ($mon == $rel_mon) and ($mday < $rel_day)); my @c_time = (0, 0, 0, $rel_day, $rel_mon - 1, $rel_year - 1900, 0, 0, 0); - my $c_seconds = &timelocal( @c_time ); + my $c_seconds = timelocal(@c_time); $c_seconds = $now - (int rand ($now - $c_seconds)); - @c_time = localtime $c_seconds; + @c_time = localtime($c_seconds); (undef, undef, undef, $c_day, $c_mon, $c_year, undef, undef, undef) = @c_time; $c_mon += 1; $c_year += 1900; #3, 2, 1, Test. - die "Compilation year in the future" if ( $year < $c_year ); + die "Compilation year in the future" if ($year < $c_year); die "Compilation month in the future" - if ( ( $year == $c_year ) and ( $mon < $c_mon ) ); + if (($year == $c_year) and ($mon < $c_mon)); die "Compilation day in the future" - if ( ( $year == $c_year ) and ( $mon == $c_mon ) and ( $mday < $c_day ) ); + if (($year == $c_year) and ($mon == $c_mon) and ($mday < $c_day)); - return sprintf "%.2i%.2i%.2i", $c_year, $c_mon, $c_day; + return sprintf("%.2i%.2i%.2i", $c_year, $c_mon, $c_day); } sub generate_language_settings() { @@ -132,16 +129,22 @@ sub generate_language_settings() { sub generate_platform_and_os() { my %os_data = ( + ElectroBSD => { + karma => 1, + platform => 'X11', + architectures => [ 'i386', 'amd64' ], + order_is_inversed => 0, + }, FreeBSD => { karma => 1, platform => 'X11', - architectures => [ 'i386', 'amd64', 'sparc64', 'alpha' ], + architectures => [ 'i386', 'amd64' ], order_is_inversed => 0, }, OpenBSD => { karma => 1, platform => 'X11', - architectures => [ 'i386', 'amd64', 'sparc64', 'alpha' ], + architectures => [ 'arm64', 'i386', 'amd64', 'sparc64', 'alpha' ], order_is_inversed => 0, }, NetBSD => { @@ -206,7 +209,6 @@ sub generate_firefox_user_agent() { our $randomize_release_date; my $mozillaversion = '5.0'; - my $security = "U"; my $creation_time = $randomize_release_date ? generate_creation_time($browser_release_date) : $browser_release_date; @@ -214,8 +216,8 @@ sub generate_firefox_user_agent() { my ( $platform, $os_or_cpu ) = generate_platform_and_os; my $firefox_user_agent = - sprintf "Mozilla/%s (%s; %s; %s; %s; rv:%s) Gecko/%s Firefox/%s", - $mozillaversion, $platform, $security, $os_or_cpu, $locale, $browser_revision, + sprintf "Mozilla/%s (%s; %s; rv:%s) Gecko/%s Firefox/%s", + $mozillaversion, $platform, $os_or_cpu, $browser_revision, $creation_time, $browser_version; return $accept_language, $firefox_user_agent; @@ -237,7 +239,7 @@ sub log_to_file($) { return if $no_logging; - open(my $log_fd, ">>" . $logfile) || die "Writing " . $logfile . " failed"; + open(my $log_fd, ">>", $logfile) || die "Writing " . $logfile . " failed"; printf $log_fd UAGEN_VERSION . " ($logtime) $message\n"; close($log_fd); } @@ -279,7 +281,7 @@ sub write_action_file() { $action_file_content .= sprintf " +hide-user-agent{%s} \\\n}\n/\n", $user_agent; } - open(my $actionfile_fd, ">" . $action_file) + open(my $actionfile_fd, ">", $action_file) or log_error "Writing action file $action_file failed!"; print $actionfile_fd $action_file_content; close($actionfile_fd); @@ -297,7 +299,7 @@ sub write_prefs_file() { my $prefs_file_content = ''; my $prefsfile_fd; - if (open($prefsfile_fd, $mozilla_prefs_file)) { + if (open($prefsfile_fd, "<", $mozilla_prefs_file)) { while (<$prefsfile_fd>) { s@user_pref\(\"general.useragent.override\",.*\);\n?@@; @@ -314,7 +316,7 @@ sub write_prefs_file() { sprintf("user_pref(\"intl.accept_languages\", \"%s\");\n", $accept_language) unless $clean_prefs; - open($prefsfile_fd, ">" . $mozilla_prefs_file) + open($prefsfile_fd, ">", $mozilla_prefs_file) or log_error "Writing prefs file $mozilla_prefs_file failed!"; print $prefsfile_fd $prefs_file_content; close($prefsfile_fd); @@ -322,8 +324,8 @@ sub write_prefs_file() { } sub VersionMessage() { - printf UAGEN_VERSION . "\n" . 'Copyright (C) 2006-2011 Fabian Keil ' . - "\nhttp://www.fabiankeil.de/sourcecode/uagen/\n"; + printf UAGEN_VERSION . "\n" . 'Copyright (C) 2006-2020 Fabian Keil ' . + "\nhttps://www.fabiankeil.de/sourcecode/uagen/\n"; } sub help() { @@ -442,7 +444,6 @@ sub main() { } main(); -exit(0); =head1 NAME @@ -583,10 +584,8 @@ could look like this one: =head1 CAVEATS -If the browser opens an encrypted connection, Privoxy can't inspect -the content and the browser's headers reach the server unmodified. -It is the user's job to use Privoxy's limit-connect action to make sure -there are no encrypted connections to untrusted sites. +Use the https-inspection action to make sure Privoxy can modify +the browser's headers for encrypted traffic as well. Mozilla users can alter the browser's User-Agent with the B<--prefs-file> option. But note that the preference file is only read @@ -602,15 +601,15 @@ Some parameters can't be specified at the command line. =head1 SEE ALSO -privoxy(1) +privoxy(8) =head1 AUTHOR Fabian Keil -http://www.fabiankeil.de/sourcecode/uagen/ +https://www.fabiankeil.de/sourcecode/uagen/ -http://www.fabiankeil.de/blog-surrogat/2006/01/26/firefox-user-agent-generator.html (German) +https://www.fabiankeil.de/blog-surrogat/2006/01/26/firefox-user-agent-generator.html (German) =cut