Josh Cummings 27c1ae56d4 Update :servlet:spring-boot:java:data to 7 3 månader sedan
..
gradle 1ce2c14dba Update to Gradle 8.10.2 1 år sedan
src 0776a62a4b Remove @JsonSerialize Annotations 3 månader sedan
README.adoc 9700368ca3 Simplify AuthorizeReturnObject Usage 1 år sedan
build.gradle c73ce7587d Use Method Security Enhancements 1 år sedan
gradle.properties 27c1ae56d4 Update :servlet:spring-boot:java:data to 7 3 månader sedan
gradlew e18c23b523 Add Spring Boot Data Sample 1 år sedan
gradlew.bat e18c23b523 Add Spring Boot Data Sample 1 år sedan
settings.gradle 50ffc04d54 Make Projects Individually Runnable 1 år sedan

README.adoc

= Spring Data Sample

After running this sample like so:

.Java
[source,java,role="primary"]
----
./gradlew :bootRun
----

Then you can query for messages using `luke/password` and `rob/password`.

Because the domain objects are secured, you will see a subset of fields with `luke`.

For example, querying `/` with `luke`, you'll see:

```json
...
{
"created": "2014-07-12T16:00:00Z",
"id": 112,
"summary": "Is this secure?",
"text": "This message is for Luke",
"to": {
"email": "luke@example.com",
"id": "luke",
"password": "password"
}
}
...
```

However, with `rob`, you'll also see `firstName` and `lastName` like so:

```json
...
{
"created": "2014-07-12T04:00:00Z",
"id": 102,
"summary": "Is this secure?",
"text": "This message is for Rob",
"to": {
"email": "rob@example.com",
"firstName": "Rob",
"id": "rob",
"lastName": "Winch",
"password": "password"
}
}
...
```

Read more about the https://docs.spring.io/spring-security/reference/servlet/authorization/method-security.html#authorize-object[`@AuthorizeReturnObject`] and https://docs.spring.io/spring-security/reference/servlet/authorization/method-security.html#fallback-values-authorization-denied[]`@DeniedHandler`] in the Spring Security Reference.