##############################################################################################
# uagen (http://www.fabiankeil.de/sourcecode/uagen/)
#
-# $Id: uagen.pl,v 1.14 2011/06/29 18:35:53 fabiankeil Exp $
-#
# 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)'.
#
use constant {
- UAGEN_VERSION => 'uagen 1.1',
+ UAGEN_VERSION => 'uagen 1.2.1',
UAGEN_LOGFILE => '/var/log/uagen.log',
ACTION_FILE => '/etc/privoxy/user-agent.action',
# 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 => "17.0",
+ BROWSER_REVISION => '17.0',
BROWSER_RELEASE_DATE => '20100101',
};
#######################################################################################
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);
$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() {
FreeBSD => {
karma => 1,
platform => 'X11',
- architectures => [ 'i386', 'amd64', 'sparc64', 'alpha' ],
+ architectures => [ 'i386', 'amd64', 'sparc64' ],
order_is_inversed => 0,
},
OpenBSD => {
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;
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;
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);
}
$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);
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?@@;
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);
}
main();
-exit(0);
=head1 NAME