-
Notifications
You must be signed in to change notification settings - Fork 30
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Invalid ResourceId's, cannot use with Java SDK #7
Comments
I found that there's another Java SDK, where source is provided and the RID parse implementation is similar: https://github.com/Azure/azure-cosmosdb-java/blob/v2.6.0/commons/src/main/java/com/microsoft/azure/cosmosdb/internal/ResourceId.java. |
Thanks for the report! Actually, we just create random strings with a few rules for now, since I was not sure how they should be constructed. The |
@nkzawa FYI there is a JS version of this file as well which may help https://github.com/Azure/azure-cosmos-js/blob/c1be5cc0fcc80670ae6c2a6b5f133530e7889db9/src/common/resourceId.ts In practice, the JS SDK doesn't use any of this information which is why it was later removed |
@southpolesteve It seems we can almost just copy and apply the file, thank you. Btw, do you know how exactly each "id" is assigned on database? As far as I observed,
If you increment const id = new ResouceId();
id.database = "1";
id.documentCollection = "1"
id.document = "1";
console.log(id.toString()); // 'AAAAAQAAAAEAAAAAAAAAAQ=='
// for the next document (wrong)
id.document = "2";
console.log(id.toString()); // 'AAAAAQAAAAEAAAAAAAAAAg==' |
I am not sure but I think you'll be fine with how you are doing it in the PR. The ResourceId just cares about the structure to determine the type of resource it is talking to. I don't think you need to worry about the exact behavior of writing new docs on _rid |
@badeball sorry for the delay. The problem should be fixed on the latest version |
Hmm, I can't seem to perform any query using the Java SDK. It fails on the read-collection-endpoint, where it is provided with Here's the stack trace, if it's of any interest.
|
@badeball Thank you again for the report. Not sure why but maybe Java client is stricter or something on other parts too. I created the issue for it. |
Hello, members of Zeit
With the official CosmosDB emulator not running on non-windows, this is more or less exactly what I'm looking for. I was however not able to use it together with the Java SDK.
It seems like the Node SDK is quite lenient and performs little to no validation on the resource ids*. Hence, generating RID's like you do probably work (I haven't actually tested your implementation with the Node SDK, but I assume it does given the readme etc).
The Java SDK however is a bit more strict and assigns much more meaning to them, as shown here. In addition to be accepted by the parser, they also need to successfully serialize back to the original string.
Since your implementation only generates a quite random ID (of 14 bytes?), the Java SDK will fail on inserting documents, as shown below.
* The source linked is of a quite old version. I can't seem to find the source for the most recent version of the Java SDK anywhere, reported here. This is obviously quite unfortunate, who knows what the SDK is doing these days.
The text was updated successfully, but these errors were encountered: