Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(lb4): decouple app config from features #613

Merged
merged 1 commit into from
Feb 7, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
61 changes: 30 additions & 31 deletions pages/en/lb4/Application.md
Original file line number Diff line number Diff line change
Expand Up @@ -38,12 +38,11 @@ export class WidgetApplication extends Application {
constructor() {
// This is where you would pass configuration to the base constructor
// (as well as handle your own!)
super({
components: [RestComponent],
});
super();
const app = this; // For clarity.
// You can bind to the Application-level context here.
// app.bind('foo').to(bar);
app.component(RestComponent);
app.controller(SamoflangeController);
app.controller(DoohickeyController);
}
Expand Down Expand Up @@ -77,8 +76,8 @@ a combination of both.

### Binding configuration
Binding is the most commonly-demonstrated form of application configuration
throughout our examples, and in most cases, is the recommended method for
setting up your application.
throughout our examples, and is the recommended method for setting up your
application.

In addition to the binding functions provided by [Context](Context.html),
the `Application` class also provides some sugar functions for commonly used
Expand Down Expand Up @@ -129,59 +128,59 @@ instance of the `WidgetRepository` class.

The `Application` class constructor also accepts an
[`ApplicationConfig`](http://apidocs.strongloop.com/@loopback%2fcore/#ApplicationConfig)
object which contains three collections: `components`, `controllers` and `servers`.
It will automatically create bindings for each of these collections as a part
of defining the application instance.
object which contains component-level configurations such as
[`RestServerConfig`](http://apidocs.strongloop.com/@loopback%2frest/#RestServerConfig).
It will automatically create bindings for these configurations and later be injected
through dependency injections. Visit [Dependency Injection](Dependency-injection.html)
for more details.

{% include note.html content="
More advanced binding configuration such as provider binding, or binding scopes
Binding configuration such as component binding, provider binding, or binding scopes
are not possible with the constructor-based configuration approach.
" %}

```ts
export class MyApplication extends Application {
export class MyApplication extends RestApplication {
constructor() {
super({
components: [
MagicSuite,
],
servers: {
'public': RestServer,
'private': RestServer,
},
controllers: [
FooController,
BarController,
BazController,
]
});
rest: {
port: 4000,
host: 'my-host'
}
})
}
}
```

#### Components
```ts
app.components([MyComponent, RestComponent]);
```
The components collection allows bulk binding of component constructors within
your `Application` instance's context.

For more information on how to make use of components,
see [Using Components](Using-components.html).

#### Controllers
```ts
app.controllers([FooController, BarController]);
```
Much like the components collection, the controllers collection allows bulk
binding of [Controllers](Controllers.html) to
the `Application` context.

#### Servers
The servers collection is a Map of server constructors, whose keys are used
as part of the server's binding name.
```ts
app.servers([MyServer, GrpcServer]);
```
The servers collection is also like the previous collections and allows
bulk binding of [Servers](Server.html).

```ts
const app = new Application({
servers: {
'public': RestServer,
'private': RestServer,
},
});
const app = new Application();
app.server(RestServer, 'public'); // {'public': RestServer}
app.server(RestServer, 'private'); // {'private': RestServer}
```
In the above example, the two server instances would be bound to the Application
context under the keys `servers.public`, and `servers.private` respectively.
Expand Down
25 changes: 14 additions & 11 deletions pages/en/lb4/Creating-components.md
Original file line number Diff line number Diff line change
Expand Up @@ -67,9 +67,8 @@ Applications can use `@inject` decorators to access the value of an exported Pro
If you’re not familiar with decorators in TypeScript, see [Key Concepts: Decorators](Decorators.html)

```js
const app = new Application({
components: [MyComponent]
});
const app = new Application();
app.component(MyComponent);

class MyController {
constructor(@inject('my-component.my-value') greeting) {
Expand Down Expand Up @@ -273,15 +272,18 @@ export function RepositoryMixin<T extends Class<any>>(superClass: T) {
return class extends superClass {
constructor(...args: any[]) {
super(...args);
... ...
// detect components attached to the app
if (this.options.components) {
for (const component of this.options.components) {
this.mountComponentRepository(component);
}
}
}
}

/**
* Add a component to this application. Also mounts
* all the components' repositories.
*/
public component(component: Class<any>) {
super.component(component);
this.mountComponentRepository(component);
}

mountComponentRepository(component: Class<any>) {
const componentKey = `components.${component.name}`;
const compInstance = this.getSync(componentKey);
Expand All @@ -306,7 +308,8 @@ import {Application} from '@loopback/core';
import {FooComponent} from 'components/src/Foo';

class AppWithRepoMixin extends RepositoryMixin(Application) {};
let app = new AppWithRepoMixin({components: [FooComponent]});
let app = new AppWithRepoMixin();
app.component(FooComponent);

// `app.find` returns all repositories in FooComponent
app.find('repositories.*');
Expand Down
4 changes: 3 additions & 1 deletion pages/en/lb4/Repositories.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,10 @@ import { AccountRepository, CategoryRepository } from './repository';
// Using the Mixin
class MyApplication extends RepositoryMixin(Application) {}


const app = new MyApplication();
// AccountRepository will be bound to key `repositories.AccountRepository`
const app = new MyApplication({repositories: [AccountRepository]});
app.repository(AccountRepository);
// CategoryRepository will be bound to key `repositories.CategoryRepository`
app.repository(CategoryRepository);
```
Expand Down
8 changes: 0 additions & 8 deletions pages/en/lb4/Using-components.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,14 +19,6 @@ const app = new Application();
app.component(AuthenticationComponent);
```

Alternatively, you can register a component through application config object.

```js
const app = new Application({
components: [AuthenticationComponent],
});
```

In general, components can contribute the following items:

- [Controllers](Controllers.html)
Expand Down