All notable changes to this project will be documented in this file. See Conventional Commits for commit guidelines.
v2.5.0 (2025-01-20)
- add repo callback to disable atomic actions and error expressions (#464)
-
generate a repo when selecting one
-
handle regex match correctly (#460)
-
use prettier SQL in
Ash.calculate
-
add
c:AshPostgres.Repo.default_constraint_match_type
-
mark ash_raise_error as STABLE
v2.4.22 (2025-01-13)
-
inner join bulk operations if distinct? is present
-
fully specificy synthesized indices from multi-resource tables
v2.4.21 (2025-01-06)
-
filter query by source record ids when lateral joining
-
don't use symlinked app dir for migration's path
v2.4.20 (2024-12-26)
- use passed in version of postgres when modifying existing repo
v2.4.19 (2024-12-26)
- ensure there is always at least one upsert field so filter is run
-
better min_pg_version when modifying a repo
-
automatically set
min_pg_version
where possible -
use a notice to suggest configuring
min_pg_version
v2.4.18 (2024-12-20)
- handle double select issue
-
make igniter optional
-
make tsvector type selectable
v2.4.17 (2024-12-16)
-
Fix query for metadata on foreign keys and fix duplicate references being produced (#444)
-
alter resource generation query to go to the source pg_constraints table instead of to the view to fetch constraint data (#443)
v2.4.16 (2024-12-12)
-
properly support expr errors in bulk create
-
only build references for belongs_to relationships
- add postgres_reference_expr callback (#438)
v2.4.15 (2024-12-06)
-
split off varchar options from index
-
don't attempt to use non-existent relationship
-
handle manual/no_attributes? relationships in lateral join logic
-
don't use
priv
configuration for snapshot_path
- update sql implementation for type determination
v2.4.14 (2024-11-27)
- pass AST to deal with stupid igniter behavior
v2.4.13 (2024-11-26)
- [
mix ash.migrate
] honor thesnapshots_only
option
-
[
mix ash.migrate
] honor repo configuration in migration generator -
[
mix ash.codegen
] honor:priv
in migration generator, and make it explicitly configurable -
[
mix ash_postgres.install
] don't generate task aliases that run seeds in test
v2.4.12 (2024-10-30)
-
[query builder] don't double add distinct clauses
-
[
AshPostgres.DataLayer
] don't usecast
for changes
-
[
AshPostgres.Repo
] setprefer_transaction?
to false in generated repos -
[
AshPostgres.DataLayer
] support prefer_transaction?
v2.4.11 (2024-10-23)
- [upserts] ensure repo_opts is passed through to
repo.all/2
v2.4.10 (2024-10-23)
- Patch of GHSA-hf59-7rwq-785m Empty, atomic, non-bulk actions, policy bypass for side-effects vulnerability.
-
[upserts] run any query that could produce errors when performing atomic upgrade
-
[multitenant migrations] race condition compiling migrations when concurrently creating new tenants (#406)
v2.4.9 (2024-10-16)
- [
mix ash_postgres.gen.resources
] fix resource generator task & tests
v2.4.8 (2024-10-11)
- [migration generator] use the
name
parameter when generating migrations
v2.4.7 (2024-10-10)
- [upserts] adapt to fixes and optimizations around skipped upserts in ash core
v2.4.6 (2024-10-07)
- [
mix ash_postgres.install
] with--yes
assume oldest version
v2.4.5 (2024-10-06)
- [upserts] ensure upsert fields are uniq
-
[
mix ash_postgres.install
] detect 1 arg repo use in installer -
[
AshPostgres.Repo
] support to_ecto(%Ecto.Changeset{}) and from_ecto(%Ecto.Changeset{}) (#395)
v2.4.4 (2024-09-29)
- [atomic updates] handle atomic array operations
v2.4.3 (2024-09-27)
- [
mix ash_postgres.gen.resources
] support pg <= 14 in resource generator, and update tests
v2.4.2 (2024-09-24)
-
[migration generator] typo of
biging
->bigint
-
[migration generator] altering attributes not properly generating foreign keys in some cases
-
[
mix ash_postres.install
] use correct module name in theDataCase
moduledocs. (#393) -
[migration generator] trim input before passing to
String.to_integer/1
. (#389)
-
[
mix ash_postgres.install
] add--repo
option to installer, and warn on clashing existing repo -
[
mix ash_postgres.install
] prompt for minimum pg version -
[
mix ash_postgres.install
] adjust mix task aliases to be used withash_postgres
-
[migration generator] set a name for generated migrations
v2.4.1 (2024-09-16)
-
[bulk updates] ensure that returning is never an empty list
-
[
mix ash_postgres.gen.resources
] match on table schema as well as table name
v2.4.0 (2024-09-13)
- [
AshPostgres.Ltree
] Implement Ltree Type (#385)
-
[migration generator] remove LEAKPROOF from function to prevent migration issues
-
[
Ash.Changeset
] support upcomingaction_select
options -
[
mix ash.install
] ensureRepo
is started after telemetry in igniter installer
v2.3.1 (2024-09-05)
-
[
mix ash_postgres.gen.migrations
] better imported index names -
[
mix ash_postgres.gen.migrations
] add--extend
option, forwarded to generated resource
v2.3.0 (2024-09-05)
- [
mix ash_postgres.gen.resources
] Addmix ash_postgres.gen.resources
for importing tables from an existing database as resources
v2.2.5 (2024-09-04)
- [
AshPostgres.DataLayer
] support ash main upsert_condition logic
v2.2.4 (2024-09-03)
-
[
AshPostgres.DataLayer
] ensure default bindings are present on data layer -
[
AshPostgres.DataLayer
] properly traverse newtypes when determining types
v2.2.3 (2024-08-18)
- [
mix ash_postgres.install
] was not adding ash_functions/min_pg_version
v2.2.2 (2024-08-17)
- [
mix ash_postgres.install
] properly handle new igniter installer functions
v2.2.1 (2024-08-16)
- [
AshPostgres.DataLayer
] set a proper default forskip_unique_indexes
- [
mix ash_postgres.install
] includemin_pg_version
in new generators
v2.2.0 (2024-08-13)
- [
AshPostgres.Repo
] removeAgent
"convenience" for determining min pg version
We need to require that users provide this function. To that end we're adding a warning in a minor release branch telling users to define this. The agent was acting as a bottleneck that all queries must go through, causing nontrivial performance issues at scale.
- [upserts] handle filter condition on create (#368)
v2.1.19 (2024-08-12)
-
[ecto compatibility] we missed a change when preparing for ecto 3.12 parameterized type changes
-
[exists aggregates] update ash_sql for exists aggregate fixes
v2.1.18 (2024-08-09)
- [
ash_postgres.gen.migration
] dynamically select and allow setting a repo
- [
ash_sql
] update ash & ash_sql for various fixes
-
[updates] don't overwrite non-updated fields on update
-
[
mix ash_postgres.generate_migrations
] ensure app is compiled before using repo modules
- [
ash_sql
] update ash_sql for cleaner queries
v2.1.15 (2024-07-23)
- [query building] use a subquery if any exists aggregates are in play
v2.1.14 (2024-07-22)
- [multitenancy] properly convert tenant to string when building lateral join
v2.1.13 (2024-07-22)
- [atomic validations] update ash & ash_sql for fixes, test atomic validations in destroys
v2.1.12 (2024-07-19)
- [
mix ash_postgres.install
] properly add prod config in installer
-
[
mix ash_postgres.install
] properly perform or don't perform configuration modification code -
[
has_many
relationships] allow non-unique has_many source_attributes (#355)
-
[
mix ash_postgres.install
] prepend:postgres
to section order -
[
mix ash.patch.extend
] pluralize table name in extender
v2.1.10 (2024-07-18)
- [lateral joins] allow non-unique has_many source_attributes (#355)
v2.1.9 (2024-07-18)
- [
mix ash.gen.resource
] pluralize table name in extender
-
[aggregates] update ash_sql & ash for include_nil? fix (and test it)
-
[aggregates] ensure synthesized query aggregates have context set
-
[installers] update igniter dependencies
-
[expressions] add
binding()
expression, for referring to the current table
-
update to latest ash version for aggregate fix
-
update ash_sql for include_nil? fix and test it
-
ensure synthesized query aggregates have context set
-
update ash/igniter dependencies
-
add
binding()
expression -
use latest type casting code from ash
-
support new type determination code
v2.1.6 (2024-07-16)
- ensure synthesized query aggregates have context set
-
update ash/igniter dependencies
-
add
binding()
expression -
use latest type casting code from ash
-
support new type determination code
v2.1.5 (2024-07-15)
- ensure synthesized query aggregates have context set
-
[
Ash.Expr
] addbinding()
expression to refer to current table -
[
Ash.Expr
] use latest type casting code from ash
v2.1.4 (2024-07-14)
- [
Ash.Expr
] use latest type casting code from ash
v2.1.3 (2024-07-14)
- [
Ash.Expr
] support new type determination code
v2.1.2 (2024-07-13)
- [query builder] update ash & improve type casting behavior
- [mix ash_postgres.install] properly interpolate module names in installer
- [AshPostgres.DataLayer] add
storage_types
configuration (#342) - [generators] add
mix ash_postgres.install
(mix igniter.install ash_postgres
)
-
[AshPostgres.DataLayer] ensure that
from_many?
relationships in lateral join have a limit applied -
[migration generator] properly delete args passed from migrate to ecto
-
[Ash.Type.UUIDv7] add support for
:uuid_v7
type (#333) -
[migration generator] order keys in snapshot json (#339)
v2.0.12 (2024-06-20)
- [migration generator] only add references indexes if they've changed
v2.0.11 (2024-06-19)
-
[AshPostgres.DataLayer] rework expression type detection
-
[migration generator] ensure index keys are atoms in generated migrations (#332)
v2.0.10 (2024-06-18)
-
[AshPostgres.DataLayer] update ash_sql to fix query generation issues
-
[migration generator] ensure that parens are always added to calculation generated SQL
-
[migration generator] properly get calculation sql
-
[AshPostgres.DataLayer] better type handling using new type inference
-
[identities] identities w/ calculations and where clauses in upserts
v2.0.9 (2024-06-13)
- [migration generator] autogenerate index in references (#321)
-
[AshPostgres.DataLayer] fix invalid select on sorting by some calculations
-
[AshPostgres.DataLayer] fix error message displaying in identity verifier
-
[lateral joining] ensure that context multitenancy is properly applied to lateral many-to-many joins
-
[migration generator] don't assume old snapshots have
index?
key for attributes -
[ash.rollback]
list_tenants
->all_tenants
-
[ash.rollback] when checking for roll back-able migrations, only check
Path.basename
- [migration generator] don't sort identity keys.
v2.0.8 (2024-06-06)
-
[fix] update ash_sql and fix issues retaining lateral join context
-
[fix] ensure that all current attribute values are selected on bulk update shifted root query
-
[atomic updates] properly support aggregate references in atomic updates
-
[migration generator] ensure that identities are dropped when where/nils_distinct? are changed
-
[migration generator] ensure that
where
is wrapped in parenthesis -
[ecto compatibility] support old/new parameterized type format
-
[identities] require clarification of index names > 63 characters
-
[mix ash_postgres.squash_snapshots] add
ash_postgres.squash_snapshots
mix task (#302)
- [idenities] update
ash
and support newidentity
features
v2.0.4 (2024-05-23)
[updates] ensure update's reselect all changing values
v2.0.3 (2024-05-22)
[updates] handle complex maps/list on update
[Ash.Query] support anonymous aggregates in sorts
[exists] ensure parent_as bindings properly reference binding names
[migration generator] add and remove custom indexes in tandem properly
[references] support on_delete: :nilify
for specific columns (#289)
v2.0.2 (2024-05-15)
-
[update_query/destroy_query] rework the update and destroy query builder to support multiple kinds of joining
-
[mix ash_postgres.migrate] remove duplicate repo flags (#285)
-
[Ash.Error.Changes.StaleRecord] ensure filter is included in stale record error messages we return
-
[AshPostgres.MigrationGenerator] properly parse previous version from migration generation
- [AshPostgres.MigrationGenerator] properly parse previous version of custom extensions when generating migrations
The changelog is starting over. Please see /documentation/1.0-CHANGELOG.md
in GitHub for previous changelogs.
- [Ash.Type.UUID] change defaults in migrations for uuids to
gen_random_uuid()
- [Ash.Type.DateTime] Use UTC for default generated timestamps (#131)
- [AshPostgres.DataLayer] must now know the min_pg_version that will be used. By default we check this at repo startup by asking the database, but you can also define it yourself.
- [AshPostgres.DataLayer] Now requires postgres version 14 or higher
- [AshPostgres.Timestamptz] add timestamptz types (#266)
- [AshPostgres.Repo] add
create?
anddrop?
callbacks toAshPostgres.Repo
(#143) - [AshPostgres.DataLayer] support
c:AshDataLayer.calculate/3
capability
- [AshPostgres.MigrationGenerator] honor dry_run option in extension migrations
- [AshPostgres.MigrationGenerator] don't wait for shell input when checking migrations
- [AshPostgres.DataLayer] ensure limit/offset triggers joining for update/destroy query
- [AshPostgres.DataLayer] properly honor
limit
in bulk operations - [AshPostgres.DataLayer] ensure that
exists
with a filter paired withfrom_many?
functions properly
- [AshPostgres.Repo] warn on missing ash-functions at compile time
- [AshPostgres.Repo] add default implementation for pg_version, and rename to
min_pg_version
- [mix ash.rollback] support
mix ash.rollback
with interactive rollback - [AshSql] move many internals out to
AshSql
package to be shared