diff options
author | Jarkko Hietaniemi <jhi@iki.fi> | 2002-04-16 22:31:24 +0000 |
---|---|---|
committer | Jarkko Hietaniemi <jhi@iki.fi> | 2002-04-16 22:31:24 +0000 |
commit | bde417e1a2abaeddb72f93c24d4b6f59f836872a (patch) | |
tree | d68a60b57b66f6b824b6e74c01deabbbee6b122f /lib/Cwd.pm | |
parent | 0b8d6043dc77b60f4e7020acd7548c8bcae74009 (diff) | |
download | perl-bde417e1a2abaeddb72f93c24d4b6f59f836872a.tar.gz |
Document taint-safeness. Life in the fast_abs_path()
lane is unsafe.
p4raw-id: //depot/perl@15963
Diffstat (limited to 'lib/Cwd.pm')
-rw-r--r-- | lib/Cwd.pm | 18 |
1 files changed, 10 insertions, 8 deletions
diff --git a/lib/Cwd.pm b/lib/Cwd.pm index d85d1ea7dc..d1ad76e9f1 100644 --- a/lib/Cwd.pm +++ b/lib/Cwd.pm @@ -38,6 +38,8 @@ Returns the current working directory. Re-implements the getcwd(3) (or getwd(3)) functions in Perl. +Taint-safe. + =item cwd my $cwd = cwd(); @@ -46,7 +48,7 @@ The cwd() is the most natural form for the current architecture. For most systems it is identical to `pwd` (but without the trailing line terminator). -Unfortunately, cwd() tends to break if called under taint mode. +Unfortunately, cwd() is B<not> taint-safe. =item fastcwd @@ -87,18 +89,24 @@ Uses the same algorithm as getcwd(). Symbolic links and relative-path components ("." and "..") are resolved to return the canonical pathname, just like realpath(3). +Taint-safe. + =item realpath my $abs_path = realpath($file); A synonym for abs_path(). +Taint-safe. + =item fast_abs_path my $abs_path = fast_abs_path($file); A more dangerous, but potentially faster version of abs_path. +B<Not> taint-safe. + =back =head2 $ENV{PWD} @@ -409,13 +417,7 @@ sub fast_abs_path { my $path = @_ ? shift : File::Spec->curdir; CORE::chdir($path) || croak "Cannot chdir to $path: $!"; my $realpath = getcwd(); - # I cannot think of an untainting regular expression - # that wouldn't also (a) be unportable (b) disqualify valid pathnames - # so just untainting all of it here and relying on -d and CORE::chdir - # to verify the validity. - # --jhi - my ($cwd_untainted) = ($cwd =~ /^(.+)$/); - -d $cwd_untainted && CORE::chdir($cwd_untainted) || + -d $cwd && CORE::chdir($cwd) || croak "Cannot chdir back to $cwd: $!"; $realpath; } |