Validador assíncrono orientado a modelo Angular2

Eu tenho um problema com a definição de validador assíncrono no formulário orientado a modelo.

Atualmente eu tenho esta entrada:

<input type="text" ngControl="email"  [(ngModel)]="model.applicant.contact.email" #email="ngForm" required asyncEmailValidator>

com seletor de validadorasyncEmailValidator que está apontando para esta classe:

import {provide} from "angular2/core";
import {Directive} from "angular2/core";
import {NG_VALIDATORS} from "angular2/common";
import {Validator} from "angular2/common";
import {Control} from "angular2/common";
import {AccountService} from "../services/account.service";

@Directive({
selector: '[asyncEmailValidator]',
providers: [provide(NG_VALIDATORS, {useExisting: EmailValidator, multi: true}), AccountService]
})

export class EmailValidator implements Validator {
//https://angular.io/docs/ts/latest/api/common/Validator-interface.html


constructor(private accountService:AccountService) {
}

validate(c:Control):{[key: string]: any} {
    let EMAIL_REGEXP = /^[-a-z0-9~!$%^&*_=+}{\'?]+(\.[-a-z0-9~!$%^&*_=+}{\'?]+)*@([a-z0-9_][-a-z0-9_]*(\.[-a-z0-9_]+)*\.(aero|arpa|biz|com|coop|edu|gov|info|int|mil|museum|name|net|org|pro|travel|mobi|[a-z][a-z])|([0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}))(:[0-9]{1,5})?$/i;

    if (!EMAIL_REGEXP.test(c.value)) {
        return {validateEmail: {valid: false}};
    }

    return null;

    /*return new Promise(resolve =>
        this.accountService.getUserNames(c.value).subscribe(res => {
            if (res == true) {
                resolve(null);
            }
            else {
                resolve({validateEmailTaken: {valid: false}});
            }
        }));*/
}

}

A parte da regex de email está funcionando conforme o esperado e o formulário está sendo validado com êxito se a regex estiver correspondendo. Mas depois disso, quero verificar se o email ainda não está em uso, por isso estou criando uma promessa para o meu accountService. Mas isso não funciona e a forma está em estado de falha o tempo todo.

Eu li sobre formulários controlados por modelo e usando o FormBuilder como abaixo:

constructor(builder: FormBuilder) {
this.email = new Control('',
  Validators.compose([Validators.required, CustomValidators.emailFormat]), CustomValidators.duplicated
);
}

Que possuem validadores assíncronos definidos no terceiro parâmetro deAo controle() Mas este não é o meu caso, porque estou usando uma abordagem diferente.

Então, minha pergunta é: é possível criar validador assíncrono usando formulários orientados a modelos?

questionAnswers(3)

yourAnswerToTheQuestion