IdP40Details
This is historical obviously, it was used during V4 planning.
Collection point for discussion around V4 scoping, before we turn this into formal JIRA issues.
Technical
- Require Java 11
- By transitive closure this means moving Guava up to 23 (where it will use Java 8 Functions)
- Spring Framework 5, SWF 2.5
- Deprecated or embrace Rhino? Or Nashorn?
- Code Coverage - we used it early in V3, Â Adopt or drop.
- Remove use of parameterized constructors - IDP-1047Getting issue details... STATUS , - IDP-1054Getting issue details... STATUS  (and others)
- Generics in API classes - IDP-316Getting issue details... STATUS  (and others)
- Deprecate SVN Resource and replace with "something" (see also here)
- Other code cleanup
Additions
Move Attribute Encoding elsewhere - IDP-1434Getting issue details... STATUS
This has a significant impact on attribute mapping (reversing SAML into IdPAttributes, since the mapping assumes that attribute have encoders and IDs and that makes it easy to map. Dictionary lookup will require either reverse lookup of eschewing this for dictionary defined attributes.
- Fix use of impl classes in deployer wiring of connectors - IDP-1179Getting issue details... STATUS
- Mixed Mode language (allow raw spring inside attribute-resolver &c, and get it parsed inside the same spring context tree) - JSE-18Getting issue details... STATUS
- Multi- Attribute sources, attribute decoding (and gateways)Â - IDP-926Getting issue details... STATUS Â and many many more
- Container work (jetty-base, windows installer,  containers, java (see also - IDP-1092Getting issue details... STATUS  and many many many moreÂ
- Type conversion in data connectors - IDP-514Getting issue details... STATUS
- Signable Config - IDP-448Getting issue details... STATUS
- pre-canned AD config file for all platforms. - IDP-1175Getting issue details... STATUS
- SOAP logout - IDP-964Getting issue details... STATUS
Changes
- ValidUntil Metadata filter - IDP-693Getting issue details... STATUS
- Old style transients in the attribute encode
- UK Federation issue?
- Data Connectors shared between users (some write back some dont) - IDP-1052Getting issue details... STATUS
- Template AttributeDefinition ignores input attributes with no values instead of failing - IDP-1362Getting issue details... STATUS
- Change default for local storage use and logout properties to true in the actual property file, though not internally
Removals
Feature Related
Remove the text-based status view and point the status command line at the metrics interface.
- Perhaps turn text view into a prettier view of more information
Language based attributes - IDP-102Getting issue details... STATUS
Configuration Related
Unless explicitly noted, everything proposed currently warns in the log.Â
- 'Legacy' (V2) relying-party.xml. and security name space
- This is currently not warned on
- The security name space is, in addition used in support of complex metadata configuration (e.g. X509 signature validation). Â We should remove this and document how to do it with attendant spring wiring.
- Removing this will allow cleanup in metadata-providers parsing (for example the <MetadataResolver> parser needs to be aware that it might be top level or it might be below a <RelyingParty>)
- Legacy Principal Connectors
- Plus a lot of upstream code.
- Currently warned on (since 3.0)
- Will this allow refactoring of the C14N code to remove hooks for legacy support?
- Legacy namespaces for Attribute Fitering and Resolution
(urn:mace:shibboleth:2.0:afp:mf:basic, urn:mace:shibboleth:2.0:afp:mf:saml, urn:mace:shibboleth:2.0:attribute:encoder,  urn:mace:shibboleth:2.0:resolver:ad, urn:mace:shibboleth:2.0:resolver:dc, urn:mace:shibboleth:2.0:resolver:pc)
- Currently warned on (since 3.3, 3.2)
- Legacy NameID-based AttributeEncoders
- Making the work context available to to Attribute Scripts
- Warned on
- Can then removeÂ
net.shibboleth.idp.attribute.resolver.ad.impl.DelegatedWorkContext
- LDAPDataConnector:
- mergeResults attributes (deprecated since V2.?)
- RDBMS
- queryUsesStoredProcedure & cacheResults attributes (deprecated in V2?)
- Attribute Filter detailsÂ
- Issuer filters (Not implemented and warned on in V3.)
- Rule & Policy References
- Attribute <Dependency>Â
-
IDP-680Getting issue details...
STATUS
 (Plus a lot of upstream code.)
- Do we want to be more radical?
- Â
/META-INF/net.shibboleth.idp/config.xml
- Old style scripted attributesÂ
edu.internet2.middleware.shibboleth.common.attribute.provider.BasicAttribute
- Old style (pre 3.3) MFA
- Will be tricky but need to warn on property and flow use if we can
- Resources and end-of-life-ing of other custom schema
- Change default audit log format
Code Related
There are many deprecated methods and classes (also Interfaces) which currently do not log warnings. Â Probably need to review and, if appropriate add warning for 3.4.
Release Notes
Since we have no doc space for 4.0 yet, tracking anything that would be an obvious "note for upgraders" here...
The Velocity 2.0 upgrade causes some template breakage, so far in two known spots:
- there's a "$" expression in attribute-release.vm that has to be converted to '$'
- the dummy URL defaults in various views has to be converted frm "#" to '#' (or anything else of course, don't imagine this really should impact sites using the software already)