@Override public void write(final ChannelHandlerContext ctx, final Object msg, final ChannelPromise promise) throws Exception { if (msg instanceof HttpResponse) { final HttpResponse response = (HttpResponse) msg; final CorsMetadata cmd = ctx.channel().attr(CorsInboundHandler.CORS).get(); if (cmd != null) { response.headers().set(HttpHeaders.Names.ACCESS_CONTROL_ALLOW_ORIGIN, cmd.origin()); if (cmd.hasHeaders()) { response.headers().set(HttpHeaders.Names.ACCESS_CONTROL_ALLOW_HEADERS, cmd.headers()); } response.headers().set(HttpHeaders.Names.ACCESS_CONTROL_ALLOW_CREDENTIALS, "true"); } } ctx.writeAndFlush(msg, promise); }
@Override public void write(final ChannelHandlerContext ctx, final Object msg, final ChannelPromise promise) throws Exception { if (msg instanceof HttpResponse) { final HttpResponse response = (HttpResponse) msg; final CorsMetadata cmd = ctx.channel().attr(CorsInboundHandler.CORS).get(); if (cmd != null) { response.headers().set(HttpHeaders.Names.ACCESS_CONTROL_ALLOW_ORIGIN, cmd.origin()); if (cmd.hasHeaders()) { response.headers().set(HttpHeaders.Names.ACCESS_CONTROL_ALLOW_HEADERS, cmd.headers()); } response.headers().set(HttpHeaders.Names.ACCESS_CONTROL_ALLOW_CREDENTIALS, "true"); } } ctx.writeAndFlush(msg, promise); }