-
Notifications
You must be signed in to change notification settings - Fork 356
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
Validator::validate() doesn't correctly apply schema ID when the schema is an assoc array (works when an object) #767
Comments
This comment was marked as outdated.
This comment was marked as outdated.
Hi @dkarlovi In willing to check this out but would need a little bit more context. Could you share the code in order te reproduce this issue? Did you also check with the examples from the wiki? I guess the https://github.com/jsonrainbow/json-schema/wiki/Validate-using-an-inline-schema might best fit your case? |
Hello, this is just validating a payload against a schema, but the schema is built as building blocks so being able to load relative schemas to compose into a larger more complex one is key. I can send the code snippet, but there's nothing unexpected, the schema I'm using is just composed of smaller schemas in files next to it. This worked as shown in 5.x, it works in 6.x with the path change and the snippet shown, even though I think the path should be relative to the current schema, which 5.x did but 6.x does not. |
@dkarlovi I think the code snippet can be very helpful in under standing the issue/impact. It is also to assist in the most effective way. This project is open source and is powered by people putting in their time for free. This repo has a Bowtie report which points out that JSON Schema test suite with the references are working. This just makes me think since it worked for you in |
@DannyvdSluijs yes, I understand. 👍 I'll try to create a minimal reproducer. |
@DannyvdSluijs found the issue: I was passing my schema as an assoc array. When I pass it as an object, it works. This fails as is: <?php
use JsonSchema\Constraints\Constraint;
use JsonSchema\Validator;
require_once __DIR__ . '/vendor/autoload.php';
$data = new stdClass;
$data->results = [];
validate($data, __DIR__.'/tests/schemas/suggest/empty.schema.json');
function validate(array|object $data, string $path): void
{
// switch second arg to false to have it work
$schema = json_decode(file_get_contents($path), true);
$validator = new Validator();
$response = $validator->validate(
$data,
$schema,
Constraint::CHECK_MODE_VALIDATE_SCHEMA & Constraint::CHECK_MODE_APPLY_DEFAULTS
);
if ($response === 0) {
return;
}
var_dump($validator->getErrors());
} It only checks for json-schema/src/JsonSchema/Validator.php Lines 61 to 65 in 3772314
|
@dkarlovi great that you found the cause. Secondly, I would like to first understand why this change was added tot v6 in the first place before starting to add code in order to support associative array schemas. As raised in other issues as well, associative arrays is something very specific to PHP and no other programming language. |
@DannyvdSluijs this is probably some misunderstanding? The patch doesn't introduce support for accepting schemas as assoc arrays: it was always supported, you even have a test to make sure it works: json-schema/tests/ValidatorTest.php Lines 10 to 19 in 3772314
This patch is fixing the regression in 6.x which broke this specific thing with not applying the schema ID correctly from an assoc array.
If so, the validate() method should clearly state so, currently it does not. |
Well that helps a lot in clarifying things. I'll look into it. |
Ive been diving into the git blame and history. While doing so I was able to find #389 which actually introduces the code in Since the suggested change is only adding the reading of the Seeing the history, the intention and the internal casting of schema's to objects I would lean towards the "Schema should be object" thought. Which then bring back your point that it currently isn't correctly stated by the lib. This might be the alternative approach to explore. I'm very eager to see what @erayd thinks about this case and see if he is available for a brief answer or more. @dkarlovi I also wanted to point out that you're still helping out. I noticed you're a First Time Contributor to the project and the amount of information as well as the quick turn around with information is helping us here. So please bear with us in finding the correct approach and seeing how we move forward with this and #769 |
@DannyvdSluijs Happy to dig back into this, although it was over seven years ago - definitely going to be stretching the memory a bit on this one! What is it specifically you're wanting me to look at? The OP report, or are you wanting some clarification on the historical changes you've linked above? |
@DannyvdSluijs from my POV, the solution is quite clear:
The proposed patch fixes this feature and removes the regression made in the 5.x -> 6.x transition. The patch should get accepted (or an equivalent patch be made) even if the feature is to be deprecated in 6.x and removed in 7.x, that consideration (which, again, I mostly agree with) should be made in a totally separate PR. Otherwise, you're keeping a fully supported feature broken for no good reason.
isn't a good argument, it's broken now. |
@DannyvdSluijs did you get a chance to consider this topic yet? #769 is ready for review IMO. |
@digitalkaoz I didn’t find the time yet sadly. Thanks for this gentle nudge. I’m currently out with the flu but will see if I can pick this up somewhere next weeks. |
Update: this is due to the validator not applying the schema ID correctly, it only handles an object, not an assoc array.
I have this schema:
With the update to 6.x, this fails with
I guess the schemaless ref is now interpreted as internal in some way?
If I modify my schema as so
Now it says
which means it understands it needs to read the file locally. For some reason, it doesn't read the file even though it exists.
If I add
to strip
file://
before here, it works.json-schema/src/JsonSchema/Uri/Retrievers/FileGetContents.php
Line 36 in 3772314
Should this happen conditionally, if there's a
file://
prefix, strip it? There's somefile://
special handling a little later in the function, but it's already too late because an error was raised.The text was updated successfully, but these errors were encountered: