HEX
Server: Apache
System: Linux p3plzcpnl506847.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: slfopp7cb1df (5698090)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: /home/slfopp7cb1df/www/shaneconrad.me/wp-content/plugins/shared-files/admin/class-sf-admin-list.php
<?php

class SharedFilesAdminList {
    /**
     * Custom columns for shared file.
     *
     * @since    1.0.0
     */
    public function shared_file_custom_columns( $defaults ) {
        $s = get_option( 'shared_files_settings' );
        if ( SharedFilesHelpers::isPremium() == 0 ) {
            $defaults['_category'] = sanitize_text_field( __( 'Category', 'shared-files' ) );
        }
        $defaults['file_url'] = sanitize_text_field( __( 'Shortcode', 'shared-files' ) );
        $defaults['filesize'] = sanitize_text_field( __( 'File size', 'shared-files' ) );
        $defaults['load_cnt'] = sanitize_text_field( __( 'Downloads', 'shared-files' ) );
        if ( !isset( $s['hide_limit_downloads'] ) ) {
            $defaults['limit_downloads'] = sanitize_text_field( __( 'Limit', 'shared-files' ) );
        }
        if ( !isset( $s['hide_file_added'] ) ) {
            $defaults['file_added'] = sanitize_text_field( __( 'File added', 'shared-files' ) );
        }
        if ( !isset( $s['hide_last_access'] ) ) {
            $defaults['last_access'] = sanitize_text_field( __( 'Last access', 'shared-files' ) );
        }
        return $defaults;
    }

    public function set_custom_shared_files_sortable_columns( $columns ) {
        $columns['taxonomy-shared-file-category'] = 'shared-file-category';
        $columns['expiration_date'] = '_sf_expiration_date';
        $columns['file_added'] = '_sf_file_added';
        $columns['last_access'] = '_sf_last_access';
        $columns['load_cnt'] = '_sf_load_cnt';
        $columns['limit_downloads'] = '_sf_limit_downloads';
        $columns['filesize'] = '_sf_filesize';
        return $columns;
    }

    public function sort_posts_by_meta_value( $query ) {
        if ( !is_admin() || !$query->is_main_query() ) {
            return;
        }
        global $pagenow;
        if ( is_admin() && $pagenow == 'edit.php' && isset( $_GET['post_type'] ) && $_GET['post_type'] == 'shared_file' && isset( $_GET['orderby'] ) && $_GET['orderby'] != 'None' ) {
            if ( $_GET['orderby'] == '_sf_expiration_date' ) {
                $query->query_vars['orderby'] = 'meta_value';
                $query->query_vars['meta_key'] = sanitize_title( $_GET['orderby'] );
            } elseif ( $_GET['orderby'] == '_sf_file_added' ) {
                $query->query_vars['orderby'] = 'meta_value';
                $query->query_vars['meta_key'] = sanitize_title( $_GET['orderby'] );
                $query->query_vars['meta_type'] = 'DATETIME';
            } elseif ( $_GET['orderby'] == '_sf_last_access' ) {
                $query->query_vars['orderby'] = 'meta_value';
                $query->query_vars['meta_key'] = sanitize_title( $_GET['orderby'] );
                $query->query_vars['meta_type'] = 'DATETIME';
            } elseif ( $_GET['orderby'] == '_sf_load_cnt' ) {
                $query->query_vars['orderby'] = 'meta_value';
                $query->query_vars['meta_key'] = sanitize_title( $_GET['orderby'] );
                $query->query_vars['meta_type'] = 'numeric';
            } elseif ( $_GET['orderby'] == '_sf_limit_downloads' ) {
                $query->query_vars['orderby'] = 'meta_value';
                $query->query_vars['meta_key'] = sanitize_title( $_GET['orderby'] );
                $query->query_vars['meta_type'] = 'numeric';
            } elseif ( $_GET['orderby'] == '_sf_filesize' ) {
                $query->query_vars['orderby'] = 'meta_value';
                $query->query_vars['meta_key'] = sanitize_title( $_GET['orderby'] );
                $query->query_vars['meta_type'] = 'numeric';
            }
        }
    }

    /**
     * Custom column content for shared file.
     *
     * @since    1.0.0
     */
    public function shared_file_custom_columns_content( $column_name, $post_ID ) {
        $post_ID = intval( $post_ID );
        $file_id = intval( get_the_ID() );
        switch ( $column_name ) {
            case '_category':
                echo '<a href="' . esc_url_raw( get_admin_url() ) . 'options-general.php?page=shared-files-pricing"><div class="shared-files-pro-only">' . esc_html__( 'All Plans', 'shared-files' ) . '</div></a>';
                break;
            case 'file_url':
                echo '<span class="shared-files-shortcode-admin-list shared-files-shortcode-admin-list-file shared-files-shortcode-' . esc_attr( $post_ID ) . '" title="[shared_files file_id=' . esc_attr( $post_ID ) . ']">[shared_files file_id=' . esc_attr( $post_ID ) . ']</span>';
                echo '<button class="shared-files-copy shared-files-copy-single shared-files-copy-admin-list" data-clipboard-action="copy" data-clipboard-target=".shared-files-shortcode-' . esc_attr( $post_ID ) . '">' . esc_html__( 'Copy', 'shared-files' ) . '</button>';
                $folder_name = get_post_meta( $file_id, '_sf_subdir', true );
                if ( $folder_name ) {
                    echo '<hr class="clear" /><div class="shared-files-admin-folder-name">' . esc_html( $folder_name ) . '/</div>';
                }
                //        $file_url = SharedFilesAdminHelpers::sf_root() . '/shared-files/' . $post_ID . '/' . SharedFilesHelpers::wp_engine() . sanitize_text_field( get_post_meta($post_ID, '_sf_filename', true) );
                $file_url = SharedFilesPublicHelpers::getFileURL( $file_id );
                echo '<hr class="clear" /><a href="' . esc_url( $file_url ) . '" class="shared-files-admin-file-url" target="_blank">' . esc_url( $file_url ) . '</a>';
                break;
            case 'filesize':
                if ( get_post_meta( $post_ID, '_sf_external_url', true ) ) {
                    echo 'n/a';
                } else {
                    echo esc_html( SharedFilesAdminHelpers::human_filesize( sanitize_text_field( get_post_meta( $post_ID, '_sf_filesize', true ) ) ) );
                }
                break;
            case 'restriction':
                break;
            case 'load_cnt':
                echo esc_html( get_post_meta( $post_ID, '_sf_load_cnt', true ) );
                break;
            case 'limit_downloads':
                if ( SharedFilesHelpers::isPremium() == 0 ) {
                    echo '<a href="' . esc_url_raw( get_admin_url() ) . 'options-general.php?page=shared-files-pricing"><div class="shared-files-pro-only">' . esc_html__( 'All Plans', 'shared-files' ) . '</div></a>';
                }
                break;
            case 'file_added':
                echo esc_html( get_post_meta( $post_ID, '_sf_file_added', true ) );
                break;
            case 'last_access':
                if ( SharedFilesHelpers::isPremium() == 0 ) {
                    echo '<a href="' . esc_url_raw( get_admin_url() ) . 'options-general.php?page=shared-files-pricing"><div class="shared-files-pro-only">' . esc_html__( 'All Plans', 'shared-files' ) . '</div></a>';
                }
                break;
            case 'bandwidth_usage':
                if ( SharedFilesHelpers::isPremium() == 0 ) {
                    echo '<a href="' . esc_url_raw( get_admin_url() ) . 'options-general.php?page=shared-files-pricing"><div class="shared-files-pro-only">' . esc_html__( 'All Plans', 'shared-files' ) . '</div></a>';
                }
                break;
            case 'expiration_date':
                if ( SharedFilesHelpers::isPremium() == 0 ) {
                    echo '<a href="' . esc_url_raw( get_admin_url() ) . 'options-general.php?page=shared-files-pricing"><div class="shared-files-pro-only">' . esc_html__( 'All Plans', 'shared-files' ) . '</div></a>';
                }
                break;
        }
    }

    function filter_files_by_taxonomies( $post_type, $which ) {
        // Apply this only on a specific post type
        if ( $post_type !== 'shared_file' ) {
            return;
        }
        $taxonomy_slug = 'shared-file-category';
        $current_category_slug = ( isset( $_GET['shared-file-category'] ) ? sanitize_title( $_GET['shared-file-category'] ) : '' );
        if ( get_taxonomy( $taxonomy_slug ) ) {
            if ( has_term( '', $taxonomy_slug ) ) {
                wp_dropdown_categories( [
                    'show_option_all' => get_taxonomy( $taxonomy_slug )->labels->all_items,
                    'hide_empty'      => 1,
                    'hierarchical'    => 1,
                    'show_count'      => 1,
                    'orderby'         => 'name',
                    'name'            => $taxonomy_slug,
                    'value_field'     => 'slug',
                    'taxonomy'        => $taxonomy_slug,
                    'selected'        => $current_category_slug,
                ] );
            }
        }
    }

    public function sort_by_custom_taxonomy( $clauses, $wp_query ) {
        global $wpdb;
        if ( isset( $wp_query->query['orderby'] ) && $wp_query->query['orderby'] == 'shared-file-category' ) {
            $clauses['join'] .= "\n        LEFT OUTER JOIN {$wpdb->term_relationships} ON {$wpdb->posts}.ID={$wpdb->term_relationships}.object_id\n        LEFT OUTER JOIN {$wpdb->term_taxonomy} USING (term_taxonomy_id)\n        LEFT OUTER JOIN {$wpdb->terms} USING (term_id)\n        ";
            $clauses['where'] .= " AND (taxonomy = 'shared-file-category' OR taxonomy IS NULL)";
            $clauses['groupby'] = "object_id";
            $clauses['orderby'] = "GROUP_CONCAT({$wpdb->terms}.name ORDER BY name ASC) ";
            $clauses['orderby'] .= ( 'ASC' == strtoupper( $wp_query->get( 'order' ) ) ? 'ASC' : 'DESC' );
        }
        return $clauses;
    }

}