Don't require api_listener when validating Listener

This commit is contained in:
Michael Lumish 2025-02-12 15:33:52 -08:00
parent 564e80f736
commit eed4d54537
1 changed files with 9 additions and 8 deletions

View File

@ -262,14 +262,15 @@ export class ListenerResourceType extends XdsResourceType {
private validateResource(context: XdsDecodeContext, message: Listener__Output): ValidationResult<Listener__Output> { private validateResource(context: XdsDecodeContext, message: Listener__Output): ValidationResult<Listener__Output> {
const errors: string[] = []; const errors: string[] = [];
if ( if (message.api_listener?.api_listener) {
message.api_listener?.api_listener && if (
message.api_listener.api_listener.type_url === HTTP_CONNECTION_MANGER_TYPE_URL message.api_listener.api_listener.type_url === HTTP_CONNECTION_MANGER_TYPE_URL
) { ) {
const httpConnectionManager = decodeSingleResource(HTTP_CONNECTION_MANGER_TYPE_URL, message.api_listener!.api_listener.value); const httpConnectionManager = decodeSingleResource(HTTP_CONNECTION_MANGER_TYPE_URL, message.api_listener!.api_listener.value);
errors.push(...validateHttpConnectionManager(httpConnectionManager).map(error => `api_listener.api_listener: ${error}`)); errors.push(...validateHttpConnectionManager(httpConnectionManager).map(error => `api_listener.api_listener: ${error}`));
} else { } else {
errors.push(`api_listener.api_listener.type_url != ${HTTP_CONNECTION_MANGER_TYPE_URL}`); errors.push(`api_listener.api_listener.type_url != ${HTTP_CONNECTION_MANGER_TYPE_URL}`);
}
} }
if (message.listener_filters.length > 0) { if (message.listener_filters.length > 0) {
errors.push('listener_filters populated'); errors.push('listener_filters populated');