Skip to content
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

Section Initial Base URI contradicts referenced RFC3986 #745

Closed
Relequestual opened this issue May 28, 2019 · 4 comments · Fixed by #747
Closed

Section Initial Base URI contradicts referenced RFC3986 #745

Relequestual opened this issue May 28, 2019 · 4 comments · Fixed by #747
Assignees

Comments

@Relequestual
Copy link
Member

This is more a comment for me to make sure I make a PR agains the validation document.
Section title "Initial Base URI" states that...

RFC3986 Section 5.1 defines how to determine the
default base URI of a document.

But also that...

Informatively, the initial base URI of a schema is the URI at which it was
found, whether that was a network location, a local filesystem, or any other
situation identifiable by a URI of any known scheme.

The point of referencing the RFC is so we don't have to include all the content, however in this case it reads to me as a contradiction.

The order of precedence in RFC3986 says first look for a base URI embedded in the contnet, which for JSON Schema is $id. Prefixing "informativly" to the scentence does not prohibit that it seems to be stating the "base URI of a schema is the location where the schema is found", which the third order of precedence according to RFC3986.

It should be clear in saying that the base URI in relation to "URI used to retrieve the entity" as per RFC3986 order of precedence in determining base URI, may be a network location, a local file system, or something else.

It could also be useful to note that a base URI must also conform to an absolute-uri, syntax as defined in said RFC, which inclues a URI schema, which for a local filesystem is the file URI schema, defined by RFC8089.

@Relequestual Relequestual added this to the draft-08 milestone May 28, 2019
@handrews
Copy link
Contributor

handrews commented May 28, 2019

@Relequestual see PR #686 and python-jsonschema/jsonschema#343 (comment) for why this language was added.

I don't really follow how why this is a contradiction. Your first assumption of the base URI is the retrieval URI. The way that precedence diagram works is that you start from the outermost layer (application specific) which is modified or overridden as you go towards the innermost layer.

To use a JSON Schema example, if the $id in the root schema is /foo (which is not what is recommended but is technically allowed) then you need to know what the retrieval URI was in order to calculate the modified base.

The wording as given is correct. I avoided the words "may" or "should" even in lower-case intentionally, because we are talking about things that happen, not recommendations or requirements.

@Relequestual
Copy link
Member Author

But... just above the precedence diagram (that I was looking at anyway)...

The order of precedence can be thought of in terms of layers, where the innermost defined base URI has the highest precedence.

You've said outer to inner, but RFC3986 says it's inner to outer.

@handrews
Copy link
Contributor

@Relequestual yes, the innermost layer that is relevant produces the base URI. But to get there you start from the outermost layer and work your way in. You don't have to actually do that as steps, but conceptually that's how it works. How else would you interpret $id: "/foo" in the root schema?

@Relequestual
Copy link
Member Author

After discussing this with @handrews on slack, I now understand. I'll consider if there's a way to make this clearer of if I was just having a dumb day.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants