5 File::Temp - return name and handle of a temporary file safely
11 This module is designed to be portable across operating systems
12 and it currently supports Unix, VMS, DOS, OS/2 and Windows. When
13 porting to a new OS there are generally three main issues
14 that have to be solved:
20 Can the OS unlink an open file? If it can't then the
21 C<_can_unlink_opened_file> method should be modified.
25 Are the return values from C<stat> reliable? By default all the
26 return values from C<stat> are compared when unlinking a temporary
27 file using the filename and the handle. Operating systems other than
28 unix do not always have valid entries in all fields. If C<unlink0> fails
29 then the C<stat> comparison should be modified accordingly.
33 Security. Systems that can not support a test for the sticky bit
34 on a directory can not use the MEDIUM and HIGH security tests.
35 The C<_can_do_level> method should be modified accordingly.
43 use File::Temp qw/ tempfile tempdir /;
45 $dir = tempdir( CLEANUP => 1 );
46 ($fh, $filename) = tempfile( DIR => $dir );
48 ($fh, $filename) = tempfile( $template, DIR => $dir);
49 ($fh, $filename) = tempfile( $template, SUFFIX => '.dat');
55 use File::Temp qw/ :mktemp /;
57 ($fh, $file) = mkstemp( "tmpfileXXXXX" );
58 ($fh, $file) = mkstemps( "tmpfileXXXXXX", $suffix);
60 $tmpdir = mkdtemp( $template );
62 $unopened_file = mktemp( $template );
66 use File::Temp qw/ :POSIX /;
71 ($fh, $file) = tmpnam();
72 ($fh, $file) = tmpfile();
75 Compatibility functions:
77 $unopened_file = File::Temp::tempnam( $dir, $pfx );
81 Objects (NOT YET IMPLEMENTED):
85 $fh = new File::Temp($template);
86 $fname = $fh->filename;
92 C<File::Temp> can be used to create and open temporary files in a safe way.
93 The tempfile() function can be used to return the name and the open
94 filehandle of a temporary file. The tempdir() function can
95 be used to create a temporary directory.
97 The security aspect of temporary file creation is emphasized such that
98 a filehandle and filename are returned together. This helps guarantee
99 that a race condition can not occur where the temporary file is
100 created by another process between checking for the existence of the
101 file and its opening. Additional security levels are provided to
102 check, for example, that the sticky bit is set on world writable
103 directories. See L<"safe_level"> for more information.
105 For compatibility with popular C library functions, Perl implementations of
106 the mkstemp() family of functions are provided. These are, mkstemp(),
107 mkstemps(), mkdtemp() and mktemp().
109 Additionally, implementations of the standard L<POSIX|POSIX>
110 tmpnam() and tmpfile() functions are provided if required.
112 Implementations of mktemp(), tmpnam(), and tempnam() are provided,
113 but should be used with caution since they return only a filename
114 that was valid when function was called, so cannot guarantee
115 that the file will not exist by the time the caller opens the filename.
119 # 5.6.0 gives us S_IWOTH, S_IWGRP, our and auto-vivifying filehandls
120 # People would like a version on 5.005 so give them what they want :-)
125 use File::Path qw/ rmtree /;
128 require VMS::Stdio if $^O eq 'VMS';
130 # Need the Symbol package if we are running older perl
131 require Symbol if $] < 5.006;
134 # use 'our' on v5.6.0
135 use vars qw($VERSION @EXPORT_OK %EXPORT_TAGS $DEBUG);
139 # We are exporting functions
141 use base qw/Exporter/;
143 # Export list - to allow fine tuning of export table
157 # Groups of functions for export
160 'POSIX' => [qw/ tmpnam tmpfile /],
161 'mktemp' => [qw/ mktemp mkstemp mkstemps mkdtemp/],
164 # add contents of these tags to @EXPORT
165 Exporter::export_tags('POSIX','mktemp');
171 # This is a list of characters that can be used in random filenames
173 my @CHARS = (qw/ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
174 a b c d e f g h i j k l m n o p q r s t u v w x y z
175 0 1 2 3 4 5 6 7 8 9 _
178 # Maximum number of tries to make a temp file before failing
180 use constant MAX_TRIES => 10;
182 # Minimum number of X characters that should be in a template
183 use constant MINX => 4;
185 # Default template when no template supplied
187 use constant TEMPXXX => 'X' x 10;
189 # Constants for the security level
191 use constant STANDARD => 0;
192 use constant MEDIUM => 1;
193 use constant HIGH => 2;
195 # OPENFLAGS. If we defined the flag to use with Sysopen here this gives
196 # us an optimisation when many temporary files are requested
198 my $OPENFLAGS = O_CREAT | O_EXCL | O_RDWR;
200 for my $oflag (qw/ FOLLOW BINARY LARGEFILE EXLOCK NOINHERIT /) {
201 my ($bit, $func) = (0, "Fcntl::O_" . $oflag);
203 $OPENFLAGS |= $bit if eval { $bit = &$func(); 1 };
206 # On some systems the O_TEMPORARY flag can be used to tell the OS
207 # to automatically remove the file when it is closed. This is fine
208 # in most cases but not if tempfile is called with UNLINK=>0 and
209 # the filename is requested -- in the case where the filename is to
210 # be passed to another routine. This happens on windows. We overcome
211 # this by using a second open flags variable
213 my $OPENTEMPFLAGS = $OPENFLAGS;
214 for my $oflag (qw/ TEMPORARY /) {
215 my ($bit, $func) = (0, "Fcntl::O_" . $oflag);
217 $OPENTEMPFLAGS |= $bit if eval { $bit = &$func(); 1 };
221 # INTERNAL ROUTINES - not to be used outside of package
223 # Generic routine for getting a temporary filename
224 # modelled on OpenBSD _gettemp() in mktemp.c
226 # The template must contain X's that are to be replaced
227 # with the random values
231 # TEMPLATE - string containing the XXXXX's that is converted
232 # to a random filename and opened if required
234 # Optionally, a hash can also be supplied containing specific options
235 # "open" => if true open the temp file, else just return the name
237 # "mkdir"=> if true, we are creating a temp directory rather than tempfile
239 # "suffixlen" => number of characters at end of PATH to be ignored.
241 # "unlink_on_close" => indicates that, if possible, the OS should remove
242 # the file as soon as it is closed. Usually indicates
243 # use of the O_TEMPORARY flag to sysopen.
244 # Usually irrelevant on unix
246 # "open" and "mkdir" can not both be true
247 # "unlink_on_close" is not used when "mkdir" is true.
249 # The default options are equivalent to mktemp().
252 # filehandle - open file handle (if called with doopen=1, else undef)
253 # temp name - name of the temp file or directory
256 # ($fh, $name) = _gettemp($template, "open" => 1);
258 # for the current version, failures are associated with
259 # a carp to give the reason whilst debugging
263 croak 'Usage: ($fh, $name) = _gettemp($template, OPTIONS);'
264 unless scalar(@_) >= 1;
271 "unlink_on_close" => 0,
275 my $template = shift;
276 if (ref($template)) {
277 carp "File::Temp::_gettemp: template must not be a reference";
281 # Check that the number of entries on stack are even
282 if (scalar(@_) % 2 != 0) {
283 carp "File::Temp::_gettemp: Must have even number of options";
287 # Read the options and merge with defaults
288 %options = (%options, @_) if @_;
290 # Can not open the file and make a directory in a single call
291 if ($options{"open"} && $options{"mkdir"}) {
292 carp "File::Temp::_gettemp: doopen and domkdir can not both be true\n";
296 # Find the start of the end of the Xs (position of last X)
297 # Substr starts from 0
298 my $start = length($template) - 1 - $options{"suffixlen"};
300 # Check that we have at least MINX x X (eg 'XXXX") at the end of the string
301 # (taking suffixlen into account). Any fewer is insecure.
303 # Do it using substr - no reason to use a pattern match since
304 # we know where we are looking and what we are looking for
306 if (substr($template, $start - MINX + 1, MINX) ne 'X' x MINX) {
307 carp "File::Temp::_gettemp: The template must contain at least ". MINX ." 'X' characters\n";
311 # Replace all the X at the end of the substring with a
312 # random character or just all the XX at the end of a full string.
313 # Do it as an if, since the suffix adjusts which section to replace
314 # and suffixlen=0 returns nothing if used in the substr directly
315 # and generate a full path from the template
317 my $path = _replace_XX($template, $options{"suffixlen"});
320 # Split the path into constituent parts - eventually we need to check
321 # whether the directory exists
322 # We need to know whether we are making a temp directory
325 my ($volume, $directories, $file);
326 my $parent; # parent directory
327 if ($options{"mkdir"}) {
328 # There is no filename at the end
329 ($volume, $directories, $file) = File::Spec->splitpath( $path, 1);
331 # The parent is then $directories without the last directory
332 # Split the directory and put it back together again
333 my @dirs = File::Spec->splitdir($directories);
335 # If @dirs only has one entry that means we are in the current
338 $parent = File::Spec->curdir;
341 if ($^O eq 'VMS') { # need volume to avoid relative dir spec
342 $parent = File::Spec->catdir($volume, @dirs[0..$#dirs-1]);
343 $parent = 'sys$disk:[]' if $parent eq '';
346 # Put it back together without the last one
347 $parent = File::Spec->catdir(@dirs[0..$#dirs-1]);
349 # ...and attach the volume (no filename)
350 $parent = File::Spec->catpath($volume, $parent, '');
357 # Get rid of the last filename (use File::Basename for this?)
358 ($volume, $directories, $file) = File::Spec->splitpath( $path );
360 # Join up without the file part
361 $parent = File::Spec->catpath($volume,$directories,'');
363 # If $parent is empty replace with curdir
364 $parent = File::Spec->curdir
365 unless $directories ne '';
369 # Check that the parent directories exist
370 # Do this even for the case where we are simply returning a name
371 # not a file -- no point returning a name that includes a directory
372 # that does not exist or is not writable
374 unless (-d $parent && -w _) {
375 carp "File::Temp::_gettemp: Parent directory ($parent) is not a directory"
376 . " or is not writable\n";
380 # Check the stickiness of the directory and chown giveaway if required
381 # If the directory is world writable the sticky bit
384 if (File::Temp->safe_level == MEDIUM) {
385 unless (_is_safe($parent)) {
386 carp "File::Temp::_gettemp: Parent directory ($parent) is not safe (sticky bit not set when world writable?)";
389 } elsif (File::Temp->safe_level == HIGH) {
390 unless (_is_verysafe($parent)) {
391 carp "File::Temp::_gettemp: Parent directory ($parent) is not safe (sticky bit not set when world writable?)";
397 # Now try MAX_TRIES time to open the file
398 for (my $i = 0; $i < MAX_TRIES; $i++) {
400 # Try to open the file if requested
401 if ($options{"open"}) {
404 # If we are running before perl5.6.0 we can not auto-vivify
406 $fh = &Symbol::gensym;
409 # Try to make sure this will be marked close-on-exec
410 # XXX: Win32 doesn't respect this, nor the proper fcntl,
411 # but may have O_NOINHERIT. This may or may not be in Fcntl.
414 # Store callers umask
420 # Attempt to open the file
421 my $open_success = undef;
422 if ( $^O eq 'VMS' and $options{"unlink_on_close"} ) {
423 # make it auto delete on close by setting FAB$V_DLT bit
424 $fh = VMS::Stdio::vmssysopen($path, $OPENFLAGS, 0600, 'fop=dlt');
427 my $flags = ( $options{"unlink_on_close"} ?
430 $open_success = sysopen($fh, $path, $flags, 0600);
432 if ( $open_success ) {
437 # Opened successfully - return file handle and name
444 # Error opening file - abort with error
445 # if the reason was anything but EEXIST
446 unless ($!{EEXIST}) {
447 carp "File::Temp: Could not create temp file $path: $!";
451 # Loop round for another try
454 } elsif ($options{"mkdir"}) {
456 # Store callers umask
462 # Open the temp directory
463 if (mkdir( $path, 0700)) {
474 # Abort with error if the reason for failure was anything
476 unless ($!{EEXIST}) {
477 carp "File::Temp: Could not create directory $path: $!";
481 # Loop round for another try
487 # Return true if the file can not be found
488 # Directory has been checked previously
490 return (undef, $path) unless -e $path;
492 # Try again until MAX_TRIES
496 # Did not successfully open the tempfile/dir
497 # so try again with a different set of random letters
498 # No point in trying to increment unless we have only
499 # 1 X say and the randomness could come up with the same
500 # file MAX_TRIES in a row.
502 # Store current attempt - in principal this implies that the
503 # 3rd time around the open attempt that the first temp file
504 # name could be generated again. Probably should store each
505 # attempt and make sure that none are repeated
507 my $original = $path;
508 my $counter = 0; # Stop infinite loop
513 # Generate new name from original template
514 $path = _replace_XX($template, $options{"suffixlen"});
518 } until ($path ne $original || $counter > $MAX_GUESS);
520 # Check for out of control looping
521 if ($counter > $MAX_GUESS) {
522 carp "Tried to get a new temp name different to the previous value $MAX_GUESS times.\nSomething wrong with template?? ($template)";
528 # If we get here, we have run out of tries
529 carp "Have exceeded the maximum number of attempts (".MAX_TRIES .
530 ") to open temp file/dir";
536 # Internal routine to return a random character from the
537 # character list. Does not do an srand() since rand()
538 # will do one automatically
540 # No arguments. Return value is the random character
542 # No longer called since _replace_XX runs a few percent faster if
543 # I inline the code. This is important if we are creating thousands of
548 $CHARS[ int( rand( $#CHARS ) ) ];
552 # Internal routine to replace the XXXX... with random characters
553 # This has to be done by _gettemp() every time it fails to
554 # open a temp file/dir
556 # Arguments: $template (the template with XXX),
557 # $ignore (number of characters at end to ignore)
559 # Returns: modified template
563 croak 'Usage: _replace_XX($template, $ignore)'
564 unless scalar(@_) == 2;
566 my ($path, $ignore) = @_;
568 # Do it as an if, since the suffix adjusts which section to replace
569 # and suffixlen=0 returns nothing if used in the substr directly
570 # Alternatively, could simply set $ignore to length($path)-1
571 # Don't want to always use substr when not required though.
574 substr($path, 0, - $ignore) =~ s/X(?=X*\z)/$CHARS[ int( rand( $#CHARS ) ) ]/ge;
576 $path =~ s/X(?=X*\z)/$CHARS[ int( rand( $#CHARS ) ) ]/ge;
582 # internal routine to check to see if the directory is safe
583 # First checks to see if the directory is not owned by the
584 # current user or root. Then checks to see if anyone else
585 # can write to the directory and if so, checks to see if
586 # it has the sticky bit set
588 # Will not work on systems that do not support sticky bit
590 #Args: directory path to check
591 # Returns true if the path is safe and false otherwise.
592 # Returns undef if can not even run stat() on the path
594 # This routine based on version written by Tom Christiansen
596 # Presumably, by the time we actually attempt to create the
597 # file or directory in this directory, it may not be safe
598 # anymore... Have to run _is_safe directly after the open.
605 my @info = stat($path);
606 return 0 unless scalar(@info);
607 return 1 if $^O eq 'VMS'; # owner delete control at file level
609 # Check to see whether owner is neither superuser (or a system uid) nor me
610 # Use the real uid from the $< variable
612 if ($info[4] > File::Temp->top_system_uid() && $info[4] != $<) {
614 Carp::cluck(sprintf "uid=$info[4] topuid=%s \$<=$< path='$path'",
615 File::Temp->top_system_uid());
617 carp "Directory owned neither by root nor the current user.";
621 # check whether group or other can write file
622 # use 066 to detect either reading or writing
623 # use 022 to check writability
624 # Do it with S_IWOTH and S_IWGRP for portability (maybe)
626 if (($info[2] & &Fcntl::S_IWGRP) || # Is group writable?
627 ($info[2] & &Fcntl::S_IWOTH) ) { # Is world writable?
628 return 0 unless -d _; # Must be a directory
629 return 0 unless -k _; # Must be sticky
635 # Internal routine to check whether a directory is safe
636 # for temp files. Safer than _is_safe since it checks for
637 # the possibility of chown giveaway and if that is a possibility
638 # checks each directory in the path to see if it is safe (with _is_safe)
640 # If _PC_CHOWN_RESTRICTED is not set, does the full test of each
645 # Need POSIX - but only want to bother if really necessary due to overhead
649 return 1 if $^O eq 'VMS'; # owner delete control at file level
651 # Should Get the value of _PC_CHOWN_RESTRICTED if it is defined
652 # and If it is not there do the extensive test
653 my $chown_restricted;
654 $chown_restricted = &POSIX::_PC_CHOWN_RESTRICTED()
655 if eval { &POSIX::_PC_CHOWN_RESTRICTED(); 1};
657 # If chown_resticted is set to some value we should test it
658 if (defined $chown_restricted) {
660 # Return if the current directory is safe
661 return _is_safe($path) if POSIX::sysconf( $chown_restricted );
665 # To reach this point either, the _PC_CHOWN_RESTRICTED symbol
666 # was not avialable or the symbol was there but chown giveaway
667 # is allowed. Either way, we now have to test the entire tree for
670 # Convert path to an absolute directory if required
671 unless (File::Spec->file_name_is_absolute($path)) {
672 $path = File::Spec->rel2abs($path);
675 # Split directory into components - assume no file
676 my ($volume, $directories, undef) = File::Spec->splitpath( $path, 1);
678 # Slightly less efficient than having a a function in File::Spec
679 # to chop off the end of a directory or even a function that
680 # can handle ../ in a directory tree
681 # Sometimes splitdir() returns a blank at the end
682 # so we will probably check the bottom directory twice in some cases
683 my @dirs = File::Spec->splitdir($directories);
685 # Concatenate one less directory each time around
686 foreach my $pos (0.. $#dirs) {
687 # Get a directory name
688 my $dir = File::Spec->catpath($volume,
689 File::Spec->catdir(@dirs[0.. $#dirs - $pos]),
693 print "TESTING DIR $dir\n" if $DEBUG;
695 # Check the directory
696 return 0 unless _is_safe($dir);
705 # internal routine to determine whether unlink works on this
706 # platform for files that are currently open.
707 # Returns true if we can, false otherwise.
709 # Currently WinNT, OS/2 and VMS can not unlink an opened file
710 # On VMS this is because the O_EXCL flag is used to open the
711 # temporary file. Currently I do not know enough about the issues
712 # on VMS to decide whether O_EXCL is a requirement.
714 sub _can_unlink_opened_file {
716 if ($^O eq 'MSWin32' || $^O eq 'os2' || $^O eq 'VMS' || $^O eq 'dos') {
724 # internal routine to decide which security levels are allowed
725 # see safe_level() for more information on this
727 # Controls whether the supplied security level is allowed
729 # $cando = _can_do_level( $level )
736 # Always have to be able to do STANDARD
737 return 1 if $level == STANDARD;
739 # Currently, the systems that can do HIGH or MEDIUM are identical
740 if ( $^O eq 'MSWin32' || $^O eq 'os2' || $^O eq 'cygwin' || $^O eq 'dos') {
748 # This routine sets up a deferred unlinking of a specified
749 # filename and filehandle. It is used in the following cases:
750 # - Called by unlink0 if an opened file can not be unlinked
751 # - Called by tempfile() if files are to be removed on shutdown
752 # - Called by tempdir() if directories are to be removed on shutdown
755 # _deferred_unlink( $fh, $fname, $isdir );
757 # - filehandle (so that it can be expclicitly closed if open
758 # - filename (the thing we want to remove)
759 # - isdir (flag to indicate that we are being given a directory)
760 # [and hence no filehandle]
762 # Status is not referred to since all the magic is done with an END block
765 # Will set up two lexical variables to contain all the files to be
766 # removed. One array for files, another for directories
767 # They will only exist in this block
768 # This means we only have to set up a single END block to remove all files
769 # @files_to_unlink contains an array ref with the filehandle and filename
770 my (@files_to_unlink, @dirs_to_unlink);
772 # Set up an end block to use these arrays
775 foreach my $file (@files_to_unlink) {
776 # close the filehandle without checking its state
777 # in order to make real sure that this is closed
778 # if its already closed then I dont care about the answer
779 # probably a better way to do this
780 close($file->[0]); # file handle is [0]
782 if (-f $file->[1]) { # file name is [1]
783 unlink $file->[1] or warn "Error removing ".$file->[1];
787 foreach my $dir (@dirs_to_unlink) {
789 rmtree($dir, $DEBUG, 1);
796 # This is the sub called to register a file for deferred unlinking
797 # This could simply store the input parameters and defer everything
798 # until the END block. For now we do a bit of checking at this
799 # point in order to make sure that (1) we have a file/dir to delete
800 # and (2) we have been called with the correct arguments.
801 sub _deferred_unlink {
803 croak 'Usage: _deferred_unlink($fh, $fname, $isdir)'
804 unless scalar(@_) == 3;
806 my ($fh, $fname, $isdir) = @_;
808 warn "Setting up deferred removal of $fname\n"
811 # If we have a directory, check that it is a directory
816 # Directory exists so store it
817 # first on VMS turn []foo into [.foo] for rmtree
818 $fname = VMS::Filespec::vmspath($fname) if $^O eq 'VMS';
819 push (@dirs_to_unlink, $fname);
822 carp "Request to remove directory $fname could not be completed since it does not exist!\n";
829 # file exists so store handle and name for later removal
830 push(@files_to_unlink, [$fh, $fname]);
833 carp "Request to remove file $fname could not be completed since it is not there!\n";
845 This section describes the recommended interface for generating
846 temporary files and directories.
852 This is the basic function to generate temporary files.
853 The behaviour of the file can be changed using various options:
855 ($fh, $filename) = tempfile();
857 Create a temporary file in the directory specified for temporary
858 files, as specified by the tmpdir() function in L<File::Spec>.
860 ($fh, $filename) = tempfile($template);
862 Create a temporary file in the current directory using the supplied
863 template. Trailing `X' characters are replaced with random letters to
864 generate the filename. At least four `X' characters must be present
867 ($fh, $filename) = tempfile($template, SUFFIX => $suffix)
869 Same as previously, except that a suffix is added to the template
870 after the `X' translation. Useful for ensuring that a temporary
871 filename has a particular extension when needed by other applications.
872 But see the WARNING at the end.
874 ($fh, $filename) = tempfile($template, DIR => $dir);
876 Translates the template as before except that a directory name
879 ($fh, $filename) = tempfile($template, UNLINK => 1);
881 Return the filename and filehandle as before except that the file is
882 automatically removed when the program exits. Default is for the file
883 to be removed if a file handle is requested and to be kept if the
884 filename is requested. In a scalar context (where no filename is
885 returned) the file is always deleted either on exit or when it is closed.
887 If the template is not specified, a template is always
888 automatically generated. This temporary file is placed in tmpdir()
889 (L<File::Spec>) unless a directory is specified explicitly with the
892 $fh = tempfile( $template, DIR => $dir );
894 If called in scalar context, only the filehandle is returned
895 and the file will automatically be deleted when closed (see
896 the description of tmpfile() elsewhere in this document).
897 This is the preferred mode of operation, as if you only
898 have a filehandle, you can never create a race condition
899 by fumbling with the filename. On systems that can not unlink
900 an open file or can not mark a file as temporary when it is opened
901 (for example, Windows NT uses the C<O_TEMPORARY> flag))
902 the file is marked for deletion when the program ends (equivalent
903 to setting UNLINK to 1). The C<UNLINK> flag is ignored if present.
906 (undef, $filename) = tempfile($template, OPEN => 0);
908 This will return the filename based on the template but
909 will not open this file. Cannot be used in conjunction with
910 UNLINK set to true. Default is to always open the file
911 to protect from possible race conditions. A warning is issued
912 if warnings are turned on. Consider using the tmpnam()
913 and mktemp() functions described elsewhere in this document
914 if opening the file is not required.
916 Options can be combined as required.
922 # Can not check for argument count since we can have any
927 "DIR" => undef, # Directory prefix
928 "SUFFIX" => '', # Template suffix
929 "UNLINK" => 0, # Do not unlink file on exit
930 "OPEN" => 1, # Open file
933 # Check to see whether we have an odd or even number of arguments
934 my $template = (scalar(@_) % 2 == 1 ? shift(@_) : undef);
936 # Read the options and merge with defaults
937 %options = (%options, @_) if @_;
939 # First decision is whether or not to open the file
940 if (! $options{"OPEN"}) {
942 warn "tempfile(): temporary filename requested but not opened.\nPossibly unsafe, consider using tempfile() with OPEN set to true\n"
947 if ($options{"DIR"} and $^O eq 'VMS') {
949 # on VMS turn []foo into [.foo] for concatenation
950 $options{"DIR"} = VMS::Filespec::vmspath($options{"DIR"});
953 # Construct the template
955 # Have a choice of trying to work around the mkstemp/mktemp/tmpnam etc
956 # functions or simply constructing a template and using _gettemp()
957 # explicitly. Go for the latter
959 # First generate a template if not defined and prefix the directory
960 # If no template must prefix the temp directory
961 if (defined $template) {
962 if ($options{"DIR"}) {
964 $template = File::Spec->catfile($options{"DIR"}, $template);
970 if ($options{"DIR"}) {
972 $template = File::Spec->catfile($options{"DIR"}, TEMPXXX);
976 $template = File::Spec->catfile(File::Spec->tmpdir, TEMPXXX);
983 $template .= $options{"SUFFIX"};
985 # Determine whether we should tell _gettemp to unlink the file
986 # On unix this is irrelevant and can be worked out after the file is
987 # opened (simply by unlinking the open filehandle). On Windows or VMS
988 # we have to indicate temporary-ness when we open the file. In general
989 # we only want a true temporary file if we are returning just the
990 # filehandle - if the user wants the filename they probably do not
991 # want the file to disappear as soon as they close it.
992 # For this reason, tie unlink_on_close to the return context regardless
994 my $unlink_on_close = ( wantarray ? 0 : 1);
998 croak "Error in tempfile() using $template"
999 unless (($fh, $path) = _gettemp($template,
1000 "open" => $options{'OPEN'},
1002 "unlink_on_close" => $unlink_on_close,
1003 "suffixlen" => length($options{'SUFFIX'}),
1006 # Set up an exit handler that can do whatever is right for the
1007 # system. This removes files at exit when requested explicitly or when
1008 # system is asked to unlink_on_close but is unable to do so because
1009 # of OS limitations.
1010 # The latter should be achieved by using a tied filehandle.
1011 # Do not check return status since this is all done with END blocks.
1012 _deferred_unlink($fh, $path, 0) if $options{"UNLINK"};
1017 if ($options{'OPEN'}) {
1018 return ($fh, $path);
1020 return (undef, $path);
1025 # Unlink the file. It is up to unlink0 to decide what to do with
1026 # this (whether to unlink now or to defer until later)
1027 unlink0($fh, $path) or croak "Error unlinking file $path using unlink0";
1029 # Return just the filehandle.
1038 This is the recommended interface for creation of temporary directories.
1039 The behaviour of the function depends on the arguments:
1041 $tempdir = tempdir();
1043 Create a directory in tmpdir() (see L<File::Spec|File::Spec>).
1045 $tempdir = tempdir( $template );
1047 Create a directory from the supplied template. This template is
1048 similar to that described for tempfile(). `X' characters at the end
1049 of the template are replaced with random letters to construct the
1050 directory name. At least four `X' characters must be in the template.
1052 $tempdir = tempdir ( DIR => $dir );
1054 Specifies the directory to use for the temporary directory.
1055 The temporary directory name is derived from an internal template.
1057 $tempdir = tempdir ( $template, DIR => $dir );
1059 Prepend the supplied directory name to the template. The template
1060 should not include parent directory specifications itself. Any parent
1061 directory specifications are removed from the template before
1062 prepending the supplied directory.
1064 $tempdir = tempdir ( $template, TMPDIR => 1 );
1066 Using the supplied template, creat the temporary directory in
1067 a standard location for temporary files. Equivalent to doing
1069 $tempdir = tempdir ( $template, DIR => File::Spec->tmpdir);
1071 but shorter. Parent directory specifications are stripped from the
1072 template itself. The C<TMPDIR> option is ignored if C<DIR> is set
1073 explicitly. Additionally, C<TMPDIR> is implied if neither a template
1074 nor a directory are supplied.
1076 $tempdir = tempdir( $template, CLEANUP => 1);
1078 Create a temporary directory using the supplied template, but
1079 attempt to remove it (and all files inside it) when the program
1080 exits. Note that an attempt will be made to remove all files from
1081 the directory even if they were not created by this module (otherwise
1082 why ask to clean it up?). The directory removal is made with
1083 the rmtree() function from the L<File::Path|File::Path> module.
1084 Of course, if the template is not specified, the temporary directory
1085 will be created in tmpdir() and will also be removed at program exit.
1093 # Can not check for argument count since we can have any
1098 "CLEANUP" => 0, # Remove directory on exit
1099 "DIR" => '', # Root directory
1100 "TMPDIR" => 0, # Use tempdir with template
1103 # Check to see whether we have an odd or even number of arguments
1104 my $template = (scalar(@_) % 2 == 1 ? shift(@_) : undef );
1106 # Read the options and merge with defaults
1107 %options = (%options, @_) if @_;
1109 # Modify or generate the template
1111 # Deal with the DIR and TMPDIR options
1112 if (defined $template) {
1114 # Need to strip directory path if using DIR or TMPDIR
1115 if ($options{'TMPDIR'} || $options{'DIR'}) {
1117 # Strip parent directory from the filename
1119 # There is no filename at the end
1120 $template = VMS::Filespec::vmspath($template) if $^O eq 'VMS';
1121 my ($volume, $directories, undef) = File::Spec->splitpath( $template, 1);
1123 # Last directory is then our template
1124 $template = (File::Spec->splitdir($directories))[-1];
1126 # Prepend the supplied directory or temp dir
1127 if ($options{"DIR"}) {
1129 $template = File::Spec->catdir($options{"DIR"}, $template);
1131 } elsif ($options{TMPDIR}) {
1134 $template = File::Spec->catdir(File::Spec->tmpdir, $template);
1142 if ($options{"DIR"}) {
1144 $template = File::Spec->catdir($options{"DIR"}, TEMPXXX);
1148 $template = File::Spec->catdir(File::Spec->tmpdir, TEMPXXX);
1154 # Create the directory
1157 if ($^O eq 'VMS') { # dir names can end in delimiters
1158 $template =~ m/([\.\]:>]+)$/;
1159 $suffixlen = length($1);
1161 croak "Error in tempdir() using $template"
1162 unless ((undef, $tempdir) = _gettemp($template,
1165 "suffixlen" => $suffixlen,
1168 # Install exit handler; must be dynamic to get lexical
1169 if ( $options{'CLEANUP'} && -d $tempdir) {
1170 _deferred_unlink(undef, $tempdir, 1);
1173 # Return the dir name
1180 =head1 MKTEMP FUNCTIONS
1182 The following functions are Perl implementations of the
1183 mktemp() family of temp file generation system calls.
1189 Given a template, returns a filehandle to the temporary file and the name
1192 ($fh, $name) = mkstemp( $template );
1194 In scalar context, just the filehandle is returned.
1196 The template may be any filename with some number of X's appended
1197 to it, for example F</tmp/temp.XXXX>. The trailing X's are replaced
1198 with unique alphanumeric combinations.
1206 croak "Usage: mkstemp(template)"
1209 my $template = shift;
1212 croak "Error in mkstemp using $template"
1213 unless (($fh, $path) = _gettemp($template,
1220 return ($fh, $path);
1230 Similar to mkstemp(), except that an extra argument can be supplied
1231 with a suffix to be appended to the template.
1233 ($fh, $name) = mkstemps( $template, $suffix );
1235 For example a template of C<testXXXXXX> and suffix of C<.dat>
1236 would generate a file similar to F<testhGji_w.dat>.
1238 Returns just the filehandle alone when called in scalar context.
1244 croak "Usage: mkstemps(template, suffix)"
1248 my $template = shift;
1251 $template .= $suffix;
1254 croak "Error in mkstemps using $template"
1255 unless (($fh, $path) = _gettemp($template,
1258 "suffixlen" => length($suffix),
1262 return ($fh, $path);
1271 Create a directory from a template. The template must end in
1272 X's that are replaced by the routine.
1274 $tmpdir_name = mkdtemp($template);
1276 Returns the name of the temporary directory created.
1277 Returns undef on failure.
1279 Directory must be removed by the caller.
1287 croak "Usage: mkdtemp(template)"
1290 my $template = shift;
1292 if ($^O eq 'VMS') { # dir names can end in delimiters
1293 $template =~ m/([\.\]:>]+)$/;
1294 $suffixlen = length($1);
1296 my ($junk, $tmpdir);
1297 croak "Error creating temp directory from template $template\n"
1298 unless (($junk, $tmpdir) = _gettemp($template,
1301 "suffixlen" => $suffixlen,
1310 Returns a valid temporary filename but does not guarantee
1311 that the file will not be opened by someone else.
1313 $unopened_file = mktemp($template);
1315 Template is the same as that required by mkstemp().
1321 croak "Usage: mktemp(template)"
1324 my $template = shift;
1326 my ($tmpname, $junk);
1327 croak "Error getting name to temp file from template $template\n"
1328 unless (($junk, $tmpname) = _gettemp($template,
1339 =head1 POSIX FUNCTIONS
1341 This section describes the re-implementation of the tmpnam()
1342 and tmpfile() functions described in L<POSIX>
1343 using the mkstemp() from this module.
1345 Unlike the L<POSIX|POSIX> implementations, the directory used
1346 for the temporary file is not specified in a system include
1347 file (C<P_tmpdir>) but simply depends on the choice of tmpdir()
1348 returned by L<File::Spec|File::Spec>. On some implementations this
1349 location can be set using the C<TMPDIR> environment variable, which
1351 If this is a problem, simply use mkstemp() and specify a template.
1357 When called in scalar context, returns the full name (including path)
1358 of a temporary file (uses mktemp()). The only check is that the file does
1359 not already exist, but there is no guarantee that that condition will
1364 When called in list context, a filehandle to the open file and
1365 a filename are returned. This is achieved by calling mkstemp()
1366 after constructing a suitable template.
1368 ($fh, $file) = tmpnam();
1370 If possible, this form should be used to prevent possible
1373 See L<File::Spec/tmpdir> for information on the choice of temporary
1374 directory for a particular operating system.
1380 # Retrieve the temporary directory name
1381 my $tmpdir = File::Spec->tmpdir;
1383 croak "Error temporary directory is not writable"
1386 # Use a ten character template and append to tmpdir
1387 my $template = File::Spec->catfile($tmpdir, TEMPXXX);
1390 return mkstemp($template);
1392 return mktemp($template);
1399 In scalar context, returns the filehandle of a temporary file.
1403 The file is removed when the filehandle is closed or when the program
1404 exits. No access to the filename is provided.
1410 # Simply call tmpnam() in a list context
1411 my ($fh, $file) = tmpnam();
1413 # Make sure file is removed when filehandle is closed
1414 unlink0($fh, $file) or croak "Unable to unlink temporary file: $!";
1422 =head1 ADDITIONAL FUNCTIONS
1424 These functions are provided for backwards compatibility
1425 with common tempfile generation C library functions.
1427 They are not exported and must be addressed using the full package
1434 Return the name of a temporary file in the specified directory
1435 using a prefix. The file is guaranteed not to exist at the time
1436 the function was called, but such guarantees are good for one
1437 clock tick only. Always use the proper form of C<sysopen>
1438 with C<O_CREAT | O_EXCL> if you must open such a filename.
1440 $filename = File::Temp::tempnam( $dir, $prefix );
1442 Equivalent to running mktemp() with $dir/$prefixXXXXXXXX
1443 (using unix file convention as an example)
1445 Because this function uses mktemp(), it can suffer from race conditions.
1451 croak 'Usage tempnam($dir, $prefix)' unless scalar(@_) == 2;
1453 my ($dir, $prefix) = @_;
1455 # Add a string to the prefix
1456 $prefix .= 'XXXXXXXX';
1458 # Concatenate the directory to the file
1459 my $template = File::Spec->catfile($dir, $prefix);
1461 return mktemp($template);
1467 =head1 UTILITY FUNCTIONS
1469 Useful functions for dealing with the filehandle and filename.
1475 Given an open filehandle and the associated filename, make a safe
1476 unlink. This is achieved by first checking that the filename and
1477 filehandle initially point to the same file and that the number of
1478 links to the file is 1 (all fields returned by stat() are compared).
1479 Then the filename is unlinked and the filehandle checked once again to
1480 verify that the number of links on that file is now 0. This is the
1481 closest you can come to making sure that the filename unlinked was the
1482 same as the file whose descriptor you hold.
1484 unlink0($fh, $path) or die "Error unlinking file $path safely";
1486 Returns false on error. The filehandle is not closed since on some
1487 occasions this is not required.
1489 On some platforms, for example Windows NT, it is not possible to
1490 unlink an open file (the file must be closed first). On those
1491 platforms, the actual unlinking is deferred until the program ends and
1492 good status is returned. A check is still performed to make sure that
1493 the filehandle and filename are pointing to the same thing (but not at
1494 the time the end block is executed since the deferred removal may not
1495 have access to the filehandle).
1497 Additionally, on Windows NT not all the fields returned by stat() can
1498 be compared. For example, the C<dev> and C<rdev> fields seem to be
1499 different. Also, it seems that the size of the file returned by stat()
1500 does not always agree, with C<stat(FH)> being more accurate than
1501 C<stat(filename)>, presumably because of caching issues even when
1502 using autoflush (this is usually overcome by waiting a while after
1503 writing to the tempfile before attempting to C<unlink0> it).
1505 Finally, on NFS file systems the link count of the file handle does
1506 not always go to zero immediately after unlinking. Currently, this
1507 command is expected to fail on NFS disks.
1513 croak 'Usage: unlink0(filehandle, filename)'
1514 unless scalar(@_) == 2;
1517 my ($fh, $path) = @_;
1519 warn "Unlinking $path using unlink0\n"
1522 # Stat the filehandle
1525 if ($fh[3] > 1 && $^W) {
1526 carp "unlink0: fstat found too many links; SB=@fh";
1530 my @path = stat $path;
1533 carp "unlink0: $path is gone already" if $^W;
1537 # this is no longer a file, but may be a directory, or worse
1539 confess "panic: $path is no longer a file: SB=@fh";
1542 # Do comparison of each member of the array
1543 # On WinNT dev and rdev seem to be different
1544 # depending on whether it is a file or a handle.
1545 # Cannot simply compare all members of the stat return
1546 # Select the ones we can use
1547 my @okstat = (0..$#fh); # Use all by default
1548 if ($^O eq 'MSWin32') {
1549 @okstat = (1,2,3,4,5,7,8,9,10);
1550 } elsif ($^O eq 'os2') {
1551 @okstat = (0, 2..$#fh);
1552 } elsif ($^O eq 'VMS') { # device and file ID are sufficient
1554 } elsif ($^O eq 'dos') {
1555 @okstat = (0,2..7,11..$#fh);
1558 # Now compare each entry explicitly by number
1560 print "Comparing: $_ : $fh[$_] and $path[$_]\n" if $DEBUG;
1561 # Use eq rather than == since rdev, blksize, and blocks (6, 11,
1562 # and 12) will be '' on platforms that do not support them. This
1563 # is fine since we are only comparing integers.
1564 unless ($fh[$_] eq $path[$_]) {
1565 warn "Did not match $_ element of stat\n" if $DEBUG;
1570 # attempt remove the file (does not work on some platforms)
1571 if (_can_unlink_opened_file()) {
1572 # XXX: do *not* call this on a directory; possible race
1573 # resulting in recursive removal
1574 croak "unlink0: $path has become a directory!" if -d $path;
1575 unlink($path) or return 0;
1577 # Stat the filehandle
1580 print "Link count = $fh[3] \n" if $DEBUG;
1582 # Make sure that the link count is zero
1583 # - Cygwin provides deferred unlinking, however,
1584 # on Win9x the link count remains 1
1585 return ( $fh[3] == 0 or $^O eq 'cygwin' ? 1 : 0);
1588 _deferred_unlink($fh, $path, 0);
1596 =head1 PACKAGE VARIABLES
1598 These functions control the global state of the package.
1604 Controls the lengths to which the module will go to check the safety of the
1605 temporary file or directory before proceeding.
1612 Do the basic security measures to ensure the directory exists and
1613 is writable, that the umask() is fixed before opening of the file,
1614 that temporary files are opened only if they do not already exist, and
1615 that possible race conditions are avoided. Finally the L<unlink0|"unlink0">
1616 function is used to remove files safely.
1620 In addition to the STANDARD security, the output directory is checked
1621 to make sure that it is owned either by root or the user running the
1622 program. If the directory is writable by group or by other, it is then
1623 checked to make sure that the sticky bit is set.
1625 Will not work on platforms that do not support the C<-k> test
1630 In addition to the MEDIUM security checks, also check for the
1631 possibility of ``chown() giveaway'' using the L<POSIX|POSIX>
1632 sysconf() function. If this is a possibility, each directory in the
1633 path is checked in turn for safeness, recursively walking back to the
1636 For platforms that do not support the L<POSIX|POSIX>
1637 C<_PC_CHOWN_RESTRICTED> symbol (for example, Windows NT) it is
1638 assumed that ``chown() giveaway'' is possible and the recursive test
1643 The level can be changed as follows:
1645 File::Temp->safe_level( File::Temp::HIGH );
1647 The level constants are not exported by the module.
1649 Currently, you must be running at least perl v5.6.0 in order to
1650 run with MEDIUM or HIGH security. This is simply because the
1651 safety tests use functions from L<Fcntl|Fcntl> that are not
1652 available in older versions of perl. The problem is that the version
1653 number for Fcntl is the same in perl 5.6.0 and in 5.005_03 even though
1654 they are different versions.
1656 On systems that do not support the HIGH or MEDIUM safety levels
1657 (for example Win NT or OS/2) any attempt to change the level will
1658 be ignored. The decision to ignore rather than raise an exception
1659 allows portable programs to be written with high security in mind
1660 for the systems that can support this without those programs failing
1661 on systems where the extra tests are irrelevant.
1663 If you really need to see whether the change has been accepted
1664 simply examine the return value of C<safe_level>.
1666 $newlevel = File::Temp->safe_level( File::Temp::HIGH );
1667 die "Could not change to high security"
1668 if $newlevel != File::Temp::HIGH;
1673 # protect from using the variable itself
1674 my $LEVEL = STANDARD;
1679 if (($level != STANDARD) && ($level != MEDIUM) && ($level != HIGH)) {
1680 carp "safe_level: Specified level ($level) not STANDARD, MEDIUM or HIGH - ignoring\n";
1682 # Dont allow this on perl 5.005 or earlier
1683 if ($] < 5.006 && $level != STANDARD) {
1684 # Cant do MEDIUM or HIGH checks
1685 croak "Currently requires perl 5.006 or newer to do the safe checks";
1687 # Check that we are allowed to change level
1688 # Silently ignore if we can not.
1689 $LEVEL = $level if _can_do_level($level);
1698 This is the highest UID on the current system that refers to a root
1699 UID. This is used to make sure that the temporary directory is
1700 owned by a system UID (C<root>, C<bin>, C<sys> etc) rather than
1703 This is required since on many unix systems C</tmp> is not owned
1706 Default is to assume that any UID less than or equal to 10 is a root
1709 File::Temp->top_system_uid(10);
1710 my $topid = File::Temp->top_system_uid;
1712 This value can be adjusted to reduce security checking if required.
1713 The value is only relevant when C<safe_level> is set to MEDIUM or higher.
1720 my $TopSystemUID = 10;
1721 sub top_system_uid {
1725 croak "top_system_uid: UIDs should be numeric"
1726 unless $newuid =~ /^\d+$/s;
1727 $TopSystemUID = $newuid;
1729 return $TopSystemUID;
1735 For maximum security, endeavour always to avoid ever looking at,
1736 touching, or even imputing the existence of the filename. You do not
1737 know that that filename is connected to the same file as the handle
1738 you have, and attempts to check this can only trigger more race
1739 conditions. It's far more secure to use the filehandle alone and
1740 dispense with the filename altogether.
1742 If you need to pass the handle to something that expects a filename
1743 then, on a unix system, use C<"/dev/fd/" . fileno($fh)> for arbitrary
1744 programs, or more generally C<< "+<=&" . fileno($fh) >> for Perl
1745 programs. You will have to clear the close-on-exec bit on that file
1746 descriptor before passing it to another process.
1748 use Fcntl qw/F_SETFD F_GETFD/;
1749 fcntl($tmpfh, F_SETFD, 0)
1750 or die "Can't clear close-on-exec flag on temp fh: $!\n";
1752 =head2 Temporary files and NFS
1754 Some problems are associated with using temporary files that reside
1755 on NFS file systems and it is recommended that a local filesystem
1756 is used whenever possible. Some of the security tests will most probably
1757 fail when the temp file is not local. Additionally, be aware that
1758 the performance of I/O operations over NFS will not be as good as for
1763 Originally began life in May 1999 as an XS interface to the system
1764 mkstemp() function. In March 2000, the OpenBSD mkstemp() code was
1765 translated to Perl for total control of the code's
1766 security checking, to ensure the presence of the function regardless of
1767 operating system and to help with portability.
1771 L<POSIX/tmpnam>, L<POSIX/tmpfile>, L<File::Spec>, L<File::Path>
1773 See L<IO::File> and L<File::MkTemp> for different implementations of
1774 temporary file handling.
1778 Tim Jenness E<lt>t.jenness@jach.hawaii.eduE<gt>
1780 Copyright (C) 1999, 2000 Tim Jenness and the UK Particle Physics and
1781 Astronomy Research Council. All Rights Reserved. This program is free
1782 software; you can redistribute it and/or modify it under the same
1783 terms as Perl itself.
1785 Original Perl implementation loosely based on the OpenBSD C code for
1786 mkstemp(). Thanks to Tom Christiansen for suggesting that this module
1787 should be written and providing ideas for code improvements and
1788 security enhancements.