blob: 3fc4bb51015fbaee38235f8b4c2e02ced3ab0797 [file] [log] [blame]
Phaneendra Manda1c0061d2015-08-06 12:29:38 +05301/*
2 * Copyright 2015 Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://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,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package org.onosproject.pcepio.protocol;
18
19import org.jboss.netty.buffer.ChannelBuffer;
20import org.onosproject.pcepio.exceptions.PcepParseException;
21import org.onosproject.pcepio.types.PcepObjectHeader;
22
23/**
24 * Abstraction of an entity providing FEC Object of Type is 4 IPv6 Adjacency.
25 */
26public interface PcepFecObjectIPv6Adjacency extends PcepFecObject {
27
28 /**
29 * Returns Local IPv6Address of FEC Object.
30 *
31 * @return Local IPv6Address of FEC Object
32 */
33 byte[] getLocalIPv6Address();
34
35 /**
36 * Sets Local IPv6Address with specified value.
37 *
38 * @param value Local IPv6Address
39 */
40 void seLocalIPv6Address(byte[] value);
41
42 /**
43 * Returns Remote IPv6Address of FEC Object.
44 *
45 * @return Remote IPv6Address of FEC Object
46 */
47 byte[] getRemoteIPv6Address();
48
49 /**
50 * Sets Remote IPv6Address with specified value.
51 *
52 * @param value Remote IPv6Address
53 */
54 void seRemoteIPv6Address(byte[] value);
55
56 @Override
57 void print();
58
59 @Override
60 int write(ChannelBuffer bb) throws PcepParseException;
61
62 /**
63 * Builder interface with get and set functions to build FEC object.
64 */
65 public interface Builder {
66
67 /**
68 * Builds FEC Object IPv6 Adjacency.
69 *
70 * @return FEC Object IPv6 Adjacency
71 * @throws PcepParseException while building FEC IPv6 Adjacency object.
72 */
73 PcepFecObjectIPv6Adjacency build() throws PcepParseException;
74
75 /**
76 * Returns FEC Object IPv6 Adjacency header.
77 *
78 * @return FEC Object IPv6 Adjacency header
79 */
80 PcepObjectHeader getFecIpv6AdjacencyObjHeader();
81
82 /**
83 * Sets FEC Object IPv6 Adjacency header and returns its builder.
84 *
85 * @param obj FEC Object IPv6 Adjacency header
86 * @return Builder by setting FEC Object IPv6 Adjacency header
87 */
88 Builder setFecIpv6AdjacencyObjHeader(PcepObjectHeader obj);
89
90 /**
91 * Returns Local IPv6Address of FEC Object.
92 *
93 * @return Local IPv6Address of FEC Object
94 */
95 byte[] getLocalIPv6Address();
96
97 /**
98 * Sets Local IPv6Address and returns its builder.
99 *
100 * @param value Local IPv6Address
101 * @return Builder by setting Local IPv6Address
102 */
103 Builder setLocalIPv6Address(byte[] value);
104
105 /**
106 * Returns Remote IPv6Address of FEC Object.
107 *
108 * @return Remote IPv6Address of FEC Object
109 */
110 byte[] getRemoteIPv6Address();
111
112 /**
113 * Sets Remote IPv6Address and returns its builder.
114 *
115 * @param value Remote IPv6Address
116 * @return Builder by setting Remote IPv6Address
117 */
118 Builder setRemoteIPv6Address(byte[] value);
119
120 /**
121 * Sets P flag in FEC object header and returns its builder.
122 *
123 * @param value boolean value to set P flag
124 * @return Builder by setting P flag
125 */
126 Builder setPFlag(boolean value);
127
128 /**
129 * Sets I flag in FEC object header and returns its builder.
130 *
131 * @param value boolean value to set I flag
132 * @return Builder by setting I flag
133 */
134 Builder setIFlag(boolean value);
135 }
136}