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 super(DnsQuery.class);
40 this.encoder = new DnsQueryEncoder(recordEncoder);
41 }
42
43 @Override
44 protected void encode(ChannelHandlerContext ctx, DnsQuery msg, ByteBuf out) throws Exception {
45 // Length is two octets as defined by RFC-7766
46 // See https://tools.ietf.org/html/rfc7766#section-8
47 out.writerIndex(out.writerIndex() + 2);
48 encoder.encode(msg, out);
49
50 // Now fill in the correct length based on the amount of data that we wrote the ByteBuf.
51 out.setShort(0, out.readableBytes() - 2);
52 }
53
54 @Override
55 protected ByteBuf allocateBuffer(ChannelHandlerContext ctx, @SuppressWarnings("unused") DnsQuery msg,
56 boolean preferDirect) {
57 if (preferDirect) {
58 return ctx.alloc().ioBuffer(1024);
59 } else {
60 return ctx.alloc().heapBuffer(1024);
61 }
62 }
63 }