Blueprint: How to Create A Secure Downloads System in WordPress

One of our partners approached us with a pretty interesting requirement.  They currently manage a fund that operates businesses from a portfolio of  4 different industries. This means, they want to create a special section on their site for investor relations and downloads.

Can Our Investors Download Files Securely on our WordPress-powered Site? 

With their current site built on the WordPress platform, they wanted a  way to upload monthly, quarterly and annual financial reports as well  as investor decks for fund raising. On top of that, they also wanted to make sure that some files are only viewable to certain people. To illustrate, a fund investor will have access to all files while an investor that only placed money in one business will only have access to that folder.

They examined several options before, ranging from Dropbox/Box (cheap, but has little room for customization) to full-blown Enterprise Document Management systems (expensive and too cumbersome to deploy).

The Solution: It’s All About Using Plugins Creatively

Instead of building one from scratch, you can actually implement a bonafide file management system using a cocktail of WordPress plugins. The benefits from a cost and project timeline perspective makes this whole exercise worth looking at. While it’s not a one-size-fits-all solution, this approach should give you something that actually works!

For this tutorial you’ll be needing the following WordPress Plugins:

  • Download Manager – This will serve as the main engine of the file management page of your site. From here you’ll create folders and manage file access permissions.
  • WP Login Box – The idea here is to “hide” the WordPress interface to your end users. This plugin provides you with an embeddable login box on your downloads page.
  • WPFront User Role Editor – You will need this to create custom user roles on top of standard WordPress default roles (I.e. Admin, Editor, Author, Contributor etc). We’ll need this because we have to create roles specific to your investors.

Of course this assumes that you already have an existing WordPress-powered website and have the ability to create pages without breaking your site template. This solution just requires a simple shortcode embed.

  1. Prepare Your Workspace – Make sure you’ve already installed the three plugins we mentioned above. It goes without saying that you should be doing this on your test server and have performed all the necessary backups necessary to perform this exercise.
  2. Create your Downloads Page – We are creating a special Downloads section on your site. You can do this by creating a vanilla WordPress page here and make sure that the page template you’re using is not meant for blog archives and other “specialized” pages. We want this to be as basic as possible. We’re essentially getting all these plugins to do the work for you.
  3. Create your custom roles – This is where the WPFront User Role Editor comes into play. For this exercise, you would want to create three types, Investor Type A (all access), Investor Type B (access to project 1), Investor Type C (access to project 2). Of course, the plugin won’t really ask where you plan to use these so as a rule of thumb. Just fill-in the display name and role name (or just the required fields). Leave everything blank.Creating_Roles
  4. Create your download folders – Okay, time to fire up your Download Manager setting by clicking on the link on the left pane. Click on “Add New”.Upload Files
  5. Upload Your Files – You’ll probably have your own way of organizing files. In this example, we’re sorting it by company (one of many). I uploaded three files here representing monthly reports.
  6. Put Finishing Touches on the Folder  – You want to make sure that these folders are only accessible to users with all the necessary permissions. You can simply configure that from the same folder interface by scrolling down to the bottom. It uses all visitors by default so remove that first then add the correct user types in the “Allow Access” box.Upload Options
  7. Configure and Embed the Login Shortcode. – Just add the shortcode [wplb] on the downloads page.. It’s as simple as that. Make sure you emulate the settings here! WPLB_OptionsDownloads_Page
  8. Embed your packages.  – Same as what we did for the login box. Put ALL of the package shortcodes on the page.Edit_Page_‹_JC_Medina_s_Sandbox_—_WordPress
  9. Create Your User Accounts (don’t confuse this with roles)  – We want to hide the fact that we’re using WordPress here so as a good measure, just untick the box here.AddNew User_WordPressDisabling_the_WP_bar
  10. Change the CSS – Most of the plugins mentioned in this article allow you to put in your custom CSS. Just ask your developer to do this.

If you followed all these steps. The whole flow should look like this:

User Logs in...

User Logs in….

User Sees Multiple Folders

User Sees Multiple Folders

 

...and start downloading!

…and start downloading!

So there you have it! If follow all the instructions correctly (and your files are ready) you can do all of these steps in less than an hour.

Have you considered implementing other document management solutions on WordPress? Let us know!

Comments

  1. Destiny Video says

    Oh my goodness! Incredible article dude! Thanks, However I am experiencing difficulties
    with your RSS. I don’t know the reason why I am unable to
    subscribe to it. Is there anybody having identical RSS problems?
    Anyone that knows the solution will you kindly respond?
    Thanks!!

  2. destiny.Steamtricks.Com says

    It’s really a great and useful piece of information. I am glad that you just shared this useful
    information with us. Please stay us informed like this.
    Thanks for sharing.

  3. Nick says

    Does this also protect files from direct download? I have a similar solution in place, but does this also prevent users from directly the files? The issue I am finding with wordpress is that, while it can use a software solution to protect files from download via wordpress, you would still need to put and .htaccess file in place on the uploads directory in order to prevent people from randomly finding the files and doing a direct download.

    Any help with this would be much appreciated.

  4. says

    Helpful article. Thanks. Currently I am testing on a dev server and I do not have the Pro version of the Download Manager installed. That seems to make a difference. I can only provide one file per download user at a time, and the access to the files are available to all. The Pro version would allow me to provide several downloads per Company and limit the downloading and viewing to the logged-in user with the proper role?

    Could this method also be extended to provide a means for a download user to upload a doc back to the same protected area?

    Thanks for your time to make this information available.

  5. Matt says

    A great starter tutorial, but I have one question – when I follow the instructions, the packages all appear on the download page regardless of whether or not I’m logged in. (You can’t download anything but the link structure is there.) Is there a way to condition the site so that the packages do not appear until there is a login authentication?

Trackbacks

Leave a Reply to Getnjoy Cancel reply

Your email address will not be published. Required fields are marked *