-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merged in SHIBUI-906 (pull request #224)
SHIBUI-906 (custom relying party overrides) Approved-by: Ryan Mathis <rmathis@unicon.net>
- Loading branch information
Showing
53 changed files
with
1,312 additions
and
677 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
61 changes: 61 additions & 0 deletions
61
.../tier/shibboleth/admin/ui/controller/EntityAttributesFiltersUiDefinitionController.groovy
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
package edu.internet2.tier.shibboleth.admin.ui.controller | ||
|
||
import com.fasterxml.jackson.databind.ObjectMapper | ||
import edu.internet2.tier.shibboleth.admin.ui.jsonschema.JsonSchemaResourceLocation | ||
import edu.internet2.tier.shibboleth.admin.ui.jsonschema.JsonSchemaResourceLocationRegistry | ||
import edu.internet2.tier.shibboleth.admin.ui.service.JsonSchemaBuilderService | ||
import org.springframework.beans.factory.annotation.Autowired | ||
import org.springframework.http.ResponseEntity | ||
import org.springframework.web.bind.annotation.GetMapping | ||
import org.springframework.web.bind.annotation.RequestMapping | ||
import org.springframework.web.bind.annotation.RestController | ||
|
||
import javax.annotation.PostConstruct | ||
|
||
import static edu.internet2.tier.shibboleth.admin.ui.jsonschema.JsonSchemaLocationLookup.entityAttributesFiltersSchema | ||
import static org.springframework.http.HttpStatus.INTERNAL_SERVER_ERROR | ||
|
||
/** | ||
* Controller implementing REST resource responsible for exposing structure definition for metadata sources user | ||
* interface in terms of JSON schema. | ||
* | ||
* @author Dmitriy Kopylenko | ||
* @author Bill Smith (wsmith@unicon.net) | ||
*/ | ||
@RestController | ||
@RequestMapping('/api/ui/EntityAttributesFilters') | ||
class EntityAttributesFiltersUiDefinitionController { | ||
|
||
@Autowired | ||
JsonSchemaResourceLocationRegistry jsonSchemaResourceLocationRegistry | ||
|
||
JsonSchemaResourceLocation jsonSchemaLocation | ||
|
||
@Autowired | ||
ObjectMapper jacksonObjectMapper | ||
|
||
@Autowired | ||
JsonSchemaBuilderService jsonSchemaBuilderService | ||
|
||
@GetMapping | ||
ResponseEntity<?> getUiDefinitionJsonSchema() { | ||
try { | ||
def parsedJson = jacksonObjectMapper.readValue(this.jsonSchemaLocation.url, Map) | ||
jsonSchemaBuilderService.addReleaseAttributesToJson(parsedJson['properties']['attributeRelease']['widget']) | ||
jsonSchemaBuilderService.addRelyingPartyOverridesToJson(parsedJson['properties']['relyingPartyOverrides']) | ||
jsonSchemaBuilderService.addRelyingPartyOverridesCollectionDefinitionsToJson(parsedJson["definitions"]) | ||
return ResponseEntity.ok(parsedJson) | ||
} | ||
catch (Exception e) { | ||
e.printStackTrace() | ||
return ResponseEntity.status(INTERNAL_SERVER_ERROR) | ||
.body([jsonParseError : e.getMessage(), | ||
sourceUiSchemaDefinitionFile: this.jsonSchemaLocation.url]) | ||
} | ||
} | ||
|
||
@PostConstruct | ||
void init() { | ||
this.jsonSchemaLocation = entityAttributesFiltersSchema(this.jsonSchemaResourceLocationRegistry); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
61 changes: 61 additions & 0 deletions
61
...leth/admin/ui/jsonschema/RelyingPartyOverridesJsonSchemaValidatingControllerAdvice.groovy
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
package edu.internet2.tier.shibboleth.admin.ui.jsonschema | ||
|
||
import edu.internet2.tier.shibboleth.admin.ui.domain.frontend.EntityDescriptorRepresentation | ||
import mjson.Json | ||
import org.springframework.beans.factory.annotation.Autowired | ||
import org.springframework.core.MethodParameter | ||
import org.springframework.http.HttpInputMessage | ||
import org.springframework.http.HttpStatus | ||
import org.springframework.http.ResponseEntity | ||
import org.springframework.http.converter.HttpMessageConverter | ||
import org.springframework.web.bind.annotation.ControllerAdvice | ||
import org.springframework.web.bind.annotation.ExceptionHandler | ||
import org.springframework.web.context.request.WebRequest | ||
import org.springframework.web.servlet.mvc.method.annotation.RequestBodyAdviceAdapter | ||
|
||
import javax.annotation.PostConstruct | ||
import java.lang.reflect.Type | ||
|
||
import static edu.internet2.tier.shibboleth.admin.ui.jsonschema.JsonSchemaLocationLookup.metadataSourcesSchema | ||
|
||
/** | ||
* Controller advice implementation for validating relying party overrides payload coming from UI layer | ||
* against pre-defined JSON schema. | ||
* | ||
* @author Dmitriy Kopylenko | ||
*/ | ||
@ControllerAdvice | ||
class RelyingPartyOverridesJsonSchemaValidatingControllerAdvice extends RequestBodyAdviceAdapter { | ||
|
||
@Autowired | ||
JsonSchemaResourceLocationRegistry jsonSchemaResourceLocationRegistry | ||
|
||
JsonSchemaResourceLocation jsonSchemaLocation | ||
|
||
@Override | ||
boolean supports(MethodParameter methodParameter, Type targetType, Class<? extends HttpMessageConverter<?>> converterType) { | ||
targetType.typeName == EntityDescriptorRepresentation.typeName | ||
} | ||
|
||
@Override | ||
Object afterBodyRead(Object body, HttpInputMessage inputMessage, MethodParameter parameter, Type targetType, Class<? extends HttpMessageConverter<?>> converterType) { | ||
def relyingPartyOverrides = EntityDescriptorRepresentation.cast(body).relyingPartyOverrides | ||
def relyingPartyOverridesJson = Json.make([relyingPartyOverrides: relyingPartyOverrides]) | ||
def schema = Json.schema(this.jsonSchemaLocation.uri) | ||
def validationResult = schema.validate(relyingPartyOverridesJson) | ||
if (!validationResult.at('ok')) { | ||
throw new JsonSchemaValidationFailedException(validationResult.at('errors').asList()) | ||
} | ||
body | ||
} | ||
|
||
@ExceptionHandler(JsonSchemaValidationFailedException) | ||
final ResponseEntity<?> handleUserNotFoundException(JsonSchemaValidationFailedException ex, WebRequest request) { | ||
new ResponseEntity<>([errors: ex.errors], HttpStatus.BAD_REQUEST) | ||
} | ||
|
||
@PostConstruct | ||
void init() { | ||
this.jsonSchemaLocation = metadataSourcesSchema(this.jsonSchemaResourceLocationRegistry); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
65 changes: 65 additions & 0 deletions
65
...ain/groovy/edu/internet2/tier/shibboleth/admin/ui/service/JsonSchemaBuilderService.groovy
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
package edu.internet2.tier.shibboleth.admin.ui.service | ||
|
||
import edu.internet2.tier.shibboleth.admin.ui.configuration.CustomPropertiesConfiguration | ||
import org.springframework.beans.factory.annotation.Autowired | ||
|
||
/** | ||
* @author Bill Smith (wsmith@unicon.net) | ||
*/ | ||
class JsonSchemaBuilderService { | ||
|
||
@Autowired | ||
CustomPropertiesConfiguration customPropertiesConfiguration | ||
|
||
void addReleaseAttributesToJson(Object json) { | ||
json['data'] = customPropertiesConfiguration.getAttributes().collect { | ||
[key: it['name'], label: it['displayName']] | ||
} | ||
} | ||
|
||
void addRelyingPartyOverridesToJson(Object json) { | ||
def properties = [:] | ||
customPropertiesConfiguration.getOverrides().each { | ||
def property | ||
if (it['displayType'] == 'list' | ||
|| it['displayType'] == 'set') { | ||
property = [$ref: '#/definitions/' + it['name']] | ||
} else { | ||
property = | ||
[title : it['displayName'], | ||
description: it['helpText'], | ||
type : it['displayType']] | ||
if (it['displayType'] == 'boolean') { | ||
property['default'] = (Boolean)(it['defaultValue']) | ||
} else { | ||
property['default'] = it['defaultValue'] | ||
} | ||
} | ||
properties[(String) it['name']] = property | ||
} | ||
json['properties'] = properties | ||
} | ||
|
||
void addRelyingPartyOverridesCollectionDefinitionsToJson(Object json) { | ||
customPropertiesConfiguration.getOverrides().stream().filter { | ||
it -> it['displayType'] && (it['displayType'] == 'list' || it['displayType'] == 'set') | ||
}.each { | ||
def definition = [title : it['displayName'], | ||
description: it['helpText'], | ||
type : 'array', | ||
default : null] | ||
if (it['displayType'] == 'set') { | ||
definition['uniqueItems'] = true | ||
} else if (it['displayType'] == 'list') { | ||
definition['uniqueItems'] = false | ||
} | ||
def items = [type : 'string', | ||
minLength: 1, // TODO: should this be configurable? | ||
maxLength: 255] //TODO: or this? | ||
items.widget = [id: 'datalist', data: it['defaultValues']] | ||
|
||
definition['items'] = items | ||
json[(String) it['name']] = definition | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.