Opened 14 years ago
Last modified 5 years ago
#16445 new defect (bug)
Fix incompatibilities with IDs greater than 2^31
Reported by: | Viper007Bond | Owned by: | |
---|---|---|---|
Milestone: | Priority: | normal | |
Severity: | normal | Version: | 3.1 |
Component: | Import | Keywords: | needs-patch |
Focuses: | Cc: |
Description (last modified by )
For various reasons, things go bad when you get a post ID greater than 231. When we're importing content and there's an existing ID, I suggest we ignore it if possible if it's too big.
Tumblr2WordPress for example maintains the Tumblr IDs and causes problems in WordPress.
Change History (16)
#4
@
14 years ago
- Cc daniloercoli added
i don't know if it is related but we have similar issues with post IDs using the XML-RPC endpoint.
The postID returned by metaWeblog.editPost, for example, is an int field
<methodResponse> <params> <param> <value> <struct> <member><name>dateCreated</name><value><dateTime.iso8601>20110203T23:32:58</dateTime.iso8601></value></member> <member><name>userid</name><value><string>1</string></value></member> <member><name>postid</name><value><int>2746722655</int></value></member> <member><name>description</name><value><string>.....
but in the case above the value exceeds the xml-rpc specs for the int type (four-byte signed integer - http://www.xmlrpc.com/spec)
So, within the java app, we have issues because the XML-RPC parser tries to retrieve the value using an Integer (It has a minimum value of -2,147,483,648 and a maximum value of 2,147,483,647 (inclusive)).
#5
@
14 years ago
If we change the type to 'string' for postid, will it make things work for you again? It would be great if you could test that before we consider making that change official.
#7
in reply to:
↑ 3
@
14 years ago
Replying to lloydbudd:
What things go bad? If you want to maintain the permalinks after importing from Tumblr (+custom domain) then the easiest solution is probably to maintain the bigint postid.
Agreed. This is probably a much better long term solution to just fix the things that break when the post ID gets that big, such as XML-RPC.
#9
in reply to:
↑ 6
@
14 years ago
Replying to josephscott:
Agree with you, String seems to be a good solution for the long term that respects the standard.
In any case, we should release a new version of the blackberry app (and maybe others), to switch to string, or if you won't change things on your side, we should modify the parser and generate a 'Long' when the overflow will occur.
note: we should fix page_id as well.
#10
@
14 years ago
- Milestone changed from Awaiting Review to Future Release
- Summary changed from Don't allow imported IDs to be greater than 2^31 to Fix incompatibilities with IDs greater than 2^31
#11
@
14 years ago
It's not just the interfaces to the importers/XML-RPC but rather casting to int is prevalent throughout the code base. I also assume this is not a problem for 64-bit systems on which PHP_INT_MAX is the same as BIGINT.
X-ref: Importer fails for post_id's over PHP_INT_MAX of 2147483647
#12
@
12 years ago
changing to bigint fix this for me, but JetPack site stats still show "#2147483647 (loading title)" as getting all my page views, meaning the WordPress JetPack host needs to be updated as well. See pic: http://screencast.com/t/ZdEwbRPe1BR
#13
@
12 years ago
To get Jetpack to correctly log stats I had to manually reset all the post IDs (by tweaking my sql tables, a real pain).
#16
@
9 years ago
- Component changed from WordPress.org site to Import
This is actually related to all importers, not just the Tumblr2WordPress one.
It'd probably make the most sense to handle this at the core importer level of ignoring any existing IDs if they're bigger than ones that we can safely store. That way each individual importer wouldn't need to have this logic.
What things go bad? If you want to maintain the permalinks after importing from Tumblr (+custom domain) then the easiest solution is probably to maintain the permalinks after migration using the big postid.