-
-
Notifications
You must be signed in to change notification settings - Fork 173
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
Selecting specific .fields in query with .join/.with results in FATAL ERROR #733
Comments
@mynonaGithub you're mixing eager loading and joining. The crash you're getting is because you're eager loading the relation but then telling it to only select a subset of fields. That won't work because the eager loader needs to fully construct the model. What you should do is JOIN and then get the joined model out as described in the docs. That should work when specifying the fields |
can you provide a code example of a join with only a subset of the fields? i tried joins as you can see in the provided code example but still all fields were part of the result set. when i researched this topic i found out that this issue is quite a often discussed problem. the way i solved it was to create additional (public) models with the reduced subset of fields for the queries but this is a really bad (redundant) approach. |
let result: EventLoopFuture<[Article]> = Article
.query(on: req.db)
.join(Author.self, on: \Article.$author.$id == \Author.$id, method: .inner)
.sort(\.$date, .descending) // sort articles by date
.field(\.$title)
.field(Author.self, \.$first_name)
.all() Note that using a |
Issue
Problem:
Expected behavior:
Even when I apply a JOIN operation I am able to define what fields should be included in the result set.
Why is this important?
Optimize data exchange between client and server.
The second reason is security related: We should not expose all fields in case some contain non public information.
Versions
Vapor: 4.51.0
Fluent: 4.4.0
Leaf: 4.1.3
Database driver: Fluent-mysql-driver 4.0.1
Operating system: MacOS Monterey
MySQL: 8.0.27
Concrete example
PARENT – CHILD join
SIBLING join
This code results in the correct result:
But as soon as the fields are specified the result is a fatal error:
If it would be done via a raw SQL query this is the desired outcome:
Result of the raw SQL query:
The text was updated successfully, but these errors were encountered: