• Hi,

    I have a form using ACF fields where subscribers can create a custom post type (Paper) and an ACF upload field which subscribers can use to upload a PDF/Word document to a custom folder in the wp-content/uploads directory.

    I need to add the ID of the parent (custom) post to the front of the file name, eg 435-this-is-my-file-name.pdf

    I have managed to prepend a string ‘test’ which works, but I have no idea how to get the media item’s parent post ID. My current code is:

    add_filter( 'wp_handle_upload_prefilter', 'custom_upload_filter' );
    function custom_upload_filter($file) {
        
        $file['name'] = 'test-' . $file['name'];
        return $file;
    }

    I’m guessing it’s along the following lines, but this doesn’t seem to work.

     add_filter( 'wp_handle_upload_prefilter', 'custom_upload_filter' );
    
    function custom_upload_filter($file) {
     //stuff to get parent post-id and prefix to file $parent_post_id 
    
     if( isset($_REQUEST['post_id']) ) {
            $post_id = $_REQUEST['post_id'];
        } else {
         $post_id = false;
       }
            
        $file['name'] = $post_id'-' . $file['name'];
        return $file;
    }

    Any pointers?

    Cheers,
    Tracy

Viewing 14 replies - 16 through 29 (of 29 total)
  • My latest comment has been held for moderation. Don’t know why. Hopefully it will be posted.

    That happens sometimes with more code-heavy posts – the mods are usually pretty quick with that and check it regularly. Looks like it’s already cleared!

    From that logging, it looks like this could be used:

      ["_acf_post_id"]=>
      string(3) "178"

    Does that correspond to the post ID of the one you were testing this on?

    Thread Starter Freelancealot

    (@freelancealot)

    [“_acf_post_id”]=> string(3) “178”

    The 178 is just a custom field value. It is not the post id or attachment id, it’s the id of an event the CPT is related to. So not useable.

    Drat! I wonder if our previous line of inquiry might still be a possible method. The error message you provided (Uncaught ArgumentCountError: Too few arguments to function foo_insert_post()) – was there any more text to this? In other instances of this exception method PHP will typically include the expected count and the received count.

    Thread Starter Freelancealot

    (@freelancealot)

    There was a lot!

    [22-Sep-2021 21:05:01 UTC] PHP Fatal error:  Uncaught ArgumentCountError: Too few arguments to function foo_insert_post(), 1 passed in /home/customer/www/
    ****/public_html/wp-includes/class-wp-hook.php on line 305 and exactly 3 expected in /home/customer/www/****/public_html/wp-content/themes/bafa2021/functions.php:168
    Stack trace:
    #0 /home/customer/www/***/public_html/wp-includes/class-wp-hook.php(305): foo_insert_post(485)
    #1 /home/customer/www/***/public_html/wp-includes/class-wp-hook.php(327): WP_Hook->apply_filters('', Array)
    #2 /home/customer/www/***/public_html/wp-includes/plugin.php(470): WP_Hook->do_action(Array)
    #3 /home/customer/www/***/public_html/wp-includes/post.php(4479): do_action('wp_insert_post', 485, Object(WP_Post), false)
    #4 /home/customer/www/****/public_html/wp-content/plugins/acf-extended/includes/modules/forms-action-post.php(330): wp_insert_post(Array)
    #5 /home/customer/www/***/publ in /home/customer/www/***/public_html/wp-content/themes/bafa2021/functions.php on line 168
    [22-Sep-2021 21:05:01 UTC] PHP Fatal error:  Uncaught Error: Object of class WP_Error could not be converted to string in /home/customer/www/***/public_html/wp-content/plugins/sg-security/templates/error.php:111
    Stack trace:
    #0 /home/customer/www/***/public_html/wp-content/plugins/sg-security/core/Helper/Helper.php(277): include()
    #1 /home/customer/www/***/public_html/wp-includes/functions.php(3599): SG_Security\Helper\Helper->custom_wp_die_callback(Object(WP_Error), '', Array)
    #2 /home/customer/www/***/public_html/wp-includes/class-wp-fatal-error-handler.php(233): wp_die(Object(WP_Error), '', Array)
    #3 /home/customer/www/***/public_html/wp-includes/class-wp-fatal-error-handler.php(152): WP_Fatal_Error_Handler->display_default_error_template(Array, Object(WP_Error))
    #4 /home/customer/www/***/public_html/wp-includes/class-wp-fatal-error-handler.php(57): WP_Fatal_Error_Handler->display_error_template(Array, Object(WP_Error))
    #5 [internal funct in /home/customer/www/***/public_html/wp-content/plugins/sg-security/templates/error.php on line 111

    Great! That’s quite helpful. I think that the code we were borrowing isn’t quite right, but I hope it’s on the right track.

    Do you mind changing the foo_insert_post function to the following?

    function foo_insert_post( $post ){
        //if this is cpt, go on
        if( 'your_cpt' === $post->post_type ){
            //ref: wp-includes\media.php @ ~2648
            //ref: https://developer.www.ads-software.com/reference/hooks/plupload_default_params/
            add_filter( 'plupload_default_params', 'foo_plupload_config');
        }
    }

    If that doesn’t work, can you try this instead?

    function foo_insert_post( $post_info ){
        ob_start();
        var_dump($post_info);
        $content = ob_get_contents();
        ob_end_clean();
        error_log($content)
        //if this is cpt, go on
        if( 'your_cpt' === $post_info->post_type ){
            //ref: wp-includes\media.php @ ~2648
            //ref: https://developer.www.ads-software.com/reference/hooks/plupload_default_params/
            add_filter( 'plupload_default_params', 'foo_plupload_config');
        }
    }

    This is an attempt to see what $post_info is and how we might be able to use it.

    Thread Starter Freelancealot

    (@freelancealot)

    Hi
    The first one throws up this error

    Notice: Trying to get property ‘post_type’ of non-object in /home/customer/www/***/public_html/wp-content/themes/bafa2021/functions.php on line 170

    And does not add the id to the file name.

    Line 170 in the functions.php is;

    if( 'submitted_paper' === $post->post_type ){

    Does that give you any clues? If not, I’ll try the second one.

    Cheers,
    Tracy

    Thread Starter Freelancealot

    (@freelancealot)

    The second one results in Parse error: syntax error, unexpected ‘if’ (T_IF) in /home/customer/www/***/public_html/wp-content/themes/bafa2021/functions.php on line 175

    Ah, so sorry, the error_log($content) line needs a semi-colon (;) at the end of it!

    Thread Starter Freelancealot

    (@freelancealot)

    Same error as the first one

    Notice: Trying to get property ‘post_type’ of non-object in /home/customer/www/***/public_html/wp-content/themes/bafa2021/functions.php on line 175

    In the debug log it says

    [23-Sep-2021 00:50:53 UTC] PHP Notice: Trying to get property ‘post_type’ of non-object in /home/customer/www/***/public_html/wp-content/themes/bafa2021/functions.php on line 175
    [23-Sep-2021 00:51:02 UTC] int(507)

    I checked and the id of the post just created was 507!

    But it did not add the 507 to the file name when I check in uploads/papers

    Cheers,
    Tracy

    That’s great news!! If that’s the ID, then we’re in luck. You can probably change the function to look like this:

    function foo_insert_post( $post_id ){
        $post = get_post($post_id);
        //if this is cpt, go on
        if( 'your_cpt' === $post->post_type ){
            //ref: wp-includes\media.php @ ~2648
            //ref: https://developer.www.ads-software.com/reference/hooks/plupload_default_params/
            add_filter( 'plupload_default_params', 'foo_plupload_config');
        }
    }

    Let me know if that works! You’ll also need to change your filename changing function to use $_REQUEST['post_id'], since that’s what’s being added in foo_plupload_config.

    Thread Starter Freelancealot

    (@freelancealot)

    Hi,

    Nope, didn’t add the id to the file name.

    add_filter( 'wp_insert_post', 'foo_insert_post');
    function foo_insert_post( $post_id ){
        $post = get_post($post_id);
        if( 'submitted_paper' === $post->post_type ){
            add_filter( 'plupload_default_params', 'foo_plupload_config');
        }
    }
    function foo_plupload_config($params){
        global $post;
        //assign current post id
        $params['post_id'] = $post->ID;
        return $params;
    }
    
    add_filter( 'wp_handle_upload_prefilter', 'custom_upload_filter' );
    function custom_upload_filter($file) {
    
       // Get the parent post ID, if there is one
           if( isset($_REQUEST['post_id']) ) {
               $post_id = $_REQUEST['post_id'];
          } else {
             $post_id = false;
           }
            
        $file['name'] = $post_id . '-' . $file['name'];
        return $file;
    }
    Thread Starter Freelancealot

    (@freelancealot)

    Hi,

    I found something on stackexchange that may help but not sure how to fit it in with above code.

    Someone wanting to use the id of a post to create an upload folder for the related attachments. It seems very close to what we have above.

    function media_upload_dir($upload) {
            if(!isset($_REQUEST['post_id']))
            return $upload;
    $id = $_REQUEST['post_id'];
            if (isset($_REQUEST['post_id'])) {
                $upload['path']    = "/path/www/blog/wp-content/uploads/" . $id;
                $upload['url']     = "https://site.com/blog/wp-content/uploads/" . $id;
                $upload['basedir'] = "/path/www/blog/wp-content/uploads/" . $id;
                $upload['baseurl'] = "https://site.com/blog/wp-content/uploads/" . $id;
                if (!file_exists("/path/www/blog/wp-content/uploads/" . $id)) {
                    mkdir("/path/www/blog/wp-content/uploads/" . $id, 0777);
                }
            }
            return $upload;
        }
        add_filter('upload_dir', 'media_upload_dir');

    As an alternative if there is no way to get the related post-id of an attachment before it is uploaded, is it possible to run some code that goes through a folder of attachments, adds the related post-id to the front of the file name and zips the folder for download?

    Dang, that’s unfortunate. Can you try using the previous debug logging steps to see the contents of $_POST in the custom_upload_filter function?

    It turns out that won’t make any difference. I’m still looking at other upload functions we might be able to tap into. I feel like we should be able to make the post ID available somewhere.

    I suspect the hierarchical -> true parameter you mentioned a while back will make the post_id visible. Is it possible for you to try changing that for the Paper post type (and any other relevant ones)?

Viewing 14 replies - 16 through 29 (of 29 total)
  • The topic ‘How to prepend parent post ID to uploaded file’ is closed to new replies.