Releases: go-goyave/goyave
Releases · go-goyave/goyave
Pre-release v5.0.0-rc12
- Fixed "invalid db" error when using
server.CloseDB()
on a server having a DB with a custom dialector (usually for tests). This error is now ignored. osfs
: added a constructor with an optional base directory parameter:osfs.New("/home")
.- Validation: fixed a reflect error when trying to validate elements of a
nil
array.
Pre-release v5.0.0-rc11
- Updated some documentation
- Use
errors.Is()
instead of strict equality forhttp.ErrServerClosed
- Database initialization now return previously omitted errors
fsutil.File
now supports DTO conversionosfs.FS
new methodSub()
returns a sub OS file system- Use
path.Join()
instead of concatenation testutil.FindRootDirectory()
doesn't add a trailing slash anymore and cleans up the path. Use withpath.Join()
instead of concatenation.
Pre-release v5.0.0-rc10
- Cleanup
- Removed unused structure in the auth package
- Updated some documentation in the
fsutil
package
- Reworked the
auth
package- Authenticators depend on a
UserService
instead of executing DB query themselves - Encourage using user DTO instead of models
- This all results in removing a dependency between presentation and data layer
- Removed
FindColumns
. The "username" and "password" fields are not marked with struct tags anymore: they are handled by a repository. - Reduced (but not eliminated) uses of reflection. Now only the password field from the DTO returned by the user service is retrieved using reflection.
- Take advantage of generics even more
- The request's context is now properly propagated by JWT and basic authenticators
- Authenticators depend on a
Pre-release v5.0.0-rc9
- Slog: the dev mode handler now uses a pointer for its mutex and shares the same mutex among all his clones.
Server.Stop()
won't attempt to closesigChannel
again if the server has already been stopped. This method can this be called several times safely now.- Router
- Changed the subrouter matching so it doesn't work with prefix only. This will remove conflicts between two subrouters having a prefix starting with the same characters (e.g.:
/test
and/test-2
won't conflict anymore) - The router won't turn back and explore other branches if the subrouter matches but none of its routes do. This will fix some false matches.
- Fixed
/
route defined at the main router being matched if a subrouter matches but none of its routes do and a trailing slash is present in the request URI.
- Changed the subrouter matching so it doesn't work with prefix only. This will remove conflicts between two subrouters having a prefix starting with the same characters (e.g.:
- Cleanup: removed some unused resources, outdated comments and updated incorrect documentation
- Validation
- Fixed a reflect error in
ArrayValidator
if the first element of the array is invalid (e.g.:nil
) - Use error wrapping in
Unique
/Exists
validators for better error stacktraces - Add a timeout on the SQL query executed by the
ExistsArray
validator. - Remove suffix
[]
from n-dimensional array elements field name in error messages.
- Fixed a reflect error in
Pre-release v5.0.0-rc8
- Improved docs
server.Stop()
doesn't attempt to stop the server a second time if it was already stopped- Validation: added
validation.Context
accessors for current element path and array element errors - Validation: added
validation.Context
methodsAddValidationError
andAddValidationErrors
so validators can merge additional errors that may be coming from nested validation validation.Context
'sExtra
field is nevernil
- Fixed
OPTIONS
method not added to routes if their router inherited their CORS settings from parent router - Updated dependencies
- Improved language files unmarshal error messages
Pre-release v5.0.0-rc7
- Updated dependencies
- Improved thread-safety of server status
- Updated contribution resources (issue templates, etc) and license
Pre-release v5.0.0-rc6
slog
: custom errors implementingslog.LogValuer
are now handled correctly and will be added as reason attribute.- Added parameter name hints on
goyave.Handler
so IDEs automatically name request and response properly when auto-completing. testutil
: when usingTestMiddleware
, the cloned request sent to the middleware now uses the samecontext.Context
as the original request.- Updated dependencies and CI
Pre-release v5.0.0-rc5
- Added a name to special routes (the
notFound
andmethodNotAllowed
routes) so it is possible to know if there was no matched route from inside a global middleware. testutil.TestMiddleware
now also copies therequest.Route
.⚠️ The auth middleware is now only executed if the matched route (or one of its parents) have the metaauth.MetaAuth
set totrue
. This means theauth.Middleware
is now meant to be used as a global middleware. Routers and routes can be individually marked as requiring auth or not.
Pre-release v5.0.0-rc4
- Improvements to the
session
package to make manual transaction (begin, commit, rollback) easier and to improve support on nested transaction (that can possibly involve multiple different services).- The
Session
interface now has aContext() context.Context
method. Begin()
now also injects the transaction DB in the new session's context.Begin()
andTransaction()
now use the DB retrieved from the given context if available. This makes nested transactions possible even if the service is using the root session.
- The
Pre-release v5.0.0-rc3
-database.Paginator
now uses a cloned statement for the count query to avoid modifying the original statement.
- Wrap errors using
errors.New()
in many places that were not already doing it. - Added
errors.Errorf
, which is a shortcut forerrors.New(fmt.Errorf())
. ⚠️ errors.New()
anderrors.NewSkip()
now returnnil
if givennil
as argument.nil
values in[]error
and[]any
reasons are now ignored.⚠️ errors.New()
,errors.NewSkip()
anderrors.Errorf()
now returnerror
interface instead of*errors.Error
to improve ability to compare tonil
.- Added a safeguard on
Response.error()
againstnil
errors. - Added a safeguard on
slog.Logger.logError()
againstnil
errors. - Updated internal uses of the util
errors
package according to the new changes described above.