Make WordPress Core

Changeset 56186

Timestamp:
07/10/2023 08:31:35 PM (13 months ago)
Author:
azaozz
Message:

Filesystem API: Ensure wp_tempnam() does not produce file names longer than 255 characters as this is the limit on most filesystems.

Props: costdev, doems, mikeschroder, oglekler, mrinal013.
Fixes: #35755.

Location:
trunk
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/wp-admin/includes/file.php

    r56174 r56186  
    690690    $temp_filename .= '-' . wp_generate_password( 6, false );
    691691    $temp_filename .= '.tmp';
    692     $temp_filename  = $dir . wp_unique_filename( $dir, $temp_filename );
     692    $temp_filename  = wp_unique_filename( $dir, $temp_filename );
     693
     694    /*
     695     * Filesystems typically have a limit of 255 characters for a filename.
     696     *
     697     * If the generated unique filename exceeds this, truncate the initial
     698     * filename and try again.
     699     *
     700     * As it's possible that the truncated filename may exist, producing a
     701     * suffix of "-1" or "-10" which could exceed the limit again, truncate
     702     * it to 252 instead.
     703     */
     704    $characters_over_limit = strlen( $temp_filename ) - 252;
     705    if ( $characters_over_limit > 0 ) {
     706        $filename = substr( $filename, 0, -$characters_over_limit );
     707        return wp_tempnam( $filename, $dir );
     708    }
     709
     710    $temp_filename = $dir . $temp_filename;
    693711
    694712    $fp = @fopen( $temp_filename, 'x' );
  • trunk/tests/phpunit/tests/file.php

    r55060 r56186  
    207207
    208208    /**
     209
     210
     211
     212
     213
     214
     215
     216
     217
     218
     219
     220
     221
     222
     223
     224
     225
     226
     227
     228
     229
     230
     231
     232
     233
     234
     235
     236
     237
     238
     239
     240
     241
     242
     243
     244
     245
     246
     247
     248
     249
     250
     251
     252
     253
     254
     255
     256
     257
     258
     259
     260
     261
     262
     263
     264
     265
     266
     267
     268
     269
     270
     271
     272
     273
     274
     275
     276
     277
     278
     279
     280
     281
     282
     283
     284
     285
     286
     287
     288
     289
     290
     291
     292
     293
     294
     295
     296
     297
     298
     299
     300
     301
     302
     303
     304
     305
     306
     307
     308
     309
     310
     311
     312
     313
     314
     315
     316
     317
     318
     319
     320
     321
     322
     323
     324
     325
     326
     327
     328
     329
     330
     331
     332
     333
     334
     335
     336
     337
     338
     339
     340
     341
     342
     343
     344
     345
     346
     347
     348
     349
     350
     351
     352
     353
     354
     355
     356
     357
     358
     359
     360
     361
     362
     363
     364
     365
     366
     367
     368
     369
     370
     371
     372
     373
     374
     375
     376
     377
     378
     379
     380
     381
     382
     383
     384
     385
     386
     387
     388
     389
     390
     391
     392
     393
     394
     395
     396
     397
     398
     399
     400
     401
    209402     * @ticket 47186
    210403     */
Note: See TracChangeset for help on using the changeset viewer.