Features Upgraded hibernate 5 datastore to latest version (5.2.15)
Fixes
- Fixed bug where create-time pre-security hooks were running before any values were set.
Fixes
- Performance enhancements including caching the
Class.getSimpleName
. - Fixed bug where updatePreSecurity lifecycle hook was being called for object creation. This will no longer be true. This changes the behavior of life cycle hooks (reason for minor version bump).
Features
- Added the ability to register functions (outside entity classes) for lifecycle hook callbacks.
Fixes
- Add support for retrieving values from java
Map
types. These are still modeled as lists of key/value pairs. - Log GraphQL query bodies. Private information or anything which is not intended to be logged should be passed as a variable as variables values are not logged.
- Handle the
Transaction not closed
error on aborted response.
Fixes
- Change
PersistentResourceFetcher
constructor visibility to public in order to allow this class instantiation outside of the elide-graphql.
See: 4.0-beta-5
Fixes
- Ignore non-entity types if present in the hibernate class metadata in the hibernate stores. This can legitimately occur when tools like envers are used.
Features
- Support GraphQL batch requests.
Fixes
- Ignore provided-- but null-- operation names and variables in GraphQL requests.
- Add additional logging around exception handling.
- Don't swallow generic Exception in Elide. Log it and bubble it up to caller.
- Fix a bug where null filter expressions were possible if no filter was passed in by the user, but permission filters existed.
- Fix support for handling GraphQL variables.
- Support java.util.Date types as new built-in primitive. Expects datetime as epoch millis.
- Fixed issue with supporting variables in mutations.
- Allow for arbitrary in-transaction identifiers for upserts (treated as unique identifier for current tx only).
- Ensure GraphQLEndpoint returns GraphQL spec-compliant response.
Features
- Handle ConstraintViolationException's by extracting the first constraint validation failure.
- Include GraphQL in Elide standalone by default with ability to remove it via dependency management.
- Upgrade to the latest graphql-java version: 6.0.
Fixes
- Updated MIT attribution for portions of MutableGraphQLInputObjectType
- getRelation (single) call filters in-memory to avoid collision on multiple objects being created in the same transaction.
Features
- ChangeSpec is now passed to OnUpdate life cycle hooks (allowing the hooks to see the before & after change to a given field).
Fixes
- Root collection loads now push down security filter predicates.
- Avoid throwing exceptions that must be handled by the containing application, instead throw exceptions that will be handled directly within Elide.
- Restore OnCreatePreSecurity lifecycle hook to occur after fields are populated.
Features
- Added UPDATE operation for GraphQL.
Features
- Elide now supports GraphQL (as well as JSON-API). This feature is in beta. Read the docs for specifics. Until the artifact moves to stable, we may change the semantics of the GraphQL API through a minor Elide version release.
- The semantics of
CreationPermission
have changed and can now apply towards fields as well as entities.UpdatePermission
is never checked for newly created objects. - The semantics of
SharePermission
have changed.SharePermission
can no longer have an expression defined. It either denies permission or exactly matchesReadPermission
. - RSQL queries that compare strings are now case-insensitive. There is not currently a way to make case sensitive RSQL queries, however the RSQL spec does not provide this either. Fixes #387
Fixes
- Updated PreSecurity lifecycle hooks to run prior to inline checks like they should.
Misc
- All deprecated functions from Elide 3.0 have been removed.
FilterPredicates
have been restructure to share a commonPath
with other Elide code.
Features
- Updated interface to beta standalone application. Plans to finalize this before Elide 4.0 release.
Fixes
- Rollback relationship handling change.
- Handle ForbiddenAccess only for denied Include, instead of filtering to empty set.
Fixes
- Instead of ForbiddenAccess for denied Include, filter to empty set.
- Generate error when parsing permission expression fails.
- Add support for @Any relationships through a @MappedInterface
Features
- Add Elide standalone application library
Fixes
- Fix for issue #508
- Fix for issue #521
- Fix blog example
- Properly handle proxy beans in HQL Builder
Fixes
- Fix id extraction from multiplex transaction.
Fixes
- Use Entity name when Include is empty. Cleanup Predicate.
Features Adds support for sorting by relationship (to-one) attributes. Misc Cleanup equals code style
Misc
- Replaced deprecated Hibernate Criteria with JPQL/HQL.
Fixes
- Use inverse relation type when updating.
Fixes
- Properly handle incorrect relationship field name in Patch request instead of
Entity is null
- Properly handle invalid filtering input in HQL filtering
- Properly handle NOT in filterexpressionchecks
- Fix parameter order in commit permission check
Fixes
- Fixing regression in deferred permissions for updates
Misc
- Cleanup hibernate stores to not care about multi edit transactions
- Removed dead code from hibernate3 transaction
- Special read permissions handling of newly created objects in Patch Extension
Fixes
- Change
UpdateOnCreate
check to be anOperationCheck
.
Fixes
- Use IdentityHashMap for ObjectEntityCache
- Miscellaneous cleanup.
Fixes
- Fix exception handler to pass verbose log even with unexpected exceptions.
- Fix life cycle hooks to trigger "general" hooks even when specific field acted upon.
- Build document list for swagger endpoint at the
/
path.
Features
- Add support for FieldSetToNull check.
Features
- Add support for sorting by id values
- Implement functionality for Hibernate5 to support
EntityManager
's.
Fixes
- Account for inheritance when performing new entity detection during a PATCH Extension request.
- Upgrade examples to behave properly with latest jersey release.
- Rethrow
WebApplicationException
exceptions from error response handler.
Misc
- Always setting HQL 'alias' in FilterPredicate Constructor
Misc
- Cleanup of active permission executor
Fixes
- Fixed caching of security checks (performance optimization)
- Security fix for inline checks being deferred when used in conjunction with commit checks.
- Security fix to not bypass collection filtering for patch extension requests.
Features
- Added UUID type coercion
- Move
InMemoryDataStore
to Elide core. TheInMemoryDataStore
from theelide-datastore-inmemorydb
package has been deprecated and will be removed in Elide 4.0
Fixes
- Do not save deleted objects even if referenced as an inverse from a relationship.
Fixes
- Fix HQL for order by clauses preceded by filters.
- Remove extra
DELETE
endpoint fromJsonApiEndpoint
since it's not compliant across all JAX-RS implementations. - Add support for matching inherited types while type checking.
- Fix tests to automatically set UTC timestamp.
- Fix README information and various examples.
Misc
- Clean up Elide request handler.
Fixes
- Updated HQL query aliases for page total calculation in hibernate3 and hibernate5 data stores.
Features
- Promoted
DefaultOpaqueUserFunction
to be a top-level class - Promoted
Elide.Builder
to be a top-level classElideSettingsBuilder
- Revised datastore interface
- Removed hibernate-isms
- Made key-value persistence easier to support
- Revised lifecycle hook model
- Revised audit logger interface
- Removed all deprecated features, e.g.
- SecurityMode
any
andall
permission syntax- Required use of
ElideSettingsBuilder
- Removed
PersistenceStore
from Hibernate 5 datastore
- Made
InMemoryDataStore
the reference datastore implementation - Allow filtering on nested to-one relationships
Fixes
- Close transactions properly
- Updated all dependencies
- Fixed page totals to honor filter & security permissions evaluated in the DB.