Skip to content

Latest commit

 

History

History
386 lines (317 loc) · 17.4 KB

CHANGELOG.md

File metadata and controls

386 lines (317 loc) · 17.4 KB

Changelog

8.5.0 (2025-01-08)

  • openid connect backend: Add OAuth2/OIDC backend based on idpy-oidc (new extra requirement idpy_oidc_backend to pull the library dependecy)
  • apple backend: Rework the Apple backend to be based on the generic OpenIDConnectBackend and fix the userinfo loading
  • Restructure fatal error messages to redirect to generic error page when an errors occur
  • Allow multiple values for the "resource" query param
  • Fix checks for missing state from cookie and missing relay state
  • Allow loading of tuples from YAML configs
  • docs: minor fixes

8.4.0 (2023-06-11)

  • Make cookie parameters configurable
  • Avoid setting duplicate set-cookie headers
  • Complete the support for the mdui:UIInfo element
  • satosa-saml-metadata: make signing optional
  • metadata_creation: for SAML backend, use sp.config to render metadata
  • tests: update markers of supported Python versions
  • deps: move away from pkg_resources when deriving the package version at runtime

8.3.0 (2023-06-08)

  • FilterAttributeValues plugin: add new filter types shibmdscope_match_scope and shibmdscope_match_value; add tests
  • FilterAttributeValues plugin: add example rules for saml-subject-id and saml-pairwise-id
  • FilterAttributeValues plugin: add example rules enforcing controlled vocabulary for eduPersonAffiliation and eduPersonScopedAffiliation attributes
  • DecideBackendByRequester plugin: add default_backend setting; add tests; minor fixes
  • opend_connect backend: use PyoidcSettings class to configure pyoidc/oic based clients
  • ping frontend: minor adjustments and fixes for interface compliance
  • tests: update code to use matchers API to mock responses
  • examples: improve configuration readability of the primary-identifier plugin
  • examples: minor fixes and enhancements for ContactPerson examples for SAML backend and frontend

8.2.0 (2022-11-17)

  • attribute_authorization: new configuration options force_attributes_presence_on_allow and force_attributes_presence_on_deny to enforce attribute presence enforcement
  • saml2 backend: new configuration option acs_selection_strategy to support different ways of selecting an ACS URL
  • saml2 backend: new configuration option is_passive to set whether the discovery service is allowed to visibly interact with the user agent.
  • orcid backend: make the name claim optional
  • apple backend: retrieve the name of user when available.
  • openid_connect frontend: new configuration option sub_mirror_subject the set sub to mirror the subject identifier as received in the backend.
  • openid_connect frontend: check for empty db_uri before using it with a storage backend
  • attribute_generation: try to render mustach tempate only on string values
  • logging: move cookie state log to the debug level
  • chore: fix non-formatting flake8 changes
  • tests: remove dependency on actual MongoDB instance
  • build: update links for the Docker image on Docker Hub
  • docs: properly document the name_id_format and name_id_policy_format options
  • docs attribute_generation: correct example configuration
  • docs: fix mailing list link.
  • docs: fix typos and grammar

8.1.1 (2022-06-23)

  • OIDC frontend: Set minimum pyop version to v3.4.0 to ensure the needed methods are available
  • docs: Fix orcid mapping in example internal_attributes

8.1.0 (2022-05-06)

  • OIDC frontend: support stateless code flow
  • OIDC frontend: support Redis and session expiration
  • orcid backend: allow family-name to be optional
  • docs: add references to external contributions
  • docs: update structure

8.0.1 (2022-02-22)

  • Reinitialize state if error occurs while loading state
  • VirtualCoFrontend: Expose metadata endpoint and fix duplicate entity ids with multiple backends
  • saml-backend: Allow request micro-services to affect the authn-context-class-ref
  • saml-backend: Keep the last authority from the authenticating authority list
  • minor fixes to the Apple and GitHub backends
  • micro_services: example config for attribute_policy
  • deps: bump minimum pyop version to 3.3.1
  • docs: fixes for example files and config options

8.0.0 (2021-09-07)

This is a breaking release, if you were using the openid_connect frontend. To keep compatibility:

  1. Install the proxy with pip install satosa[pyop_mongo] in order to fetch the right dependencies.
  2. If you were not using the client_db_path option then set the new option client_db_uri to the value of db_uri.
  • The internal data now hold the authenticating authority as part of the AuthenticationInformation object (satosa.internal::AuthenticationInformation::authority).
  • The Context object now holds a dictionary of query string params (context.qs_params).
  • The Context object now holds a dictionary of http headers (context.http_headers).
  • The Context object now holds a dictionary of server headers (context.server_headers).
  • The Context object now holds the request method (context.request_method).
  • The Context object now holds the request uri (context.request_uri).
  • The Context object now holds a dictionary of http headers.
  • frontends: the openid_connect frontend has a new configuration option signing_key_id to set the kid field on the jwks endpoint.
  • frontends: the openid_connect frontend dependency pyop has been updated to work with both Redis and MongoDB. This changed how its dependencies are set. This is reflected in this package's new extras that can be set to pyop_mongo (to preserve the previous behaviour), or pyop_redis.
  • frontends: the openid_connect frontend filters out unset claims.
  • frontends: the openid_connect frontend has a new option extra_id_token_claims to define in the config per client which extra claims should be added to the ID Token to also work with those clients.
  • frontends: the openid_connect frontend has a new option client_db_uri to specify a database connection string for the client database. If unset, client_db_path will be used to load the clients from a file. Previously, the option db_uri was used to set the client database string. If you were relying on this behaviour, add the client_db_uri option with the same value as db_uri.
  • frontends: document the client_db_path option for openid_connect
  • frontends: the openid_connect frontend has a new configuration option id_token_lifetime to set the lifetime of the ID token in seconds.
  • frontends: the saml2 frontend has a new option enable_metadata_reload to expose an endpoint (/<module_name>/reload-metadata) that allows external triggers to reload the frontend's metadata. This setting is disabled by default. It is up to the user to protect the endpoint if enabled. This feature requires pysaml2 > 7.0.1
  • backends: the saml2 backend derives the encryption keys based on the encryption_keypairs configuration option, otherwise falling back to the key_file and cert_file pair. This is now reflected in the internal pysaml2 configuration.
  • backends: the saml2 backend sp property is now of type saml2.client::Saml2Client instead of saml2.client_base::Base. This allows us to call the higer level method saml2.client::Saml2Client::prepare_for_negotiated_authenticate instead of saml2.client_base::Base::create_authn_request to properly behave when needing to sign the AuthnRequest using the Redirect binding.
  • backends: the saml2 backend has a new option enable_metadata_reload to expose an endpoint (/<module_name>/reload-metadata) that allows external triggers to reload the backend's metadata. This setting is disabled by default. It is up to the user to protect the endpoint if enabled. This feature requires pysaml2 > 7.0.1
  • backends: new ReflectorBackend to help with frontend debugging easier and developing quicker.
  • backends: the saml2 backend has a new configuration option send_requester_id to specify whether Scoping/RequesterID element should be part of the AuthnRequest.
  • micro-services: new DecideBackendByTargetIssuer micro-service, to select a target backend based on the target issuer.
  • micro-services: new DiscoToTargetIssuer micro-service, to set the discovery protocol response to be the target issuer.
  • micro-services: new IdpHinting micro-service, to detect if an idp-hinting feature has been requested and set the target entityID. Enabling this micro-service will result in skipping the discovery service and using the specified entityID as the IdP to be used. The IdP entityID is expected to be specified as a query-param value on the authentication request.
  • micro-services: new AttributePolicy micro-service, which is able to force attribute policies for requester by limiting results to a predefined set of allowed attributes.
  • micro-services: the PrimaryIdentifier micro-service has a new option replace_subject_id to specify whether to replace the subject_id with the constructed primary identifier.
  • micro-services: PrimaryIdentifier is set only if there is a value.
  • micro-services: AddSyntheticAttributes has various small fixes.
  • micro-services: ScopeExtractorProcessor can handle string values.
  • dependencies: the pystache package has been replaced by chevron, as pystache seems to be abandoned and will not work with python v3.10 and setuptools v58 or newer. This package is a dependency of the satosa.micro_services.attribute_generation.AddSyntheticAttributes micro-service.
  • tests: MongoDB flags have been updated to cater for deprecated flags.
  • docs: updated with information about the newly added micro-services.
  • docs: various typo fixes.
  • docs: various example configuration fixes.

7.0.3 (2021-01-21)

  • dependencies: Set minimum pysaml2 version to v6.5.1 to fix internal XML parser issues around the xs and xsd namespace prefixes declarations

7.0.2 (2021-01-20) - Security release for pySAML2 dependency

  • Add RegexSubProcessor attribute processor
  • Fix SAMLVirtualCoFrontend metadata generation
  • frontends: Deprecate the sign_alg and digest_alg configuration options on the saml2 frontend. Instead, use the signing_algorithm and digest_algorithm configuration options under the service/idp configuration path (not under service/idp/policy/default)
  • backends: New backend to login with Apple ID
  • dependencies: Set minimum pysaml2 version to v6.5.0 to make sure we get a version patched for CVE-2021-21238 and CVE-2021-21239
  • build: Fix the CI base image
  • tests: Fix entity-category checks
  • docs: Document the sub_hash_salt configuration for the OIDC frontend
  • examples: Add entityid_endpoint to the saml backend and frontend configuration
  • examples: Fix the SAMLVirtualCoFrontend example configuration

7.0.1 (2020-06-09)

  • build: fix the CI release process

7.0.0 (2020-06-09)

  • Make the AuthnContextClassRefs available through the context
  • Extend YAML parsing to understand the !ENV and !ENVFILE tags, that read values or file contents from the environment
  • Add satosa.yaml module to handle YAML parsing
  • BREAKING: Remove previously deprecated configuration options:
    • hash: use the hasher micro-service instead
    • USER_ID_HASH_SALT: use the hasher micro-service instead
  • BREAKING: Remove previously deprecated classes:
    • SAMLInternalResponse: use satosa.internal.InternalData instead
    • InternalRequest: use satosa.internal.InternalData instead
    • InternalResponse: use satosa.internal.InternalData instead
    • UserIdHashType: use the hasher micro-service instead
    • UserIdHasher: use the hasher micro-service instead
  • BREAKING: Remove previously deprecated functions:
    • hash_attributes: use the hasher micro-service instead
    • oidc_subject_type_to_hash_type: use satosa.internal.InternalData.subject_type directly
    • saml_name_id_format_to_hash_type: use satosa.internal.InternalData.subject_type directly
    • hash_type_to_saml_name_id_format: use satosa.internal.InternalData.subject_type directly
  • BREAKING: Remove previously deprecated modules:
    • src/satosa/internal_data.py
  • BREAKING: Remove previously deprecated properties of the saml2.internal.InternalData class:
    • name_id: use use subject_id instead,
    • user_id: use subject_id instead,
    • user_id_hash_type: use subject_type instead,
    • approved_attributes: use attributes instead,
  • The cookie is now a session-cookie; To have the the cookie removed immediately after use, the CONTEXT_STATE_DELETE configuration option should be set to True
  • Create dedicated module to handle the proxy version
  • Set the logger to log to stdout on DEBUG level by default
  • Cleanup code around the wsgi calls
  • micro-services: separate core from micro-services; drop checks for micro-services order; drop references to the Consent and AccountLinking micro-services
  • micro-services: generate a random name for the pool name when REUSABLE client strategy is used for the ldap-attribute-store micro-service.
  • docs: improve example proxy configuration
  • docs: minor fixes/typos/etc
  • build: update CI to use Travis-CI stages
  • build: run tests for Python3.8
  • build: tag docker image by commit, branch, PR number, version and "latest"

6.1.0 (2020-02-28) - Security release for pySAML2 dependency

  • Set the SameSite cookie attribute to "None"
  • Add compatibility support for the SameSite attribute for incompatible browsers
  • Set the Secure attribute of the cookie, always
  • Set minimum pysaml2 version to make sure we get a version patched for CVE-2020-5390
  • Fix typos and improve documetation
  • Set the session-id when state is created
  • Use LinkedIn API v2

6.0.0 (2019-12-17)

  • properly support mutliple values when converting internal attributes to OIDC claims. For all claims other than the ones define in OIDC core specification, the same values as the ones that have been set in the internal representation will be returned.
  • improve log handling
  • micro-services: Better handling of single-value attribute by LdapAttributeStore

5.0.0 (2019-11-07)

Notice: Support for python 3.5 has been dropped.

  • Add a dict-like interface to the internal objects
  • Fix escaped chars in RegEx strings
  • tests: fix warnings
  • build: drop support for python 3.5
  • misc: typos and formatting

4.5.0 (2019-11-05)

  • add options in saml-frontend to encrypt assertion from AuthnResponse
  • use saml2.extension.mdui in place of saml2.extension.ui
  • improve log handling
  • remove logging around state-cookie loading
  • print the absolute path of the configuration when failing to read it
  • error out if no backend or frontend is configured
  • frontends: oidc: support extra_scopes
  • frontends: SAMLVirtualCoFrontend: add attribute scope
  • backends: orcid: add state parameter to authorization request
  • backends: orcid: fix read address attribute
  • backends: orcid: fix authorization token header
  • backends: bitbucket: new oauth2 backend
  • backends: facebook: add more configuration options
  • micro-services: improve the ldap_attribute_store
  • build: refactor the start.sh docker script
  • build: improve travis stages for new releases
  • docs: add sequence diagrams for SAML-to-SAML flow
  • docs: improve configuration docs
  • docs: improve micro-service docs
  • misc: correct typos

4.4.0 (2019-07-09)

Trigger new version build to automatically upload to PyPI, docker hub and GitHub.

  • Fix travis CI/CD configuration

4.3.0 (2019-07-09)

Trigger new version build to automatically upload to PyPI and docker hub.

  • Fix travis CI/CD configuration

4.2.0 (2019-07-09)

Trigger new version build to automatically upload to PyPI and docker hub.

  • Fix travis CI/CD configuration
  • Fix typo in release instructions

4.1.0 (2019-07-09)

Trigger new version build to automatically upload to PyPI and docker hub.

  • Add release instructions

4.0.0 (2019-07-09)

  • Remove the warning filter; users must set the filter themselves
  • Refactor internal data representation
    • Deprecate satosa.internal_data module
    • Use satosa.internal module
    • Store the NameID value as satosa.internal.InternalData.subject_id
    • Store the NameID nameid-format as satosa.internal.InternalData.subject_type
  • Deprecate hash configuration option set in internal attributes
  • Deprecate USER_ID_HASH_SALT configuration option
  • Remove attribute hashing
  • Deprecate UserIdHasher classes
  • Deprecate UserIdHashType enum
  • Support SAML NameID nameid-format emailAddress and unspecified
  • Accept authn response with no NameID element
  • Reset state after cookie decryption failure
  • Add API to load data in Context object
    • KEY_BACKEND_METADATA_STORE
    • KEY_TARGET_ENTITYID
    • KEY_FORCE_AUTHN
    • KEY_MEMORIZED_IDP
  • Add initial eIDAS support
  • Support memoization of IdP selection when using MDQ
  • plugins: Warn when AssertionConsumerService binding is HTTP-Redirect in the saml2 backend
  • plugins: Add SAMLVirtualCoFrontend frontend
  • plugins: Add extra_scopes configuration to support multiple scopes
  • plugins: Use the latest pyop version
  • plugins: Add primary identifier micro-service
  • plugins: Misc fixes and improvents for LDAP attribute store micro-service
  • plugins: Add verify_ssl option to OIDC backend
  • plugins: Add hasher micro-service
  • plugins: Add support in frontend for common domain cookie
  • plugins: Add Ping frontend
  • plugins: Fixes for the account linking micro-service
  • tests: Misc improvements
  • tests: Use latest pytest
  • build: Set supported python versions to py35 py36 py37 and pypy3
    • Dropped support for py34
  • build: Set minimum supported pysaml2 version
  • docs: Instructions to use with Apache and mod_wsgi
  • docs: Add satosa-users mailing list information
  • docs: Add ui_info in example configs
  • docs: Add GÉANT contribution notice
  • docs: Misc typos and improvements