001// ***************************************************************************************************************************
002// * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements.  See the NOTICE file *
003// * distributed with this work for additional information regarding copyright ownership.  The ASF licenses this file        *
004// * to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance            *
005// * with the License.  You may obtain a copy of the License at                                                              *
006// *                                                                                                                         *
007// *  http://www.apache.org/licenses/LICENSE-2.0                                                                             *
008// *                                                                                                                         *
009// * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an  *
010// * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the License for the        *
011// * specific language governing permissions and limitations under the License.                                              *
012// ***************************************************************************************************************************
013package org.apache.juneau.urlencoding;
014
015import static org.apache.juneau.urlencoding.UrlEncodingSerializer.*;
016
017import java.util.*;
018
019import org.apache.juneau.*;
020import org.apache.juneau.http.*;
021import org.apache.juneau.serializer.*;
022import org.apache.juneau.uon.*;
023
024/**
025 * Builder class for building instances of URL-Encoding serializers.
026 */
027public class UrlEncodingSerializerBuilder extends UonSerializerBuilder {
028
029   /**
030    * Constructor, default settings.
031    */
032   public UrlEncodingSerializerBuilder() {
033      super();
034   }
035
036   /**
037    * Constructor.
038    * 
039    * @param ps The initial configuration settings for this builder.
040    */
041   public UrlEncodingSerializerBuilder(PropertyStore ps) {
042      super(ps);
043   }
044
045   @Override /* ContextBuilder */
046   public UrlEncodingSerializer build() {
047      return build(UrlEncodingSerializer.class);
048   }
049
050
051   //--------------------------------------------------------------------------------
052   // Properties
053   //--------------------------------------------------------------------------------
054
055   /**
056    * Configuration property:  Serialize bean property collections/arrays as separate key/value pairs.
057    * 
058    * <p>
059    * If <jk>false</jk>, serializing the array <code>[1,2,3]</code> results in <code>?key=$a(1,2,3)</code>.
060    * <br>If <jk>true</jk>, serializing the same array results in <code>?key=1&amp;key=2&amp;key=3</code>.
061    * 
062    * <h5 class='section'>See Also:</h5>
063    * <ul>
064    *    <li class='jf'>{@link UrlEncodingSerializer#URLENC_expandedParams}
065    * </ul>
066    * 
067    * @param value 
068    *    The new value for this property.
069    *    <br>The default value is <jk>false</jk>.
070    * @return This object (for method chaining).
071    */
072   public UrlEncodingSerializerBuilder expandedParams(boolean value) {
073      return set(URLENC_expandedParams, value);
074   }
075
076   /**
077    * Configuration property:  Serialize bean property collections/arrays as separate key/value pairs.
078    * 
079    * <p>
080    * Shortcut for calling <code>expandedParams(<jk>true</jk>)</code>.
081    * 
082    * <h5 class='section'>See Also:</h5>
083    * <ul>
084    *    <li class='jf'>{@link UrlEncodingSerializer#URLENC_expandedParams}
085    * </ul>
086    * 
087    * @return This object (for method chaining).
088    */
089   public UrlEncodingSerializerBuilder expandedParams() {
090      return set(URLENC_expandedParams, true);
091   }
092
093   @Override /* UonSerializerBuilder */
094   public UrlEncodingSerializerBuilder encoding(boolean value) {
095      super.encoding(value);
096      return this;
097   }
098
099   @Override /* UonSerializerBuilder */
100   public UrlEncodingSerializerBuilder encoding() {
101      super.encoding();
102      return this;
103   }
104
105   @Override /* UonSerializerBuilder */
106   public UrlEncodingSerializerBuilder paramFormat(ParamFormat paramFormat) {
107      super.paramFormat(paramFormat);
108      return this;
109   }
110
111   @Override /* UonSerializerBuilder */
112   public UrlEncodingSerializerBuilder paramFormatPlain() {
113      super.paramFormatPlain();
114      return this;
115   }
116
117   @Override /* SerializerBuilder */
118   public UrlEncodingSerializerBuilder abridged(boolean value) {
119      super.abridged(value);
120      return this;
121   }
122
123   @Override /* SerializerBuilder */
124   public UrlEncodingSerializerBuilder abridged() {
125      super.abridged();
126      return this;
127   }
128
129   @Override /* SerializerBuilder */
130   public UrlEncodingSerializerBuilder addBeanTypeProperties(boolean value) {
131      super.addBeanTypeProperties(value);
132      return this;
133   }
134
135   @Override /* SerializerBuilder */
136   public UrlEncodingSerializerBuilder detectRecursions(boolean value) {
137      super.detectRecursions(value);
138      return this;
139   }
140
141   @Override /* SerializerBuilder */
142   public UrlEncodingSerializerBuilder detectRecursions() {
143      super.detectRecursions();
144      return this;
145   }
146
147   @Override /* SerializerBuilder */
148   public UrlEncodingSerializerBuilder ignoreRecursions(boolean value) {
149      super.ignoreRecursions(value);
150      return this;
151   }
152
153   @Override /* SerializerBuilder */
154   public UrlEncodingSerializerBuilder ignoreRecursions() {
155      super.ignoreRecursions();
156      return this;
157   }
158   @Override /* SerializerBuilder */
159   public UrlEncodingSerializerBuilder initialDepth(int value) {
160      super.initialDepth(value);
161      return this;
162   }
163
164   @Override /* SerializerBuilder */
165   public UrlEncodingSerializerBuilder listener(Class<? extends SerializerListener> value) {
166      super.listener(value);
167      return this;
168   }
169
170   @Override /* SerializerBuilder */
171   public UrlEncodingSerializerBuilder maxDepth(int value) {
172      super.maxDepth(value);
173      return this;
174   }
175
176   @Override /* SerializerBuilder */
177   public UrlEncodingSerializerBuilder maxIndent(int value) {
178      super.maxIndent(value);
179      return this;
180   }
181
182   @Override /* SerializerBuilder */
183   public UrlEncodingSerializerBuilder quoteChar(char value) {
184      super.quoteChar(value);
185      return this;
186   }
187
188   @Override /* SerializerBuilder */
189   public UrlEncodingSerializerBuilder sortCollections(boolean value) {
190      super.sortCollections(value);
191      return this;
192   }
193
194   @Override /* SerializerBuilder */
195   public UrlEncodingSerializerBuilder sortCollections() {
196      super.sortCollections();
197      return this;
198   }
199
200   @Override /* SerializerBuilder */
201   public UrlEncodingSerializerBuilder sortMaps(boolean value) {
202      super.sortMaps(value);
203      return this;
204   }
205
206   @Override /* SerializerBuilder */
207   public UrlEncodingSerializerBuilder sortMaps() {
208      super.sortMaps();
209      return this;
210   }
211
212   @Override /* SerializerBuilder */
213   public UrlEncodingSerializerBuilder sq() {
214      super.sq();
215      return this;
216   }
217
218   @Override /* SerializerBuilder */
219   public UrlEncodingSerializerBuilder trimEmptyCollections(boolean value) {
220      super.trimEmptyCollections(value);
221      return this;
222   }
223
224   @Override /* SerializerBuilder */
225   public UrlEncodingSerializerBuilder trimEmptyCollections() {
226      super.trimEmptyCollections();
227      return this;
228   }
229
230   @Override /* SerializerBuilder */
231   public UrlEncodingSerializerBuilder trimEmptyMaps(boolean value) {
232      super.trimEmptyMaps(value);
233      return this;
234   }
235
236   @Override /* SerializerBuilder */
237   public UrlEncodingSerializerBuilder trimEmptyMaps() {
238      super.trimEmptyMaps();
239      return this;
240   }
241
242   @Override /* SerializerBuilder */
243   public UrlEncodingSerializerBuilder trimNullProperties(boolean value) {
244      super.trimNullProperties(value);
245      return this;
246   }
247
248   @Override /* SerializerBuilder */
249   public UrlEncodingSerializerBuilder trimStrings(boolean value) {
250      super.trimStrings(value);
251      return this;
252   }
253
254   @Override /* SerializerBuilder */
255   public UrlEncodingSerializerBuilder trimStrings() {
256      super.trimStrings();
257      return this;
258   }
259
260   @Override /* SerializerBuilder */
261   public UrlEncodingSerializerBuilder uriContext(UriContext value) {
262      super.uriContext(value);
263      return this;
264   }
265
266   @Override /* SerializerBuilder */
267   public UrlEncodingSerializerBuilder uriRelativity(UriRelativity value) {
268      super.uriRelativity(value);
269      return this;
270   }
271
272   @Override /* SerializerBuilder */
273   public UrlEncodingSerializerBuilder uriResolution(UriResolution value) {
274      super.uriResolution(value);
275      return this;
276   }
277
278   @Override /* SerializerBuilder */
279   public UrlEncodingSerializerBuilder useWhitespace(boolean value) {
280      super.useWhitespace(value);
281      return this;
282   }
283
284   @Override /* SerializerBuilder */
285   public UrlEncodingSerializerBuilder useWhitespace() {
286      super.useWhitespace();
287      return this;
288   }
289
290   @Override /* SerializerBuilder */
291   public UrlEncodingSerializerBuilder ws() {
292      super.ws();
293      return this;
294   }
295
296   @Override /* BeanContextBuilder */
297   public UrlEncodingSerializerBuilder beansRequireDefaultConstructor(boolean value) {
298      super.beansRequireDefaultConstructor(value);
299      return this;
300   }
301
302   @Override /* BeanContextBuilder */
303   public UrlEncodingSerializerBuilder beansRequireDefaultConstructor() {
304      super.beansRequireDefaultConstructor();
305      return this;
306   }
307
308   @Override /* BeanContextBuilder */
309   public UrlEncodingSerializerBuilder beansRequireSerializable(boolean value) {
310      super.beansRequireSerializable(value);
311      return this;
312   }
313
314   @Override /* BeanContextBuilder */
315   public UrlEncodingSerializerBuilder beansRequireSerializable() {
316      super.beansRequireSerializable();
317      return this;
318   }
319
320   @Override /* BeanContextBuilder */
321   public UrlEncodingSerializerBuilder beansRequireSettersForGetters(boolean value) {
322      super.beansRequireSettersForGetters(value);
323      return this;
324   }
325
326   @Override /* BeanContextBuilder */
327   public UrlEncodingSerializerBuilder beansRequireSettersForGetters() {
328      super.beansRequireSettersForGetters();
329      return this;
330   }
331
332   @Override /* BeanContextBuilder */
333   public UrlEncodingSerializerBuilder beansRequireSomeProperties(boolean value) {
334      super.beansRequireSomeProperties(value);
335      return this;
336   }
337
338   @Override /* BeanContextBuilder */
339   public UrlEncodingSerializerBuilder beanMapPutReturnsOldValue(boolean value) {
340      super.beanMapPutReturnsOldValue(value);
341      return this;
342   }
343
344   @Override /* BeanContextBuilder */
345   public UrlEncodingSerializerBuilder beanMapPutReturnsOldValue() {
346      super.beanMapPutReturnsOldValue();
347      return this;
348   }
349
350   @Override /* BeanContextBuilder */
351   public UrlEncodingSerializerBuilder beanConstructorVisibility(Visibility value) {
352      super.beanConstructorVisibility(value);
353      return this;
354   }
355
356   @Override /* BeanContextBuilder */
357   public UrlEncodingSerializerBuilder beanClassVisibility(Visibility value) {
358      super.beanClassVisibility(value);
359      return this;
360   }
361
362   @Override /* BeanContextBuilder */
363   public UrlEncodingSerializerBuilder beanFieldVisibility(Visibility value) {
364      super.beanFieldVisibility(value);
365      return this;
366   }
367
368   @Override /* BeanContextBuilder */
369   public UrlEncodingSerializerBuilder beanMethodVisibility(Visibility value) {
370      super.beanMethodVisibility(value);
371      return this;
372   }
373
374   @Override /* BeanContextBuilder */
375   public UrlEncodingSerializerBuilder useJavaBeanIntrospector(boolean value) {
376      super.useJavaBeanIntrospector(value);
377      return this;
378   }
379
380   @Override /* BeanContextBuilder */
381   public UrlEncodingSerializerBuilder useJavaBeanIntrospector() {
382      super.useJavaBeanIntrospector();
383      return this;
384   }
385
386   @Override /* BeanContextBuilder */
387   public UrlEncodingSerializerBuilder useInterfaceProxies(boolean value) {
388      super.useInterfaceProxies(value);
389      return this;
390   }
391
392   @Override /* BeanContextBuilder */
393   public UrlEncodingSerializerBuilder ignoreUnknownBeanProperties(boolean value) {
394      super.ignoreUnknownBeanProperties(value);
395      return this;
396   }
397
398   @Override /* BeanContextBuilder */
399   public UrlEncodingSerializerBuilder ignoreUnknownBeanProperties() {
400      super.ignoreUnknownBeanProperties();
401      return this;
402   }
403
404   @Override /* BeanContextBuilder */
405   public UrlEncodingSerializerBuilder ignoreUnknownNullBeanProperties(boolean value) {
406      super.ignoreUnknownNullBeanProperties(value);
407      return this;
408   }
409
410   @Override /* BeanContextBuilder */
411   public UrlEncodingSerializerBuilder ignorePropertiesWithoutSetters(boolean value) {
412      super.ignorePropertiesWithoutSetters(value);
413      return this;
414   }
415
416   @Override /* BeanContextBuilder */
417   public UrlEncodingSerializerBuilder ignoreInvocationExceptionsOnGetters(boolean value) {
418      super.ignoreInvocationExceptionsOnGetters(value);
419      return this;
420   }
421
422   @Override /* BeanContextBuilder */
423   public UrlEncodingSerializerBuilder ignoreInvocationExceptionsOnGetters() {
424      super.ignoreInvocationExceptionsOnGetters();
425      return this;
426   }
427
428   @Override /* BeanContextBuilder */
429   public UrlEncodingSerializerBuilder ignoreInvocationExceptionsOnSetters(boolean value) {
430      super.ignoreInvocationExceptionsOnSetters(value);
431      return this;
432   }
433
434   @Override /* BeanContextBuilder */
435   public UrlEncodingSerializerBuilder ignoreInvocationExceptionsOnSetters() {
436      super.ignoreInvocationExceptionsOnSetters();
437      return this;
438   }
439
440   @Override /* BeanContextBuilder */
441   public UrlEncodingSerializerBuilder sortProperties(boolean value) {
442      super.sortProperties(value);
443      return this;
444   }
445
446   @Override /* BeanContextBuilder */
447   public UrlEncodingSerializerBuilder sortProperties() {
448      super.sortProperties();
449      return this;
450   }
451
452   @Override /* BeanContextBuilder */
453   public UrlEncodingSerializerBuilder notBeanPackages(Object...values) {
454      super.notBeanPackages(values);
455      return this;
456   }
457
458   @Override /* BeanContextBuilder */
459   public UrlEncodingSerializerBuilder notBeanPackages(String...values) {
460      super.notBeanPackages(values);
461      return this;
462   }
463
464   @Override /* BeanContextBuilder */
465   public UrlEncodingSerializerBuilder notBeanPackages(boolean append, Object...values) {
466      super.notBeanPackages(append, values);
467      return this;
468   }
469
470   @Override /* BeanContextBuilder */
471   public UrlEncodingSerializerBuilder notBeanPackagesRemove(Object...values) {
472      super.notBeanPackagesRemove(values);
473      return this;
474   }
475
476   @Override /* BeanContextBuilder */
477   public UrlEncodingSerializerBuilder notBeanClasses(Object...values) {
478      super.notBeanClasses(values);
479      return this;
480   }
481
482   @Override /* BeanContextBuilder */
483   public UrlEncodingSerializerBuilder notBeanClasses(Class<?>...values) {
484      super.notBeanClasses(values);
485      return this;
486   }
487
488   @Override /* BeanContextBuilder */
489   public UrlEncodingSerializerBuilder notBeanClasses(boolean append, Object...values) {
490      super.notBeanClasses(append, values);
491      return this;
492   }
493
494   @Override /* BeanContextBuilder */
495   public UrlEncodingSerializerBuilder notBeanClassesRemove(Object...values) {
496      super.notBeanClassesRemove(values);
497      return this;
498   }
499
500   @Override /* BeanContextBuilder */
501   public UrlEncodingSerializerBuilder beanFilters(Object...values) {
502      super.beanFilters(values);
503      return this;
504   }
505
506   @Override /* BeanContextBuilder */
507   public UrlEncodingSerializerBuilder beanFilters(Class<?>...values) {
508      super.beanFilters(values);
509      return this;
510   }
511
512   @Override /* BeanContextBuilder */
513   public UrlEncodingSerializerBuilder beanFilters(boolean append, Object...values) {
514      super.beanFilters(append, values);
515      return this;
516   }
517
518   @Override /* BeanContextBuilder */
519   public UrlEncodingSerializerBuilder beanFiltersRemove(Object...values) {
520      super.beanFiltersRemove(values);
521      return this;
522   }
523
524   @Override /* BeanContextBuilder */
525   public UrlEncodingSerializerBuilder pojoSwaps(Object...values) {
526      super.pojoSwaps(values);
527      return this;
528   }
529
530   @Override /* BeanContextBuilder */
531   public UrlEncodingSerializerBuilder pojoSwaps(Class<?>...values) {
532      super.pojoSwaps(values);
533      return this;
534   }
535
536   @Override /* BeanContextBuilder */
537   public UrlEncodingSerializerBuilder pojoSwaps(boolean append, Object...values) {
538      super.pojoSwaps(append, values);
539      return this;
540   }
541
542   @Override /* BeanContextBuilder */
543   public UrlEncodingSerializerBuilder pojoSwapsRemove(Object...values) {
544      super.pojoSwapsRemove(values);
545      return this;
546   }
547
548   @Override /* BeanContextBuilder */
549   public UrlEncodingSerializerBuilder implClasses(Map<String,Class<?>> values) {
550      super.implClasses(values);
551      return this;
552   }
553
554   @Override /* BeanContextBuilder */
555   public <T> UrlEncodingSerializerBuilder implClass(Class<T> interfaceClass, Class<? extends T> implClass) {
556      super.implClass(interfaceClass, implClass);
557      return this;
558   }
559
560   @Override /* BeanContextBuilder */
561   public UrlEncodingSerializerBuilder beanDictionary(Object...values) {
562      super.beanDictionary(values);
563      return this;
564   }
565
566   @Override /* BeanContextBuilder */
567   public UrlEncodingSerializerBuilder beanDictionary(Class<?>...values) {
568      super.beanDictionary(values);
569      return this;
570   }
571
572   @Override /* BeanContextBuilder */
573   public UrlEncodingSerializerBuilder beanDictionary(boolean append, Object...values) {
574      super.beanDictionary(append, values);
575      return this;
576   }
577
578   @Override /* BeanContextBuilder */
579   public UrlEncodingSerializerBuilder beanDictionaryRemove(Object...values) {
580      super.beanDictionaryRemove(values);
581      return this;
582   }
583
584   @Override /* BeanContextBuilder */
585   public UrlEncodingSerializerBuilder beanTypePropertyName(String value) {
586      super.beanTypePropertyName(value);
587      return this;
588   }
589
590   @Override /* BeanContextBuilder */
591   public UrlEncodingSerializerBuilder locale(Locale value) {
592      super.locale(value);
593      return this;
594   }
595
596   @Override /* BeanContextBuilder */
597   public UrlEncodingSerializerBuilder timeZone(TimeZone value) {
598      super.timeZone(value);
599      return this;
600   }
601
602   @Override /* BeanContextBuilder */
603   public UrlEncodingSerializerBuilder mediaType(MediaType value) {
604      super.mediaType(value);
605      return this;
606   }
607
608   @Override /* BeanContextBuilder */
609   public UrlEncodingSerializerBuilder debug() {
610      super.debug();
611      return this;
612   }
613
614   @Override /* ContextBuilder */
615   public UrlEncodingSerializerBuilder set(String name, Object value) {
616      super.set(name, value);
617      return this;
618   }
619
620   @Override /* ContextBuilder */
621   public UrlEncodingSerializerBuilder set(boolean append, String name, Object value) {
622      super.set(append, name, value);
623      return this;
624   }
625
626   @Override /* ContextBuilder */
627   public UrlEncodingSerializerBuilder set(Map<String,Object> properties) {
628      super.set(properties);
629      return this;
630   }
631
632   @Override /* ContextBuilder */
633   public UrlEncodingSerializerBuilder add(Map<String,Object> properties) {
634      super.add(properties);
635      return this;
636   }
637
638   @Override /* ContextBuilder */
639   public UrlEncodingSerializerBuilder addTo(String name, Object value) {
640      super.addTo(name, value);
641      return this;
642   }
643
644   @Override /* ContextBuilder */
645   public UrlEncodingSerializerBuilder addTo(String name, String key, Object value) {
646      super.addTo(name, key, value);
647      return this;
648   }
649
650   @Override /* ContextBuilder */
651   public UrlEncodingSerializerBuilder removeFrom(String name, Object value) {
652      super.removeFrom(name, value);
653      return this;
654   }
655
656   @Override /* ContextBuilder */
657   public UrlEncodingSerializerBuilder apply(PropertyStore copyFrom) {
658      super.apply(copyFrom);
659      return this;
660   }
661}