Opened 12 years ago
Last modified 5 years ago
#21913 new enhancement
Detecting MIME Types in WXR Files
Reported by: | ReadyMadeWeb | Owned by: | |
---|---|---|---|
Milestone: | Priority: | normal | |
Severity: | normal | Version: | 3.4.2 |
Component: | Import | Keywords: | dev-feedback needs-refresh |
Focuses: | Cc: |
Description
In the process of creating a service to convert TypePad data to WXR formatted files, we've encountered some unique problems with TypePad data. Namely, many TypePad files are saved without file extensions, which prevents the existing importer from importing those files into the wp-content/uploads folder.
In order to import and rename these otherwise ignored files, we've created a patch for the WordPress importer that does the following:
- If there is an attachment in the WXR and the importer is not able to determine the file type from the file name (ie missing extension), the patched version will make a light (body-less) request to the web server where the file is hosted for information we can use about the file. The things we're interested in are file type, size, and filename.
- If the importer is processing an attachment under the above situation, and it is able to determine the file type, then it will rewrite the local version of the file to have the appropriate file extension.
This is a simple bit of code, but it makes a huge difference as TypePad saves without file extensions quite regularly.
We've attached our patch and a sample WXR file from ragsgupta.com, the Brightcove co-founder's blog.
Attachments (3)
Change History (14)
#2
follow-ups:
↓ 6
↓ 9
@
12 years ago
Rather than using cURL, we have an HTTP API. You can use wp_remote_head() to send a HEAD request, then use wp_remote_retrieve_header() on the response to get a specific header.
We also use lowercase true/false/null.
Also, please use svn diff
rather than the GNU diff
tool to create patches. It can still be applied with patch
but contains SVN metadata (and is properly recognized by our bug tracker).
#5
@
12 years ago
A patch file readymadeweb-filetype-HEAD.patch has been uploaded and is ready for review.
#6
in reply to:
↑ 2
@
12 years ago
Replying to nacin:
Rather than using cURL, we have an HTTP API. You can use wp_remote_head() to send a HEAD request, then use wp_remote_retrieve_header() on the response to get a specific header.
We also use lowercase true/false/null.
Also, please use
svn diff
rather than the GNUdiff
tool to create patches. It can still be applied withpatch
but contains SVN metadata (and is properly recognized by our bug tracker).
All of these issues have been addressed and a new version of the patch is uploaded. Still not sure if I'm using this forum correctly. Please excuse the excess comments.
#9
in reply to:
↑ 2
@
12 years ago
New patch is posted!
Replying to nacin:
Rather than using cURL, we have an HTTP API. You can use wp_remote_head() to send a HEAD request, then use wp_remote_retrieve_header() on the response to get a specific header.
We also use lowercase true/false/null.
Also, please use
svn diff
rather than the GNUdiff
tool to create patches. It can still be applied withpatch
but contains SVN metadata (and is properly recognized by our bug tracker).
Patch to WordPress Importer