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

Introspect Schema endpoint #6731

Merged
merged 12 commits into from
Feb 8, 2023
Merged

Introspect Schema endpoint #6731

merged 12 commits into from
Feb 8, 2023

Conversation

sujithvn
Copy link
Contributor

Signed-off-by: Sujith [email protected]

Resolves #6529 #6438
Impact: major
Type: feature

Issue

There is a requirement to introspect any given schema to analyse the fields available and its type with proper permission validation.

Solution

We have developed a new query end-point [introspectSchema] which accepts the schemaName and shopId and returns the schema details as a JSONObject.

Breaking changes

All the changes are new and does not impact any existing setup. But since this change will need additional permissions, it will have a mandatory migration to be done to start using this endpoint.

Testing

Unit test cases currently failing due to issues of the latest simpleSchema 3.4.0 with Jest.

@changeset-bot
Copy link

changeset-bot bot commented Dec 25, 2022

🦋 Changeset detected

Latest commit: 0e4bd77

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 3 packages
Name Type
@reactioncommerce/api-plugin-authorization-simple Minor
@reactioncommerce/api-plugin-simple-schema Minor
reaction Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

Copy link
Collaborator

@brent-hoover brent-hoover left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good to me. I wonder if we shouldn't merge this into release-5 though? Would also like Brian to look at it.

@brent-hoover brent-hoover requested a review from vanpho93 January 17, 2023 17:30
@brent-hoover
Copy link
Collaborator

@sujithvn Because this requires a mandatory migration I am changing the root branch to release-5 as merging it into trunk would cause productions services to stop

@brent-hoover brent-hoover changed the base branch from trunk to release-5 January 25, 2023 21:48
Copy link
Contributor

@aldeed aldeed left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There are a lot of additional changes in the diff due to pointing at the release branch. Those changes should be merged first or this PR should be rebased off the release branch.

I did my best to review the introspection files, though. See my inline comments.

Copy link
Contributor

@aldeed aldeed left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I didn't actually test it, but from a code review perspective this LGTM now!

Copy link
Member

@vanpho93 vanpho93 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Works on my local.

Copy link
Collaborator

@brent-hoover brent-hoover left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Excited to see this finally merged

@brent-hoover brent-hoover merged commit c600159 into release-5 Feb 8, 2023
@brent-hoover brent-hoover deleted the introspect-schema branch February 8, 2023 00:58
@github-actions github-actions bot mentioned this pull request Jun 13, 2023
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 this pull request may close these issues.

As a developer I want to be able to query for fields I can filter by on any Object
4 participants