5.0.0
New features
-
Reduced amount of required boilerplate code:
- The
@injectable
annotation is no longer required in classes annotated with@controller
. - Declaring bindings is no longer required in classes annotated with
@controller
.
- The
-
Support for
HttpContext
:- The current
HttpContext
can be accessed from a controller that extends theBaseHttpController
class or that gets it injected using the@injectHttpContext
decorator. - The current
HttpContext
can be accessed from middleware that extends theBaseMiddleware
class.
- The current
-
Support for
BaseMiddleware
. ExtendingBaseMiddleware
allow us to inject dependencies into a middleware function. ExtendingBaseMiddleware
also allows us to access the currentHttpContext
from a middleware function. -
Support for
AuthProvider
. If you provide an implementation ofAuthProvider
, you will be able to access the current user via the currentHttpContext
.
Breaking changes
- The
@injectable
annotation is no longer required in classes annotated with@controller
. - Declaring bindings is no longer required in classes annotated with
@controller
.
import "./controllers/some_controller"
) the class is declared and the metadata is generated. If you don't import it the metadata is never generated and therefore the controller is not found. An example of this can be found here.
If you run the application multiple times within a shared runtime process (e.g. unit testing) you might need to clean up the existing metadata before each test.
import { cleanUpMetadata } from "inversify-express-utils";
describe("Some Component", () => {
beforeEach(() => {
cleanUpMetadata();
});
it("Some test case", () => {
// ...
});
});
You can find an example of this in our unit tests.