1 /*
2 * Copyright 2019 The Netty Project
3 *
4 * The Netty Project licenses this file to you under the Apache License,
5 * version 2.0 (the "License"); you may not use this file except in compliance
6 * with the License. You may obtain a copy of the License at:
7 *
8 * https://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13 * License for the specific language governing permissions and limitations
14 * under the License.
15 */
16 package io.netty.handler.codec.dns;
17
18 import io.netty.buffer.ByteBuf;
19 import io.netty.channel.ChannelHandler;
20 import io.netty.channel.ChannelHandlerContext;
21 import io.netty.handler.codec.MessageToByteEncoder;
22
23 @ChannelHandler.Sharable
24 public final class TcpDnsQueryEncoder extends MessageToByteEncoder<DnsQuery> {
25
26 private final DnsQueryEncoder encoder;
27
28 /**
29 * Creates a new encoder with {@linkplain DnsRecordEncoder#DEFAULT the default record encoder}.
30 */
31 public TcpDnsQueryEncoder() {
32 this(DnsRecordEncoder.DEFAULT);
33 }
34
35 /**
36 * Creates a new encoder with the specified {@code recordEncoder}.
37 */
38 public TcpDnsQueryEncoder(DnsRecordEncoder recordEncoder) {
39 this.encoder = new DnsQueryEncoder(recordEncoder);
40 }
41
42 @Override
43 protected void encode(ChannelHandlerContext ctx, DnsQuery msg, ByteBuf out) throws Exception {
44 // Length is two octets as defined by RFC-7766
45 // See https://tools.ietf.org/html/rfc7766#section-8
46 out.writerIndex(out.writerIndex() + 2);
47 encoder.encode(msg, out);
48
49 // Now fill in the correct length based on the amount of data that we wrote the ByteBuf.
50 out.setShort(0, out.readableBytes() - 2);
51 }
52
53 @Override
54 protected ByteBuf allocateBuffer(ChannelHandlerContext ctx, @SuppressWarnings("unused") DnsQuery msg,
55 boolean preferDirect) {
56 if (preferDirect) {
57 return ctx.alloc().ioBuffer(1024);
58 } else {
59 return ctx.alloc().heapBuffer(1024);
60 }
61 }
62 }