Releases: cometsh/atex
Releases · cometsh/atex
v0.9.1
v0.9.0
0.9.0 - 2026-04-16
Breaking Changes
Atex.NSIDis now a struct (%Atex.NSID{authority, name, fragment}). Public
functions now accept and return structs. You can usenew/1,new!/1or the
new~NSID""for constructing from a NSID string.
Added
Atex.Repomodule for building, mutating, signing, serialising, and loading
AT Protocol repositories. Also supports lazily streaming from a CAR binary for
efficient processing of large repository exports.Atex.XRPC.UnauthedClientmodule for running unauthenticated XRPC fetches on
public APIs or PDSes.Atex.Lexicon.Resolvermodule for resolving published lexicons by NSID,
following the
publication and resolution spec.mix atex.lexicons.resolvetask for resolving one or more lexicons by NSID
and writing to a JSON file.- Sigils for
Atex.AtURIandAtex.TID,~AT"at://..."and~TID"..."
respectively. /logoutroute forAtex.OAuth.Plugto revoke the current session, as well
asAtex.OAuth.Plug.revoke_session/2to revoke a conn's session
programmaticly (e.g. from a session management dashboard).deflexiconnow generates structs for errors defined by queries and
procedures, under aErrorssubmodule.deflexicongenerated models now have acoerce_error/1function that takes
in a map and tries to convert it to one of its known error structs.Atex.XRPC.Errorstruct for wrapping XRPC error responses, including both
known errors (with typederror_struct) and unknown errors.
Fixed
- Fix issue when trying to validate OAuth authorisation codes in localhost mode
on PDS implementations that are more strict than the Bluesky reference
implementation.
v0.8.0
0.8.0 - 2026-03-29
Breaking Changes
-
The
Atex.IdentityResolverconfig key has been replaced with a flat config
option. Update your config from:config :atex, Atex.IdentityResolver, directory_url: "https://plc.directory"
to:
config :atex, plc_directory_url: "https://plc.directory"
-
Atex.Config.IdentityResolverhas been renamed toAtex.Config. -
Atex.IdentityResolver.DIDDocumenthas been renamed toAtex.DID.Document. -
Replace existing
Atex.DID.Document.new/1method with the method previously
namedfrom_json/1.
Added
Atex.Cryptomodule for performing AT Protocol-related cryptographic
operations.Atex.PLCmodule for interacting with
a did:plc directory API.Atex.ServiceAuthmodule for validating
inter-service authentication tokens.- Various improvements to
Atex.Did.Document- Add
Atex.DID.Document.ServiceandAtex.DID.Document.VerificationMethod
sub-structs. - Add
to_json/1methods andJSON.Encoderprotocols for easy conversion to
camelCase JSON.
- Add
Atex.XRPC.Routermodule withquery/3andprocedure/3macros for easily
building XRPC server routes inside aPlug.Router, with built-in service auth
validation and validation if passed the name of a module usingdeflexicon.deflexiconnow emitscontent_type/0functions (onInputsubmodules for typed JSON bodies,
otherwise on the root module) for procedures.Atex.XRPC.ServiceAuthClientmodule for making requests to other atproto services using a service auth token.
Fixed
- Fix a problem where generated
%<LexiconId>.Paramsstructs could not be
passed to an XRPC call due to not having the Enumerable protocol implemented. - Correctly generate
Input/Outputsubmodules withfrom_jsonmethods for
queries and procedures that usereforuniontypes.
v0.7.1
[0.7.1] - 2026-02-06
Breaking Changes
- Included
Com.Atproto.*lexicon modules have been removed and put into
atex_atprotoinstead.
Added
- The PLC directory used for identity resolution can now be configured. See
Atex.Config.IdentityResolvefor more information. (Thanks
@hexmani.ac!) - Add an extra optional
optsparameter to someAtex.OAuthfunctions, to
allow for better integration with other ecosystems. (Thanks
@lekkice.moe!)
v0.7.0
[0.7.0] - 2026-01-07
Breaking Changes
Atex.OAuth.Plugnow raisesAtex.OAuth.Errorexceptions instead of handling
error situations internally. Applications should implementPlug.ErrorHandler
to catch and gracefully handle them.Atex.OAuth.Plugnow saves only the user's DID in the session instead of the
entire OAuth session object. Applications must useAtex.OAuth.SessionStore
to manage OAuth sessions.Atex.XRPC.OAuthClienthas been overhauled to useAtex.OAuth.SessionStore
for retrieving and managing OAuth sessions, making it easier to use with not
needing to manually keep a Plug session in sync.
Added
Atex.OAuth.SessionStorebehaviour andAtex.OAuth.Sessionstruct for
managing OAuth sessions with pluggable storage backends.Atex.OAuth.SessionStore.ETS- in-memory session store implementation.Atex.OAuth.SessionStore.DETS- persistent disk-based session store
implementation.
Atex.OAuth.Plugnow requires a:callbackoption that is a MFA tuple
(Module, Function, Args), denoting a callback function to be invoked by after
a successful OAuth login. See the OAuth example for a
simple usage of this.Atex.OAuth.Permissionmodule for creating
AT Protocol permission strings for
OAuth.Atex.OAuth.Errorexception module for OAuth flow errors. Contains both a
human-readablemessagestring and a machine-readablereasonatom for error
handling.Atex.OAuth.Cachemodule provides TTL caching for OAuth authorization server
metadata with a 1-hour default TTL to reduce load on third-party PDSs.Atex.OAuth.get_authorization_server/2and
Atex.OAuth.get_authorization_server_metadata/2now support an optional
freshparameter to bypass the cache when needed.
Changed
mix atex.lexiconsnow adds@moduledoc falseto generated modules to stop
them from automatically cluttering documentation.Atex.IdentityResolver.Cache.ETSnow uses ConCache instead of ETS directly,
with a 1-hour TTL for cached identity information.
v0.6.0
[0.6.0] - 2025-11-25
Breaking Changes
deflexiconnow converts all def names to be in snake_case instead of the
casing as written the lexicon.
Added
deflexiconnow emits structs for records, objects, queries, and procedures.Atex.XRPC.get/3andAtex.XRPC.post/3now support having a lexicon struct
as the second argument instead of the method's name, making it easier to have
properly checked XRPC calls.- Add pre-transpiled modules for the core
com.atprotolexicons.
v0.5.0
[0.5.0] - 2025-10-11
Breaking Changes
- Remove
Atex.HTTPand associated modules as the abstraction caused a bit too
much complexities for how early atex is. It may come back in the future as
something more fleshed out once we're more stable. - Rename
Atex.XRPC.ClienttoAtex.XRPC.LoginClient
Added
Atex.OAuthmodule with utilites for handling some OAuth functionality.Atex.OAuth.Plugmodule (if Plug is loaded) which provides a basic but
complete OAuth flow, including storing the tokens inPlug.Session.Atex.XRPC.Clientbehaviour for implementing custom client variants.Atex.XRPCnow supports using different client implementations.Atex.XRPC.OAuthClientto make XRPC calls on the behalf of a user who has
authenticated with ATProto OAuth.
v0.4.0
[0.4.0] - 2025-08-27
Added
Atex.Lexiconmodule that provides thedeflexiconmacro, taking in a JSON
Lexicon definition and converts it into a series of schemas for each
definition within it.mix atex.lexiconsfor converting lexicon JSON files into modules using
deflexiconeasily.
v0.3.0
[0.3.0] - 2025-06-29
Changed
Atex.XRPC.Adapterrenamed toAtex.HTTP.Adapter.
Added
Atex.HTTPmodule that delegates to the currently configured adapter.Atex.HTTP.Responsestruct to be returned byAtex.HTTP.Adapter.Atex.IdentityResolvermodule for resolving and validating an identity,
either by DID or a handle.- Also has a pluggable cache (with a default ETS implementation) for keeping
some data locally.
- Also has a pluggable cache (with a default ETS implementation) for keeping