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 addBeanTypes(boolean value) {
119      super.addBeanTypes(value);
120      return this;
121   }
122
123   @Override /* SerializerBuilder */
124   public UrlEncodingSerializerBuilder addBeanTypes() {
125      super.addBeanTypes();
126      return this;
127   }
128
129   @Override /* SerializerBuilder */
130   public UrlEncodingSerializerBuilder addRootType(boolean value) {
131      super.addRootType(value);
132      return this;
133   }
134
135   @Override /* SerializerBuilder */
136   public UrlEncodingSerializerBuilder addRootType() {
137      super.addRootType();
138      return this;
139   }
140
141   @Override /* SerializerBuilder */
142   public UrlEncodingSerializerBuilder detectRecursions(boolean value) {
143      super.detectRecursions(value);
144      return this;
145   }
146
147   @Override /* SerializerBuilder */
148   public UrlEncodingSerializerBuilder detectRecursions() {
149      super.detectRecursions();
150      return this;
151   }
152
153   @Override /* SerializerBuilder */
154   public UrlEncodingSerializerBuilder ignoreRecursions(boolean value) {
155      super.ignoreRecursions(value);
156      return this;
157   }
158
159   @Override /* SerializerBuilder */
160   public UrlEncodingSerializerBuilder ignoreRecursions() {
161      super.ignoreRecursions();
162      return this;
163   }
164   @Override /* SerializerBuilder */
165   public UrlEncodingSerializerBuilder initialDepth(int value) {
166      super.initialDepth(value);
167      return this;
168   }
169
170   @Override /* SerializerBuilder */
171   public UrlEncodingSerializerBuilder listener(Class<? extends SerializerListener> value) {
172      super.listener(value);
173      return this;
174   }
175
176   @Override /* SerializerBuilder */
177   public UrlEncodingSerializerBuilder maxDepth(int value) {
178      super.maxDepth(value);
179      return this;
180   }
181
182   @Override /* SerializerBuilder */
183   public UrlEncodingSerializerBuilder maxIndent(int value) {
184      super.maxIndent(value);
185      return this;
186   }
187
188   @Override /* SerializerBuilder */
189   public UrlEncodingSerializerBuilder quoteChar(char value) {
190      super.quoteChar(value);
191      return this;
192   }
193
194   @Override /* SerializerBuilder */
195   public UrlEncodingSerializerBuilder sortCollections(boolean value) {
196      super.sortCollections(value);
197      return this;
198   }
199
200   @Override /* SerializerBuilder */
201   public UrlEncodingSerializerBuilder sortCollections() {
202      super.sortCollections();
203      return this;
204   }
205
206   @Override /* SerializerBuilder */
207   public UrlEncodingSerializerBuilder sortMaps(boolean value) {
208      super.sortMaps(value);
209      return this;
210   }
211
212   @Override /* SerializerBuilder */
213   public UrlEncodingSerializerBuilder sortMaps() {
214      super.sortMaps();
215      return this;
216   }
217
218   @Override /* SerializerBuilder */
219   public UrlEncodingSerializerBuilder sq() {
220      super.sq();
221      return this;
222   }
223
224   @Override /* SerializerBuilder */
225   public UrlEncodingSerializerBuilder trimEmptyCollections(boolean value) {
226      super.trimEmptyCollections(value);
227      return this;
228   }
229
230   @Override /* SerializerBuilder */
231   public UrlEncodingSerializerBuilder trimEmptyCollections() {
232      super.trimEmptyCollections();
233      return this;
234   }
235
236   @Override /* SerializerBuilder */
237   public UrlEncodingSerializerBuilder trimEmptyMaps(boolean value) {
238      super.trimEmptyMaps(value);
239      return this;
240   }
241
242   @Override /* SerializerBuilder */
243   public UrlEncodingSerializerBuilder trimEmptyMaps() {
244      super.trimEmptyMaps();
245      return this;
246   }
247
248   @Override /* SerializerBuilder */
249   public UrlEncodingSerializerBuilder trimNullProperties(boolean value) {
250      super.trimNullProperties(value);
251      return this;
252   }
253
254   @Override /* SerializerBuilder */
255   public UrlEncodingSerializerBuilder trimStrings(boolean value) {
256      super.trimStrings(value);
257      return this;
258   }
259
260   @Override /* SerializerBuilder */
261   public UrlEncodingSerializerBuilder trimStrings() {
262      super.trimStrings();
263      return this;
264   }
265
266   @Override /* SerializerBuilder */
267   public UrlEncodingSerializerBuilder uriContext(UriContext value) {
268      super.uriContext(value);
269      return this;
270   }
271
272   @Override /* SerializerBuilder */
273   public UrlEncodingSerializerBuilder uriRelativity(UriRelativity value) {
274      super.uriRelativity(value);
275      return this;
276   }
277
278   @Override /* SerializerBuilder */
279   public UrlEncodingSerializerBuilder uriResolution(UriResolution value) {
280      super.uriResolution(value);
281      return this;
282   }
283
284   @Override /* SerializerBuilder */
285   public UrlEncodingSerializerBuilder useWhitespace(boolean value) {
286      super.useWhitespace(value);
287      return this;
288   }
289
290   @Override /* SerializerBuilder */
291   public UrlEncodingSerializerBuilder useWhitespace() {
292      super.useWhitespace();
293      return this;
294   }
295
296   @Override /* SerializerBuilder */
297   public UrlEncodingSerializerBuilder ws() {
298      super.ws();
299      return this;
300   }
301
302   @Override /* BeanContextBuilder */
303   public UrlEncodingSerializerBuilder beanClassVisibility(Visibility value) {
304      super.beanClassVisibility(value);
305      return this;
306   }
307
308   @Override /* BeanContextBuilder */
309   public UrlEncodingSerializerBuilder beanConstructorVisibility(Visibility value) {
310      super.beanConstructorVisibility(value);
311      return this;
312   }
313
314   @Override /* BeanContextBuilder */
315   public UrlEncodingSerializerBuilder beanDictionary(boolean append, Object...values) {
316      super.beanDictionary(append, values);
317      return this;
318   }
319
320   @Override /* BeanContextBuilder */
321   public UrlEncodingSerializerBuilder beanDictionary(Class<?>...values) {
322      super.beanDictionary(values);
323      return this;
324   }
325
326   @Override /* BeanContextBuilder */
327   public UrlEncodingSerializerBuilder beanDictionary(Object...values) {
328      super.beanDictionary(values);
329      return this;
330   }
331
332   @Override /* BeanContextBuilder */
333   public UrlEncodingSerializerBuilder beanDictionaryRemove(Object...values) {
334      super.beanDictionaryRemove(values);
335      return this;
336   }
337
338   @Override /* BeanContextBuilder */
339   public UrlEncodingSerializerBuilder beanFieldVisibility(Visibility value) {
340      super.beanFieldVisibility(value);
341      return this;
342   }
343
344   @Override /* BeanContextBuilder */
345   public UrlEncodingSerializerBuilder beanFilters(boolean append, Object...values) {
346      super.beanFilters(append, values);
347      return this;
348   }
349
350   @Override /* BeanContextBuilder */
351   public UrlEncodingSerializerBuilder beanFilters(Class<?>...values) {
352      super.beanFilters(values);
353      return this;
354   }
355
356   @Override /* BeanContextBuilder */
357   public UrlEncodingSerializerBuilder beanFilters(Object...values) {
358      super.beanFilters(values);
359      return this;
360   }
361
362   @Override /* BeanContextBuilder */
363   public UrlEncodingSerializerBuilder beanFiltersRemove(Object...values) {
364      super.beanFiltersRemove(values);
365      return this;
366   }
367
368   @Override /* BeanContextBuilder */
369   public UrlEncodingSerializerBuilder beanMapPutReturnsOldValue(boolean value) {
370      super.beanMapPutReturnsOldValue(value);
371      return this;
372   }
373
374   @Override /* BeanContextBuilder */
375   public UrlEncodingSerializerBuilder beanMapPutReturnsOldValue() {
376      super.beanMapPutReturnsOldValue();
377      return this;
378   }
379
380   @Override /* BeanContextBuilder */
381   public UrlEncodingSerializerBuilder beanMethodVisibility(Visibility value) {
382      super.beanMethodVisibility(value);
383      return this;
384   }
385
386   @Override /* BeanContextBuilder */
387   public UrlEncodingSerializerBuilder beansRequireDefaultConstructor(boolean value) {
388      super.beansRequireDefaultConstructor(value);
389      return this;
390   }
391
392   @Override /* BeanContextBuilder */
393   public UrlEncodingSerializerBuilder beansRequireDefaultConstructor() {
394      super.beansRequireDefaultConstructor();
395      return this;
396   }
397
398   @Override /* BeanContextBuilder */
399   public UrlEncodingSerializerBuilder beansRequireSerializable(boolean value) {
400      super.beansRequireSerializable(value);
401      return this;
402   }
403
404   @Override /* BeanContextBuilder */
405   public UrlEncodingSerializerBuilder beansRequireSerializable() {
406      super.beansRequireSerializable();
407      return this;
408   }
409
410   @Override /* BeanContextBuilder */
411   public UrlEncodingSerializerBuilder beansRequireSettersForGetters(boolean value) {
412      super.beansRequireSettersForGetters(value);
413      return this;
414   }
415
416   @Override /* BeanContextBuilder */
417   public UrlEncodingSerializerBuilder beansRequireSettersForGetters() {
418      super.beansRequireSettersForGetters();
419      return this;
420   }
421
422   @Override /* BeanContextBuilder */
423   public UrlEncodingSerializerBuilder beansRequireSomeProperties(boolean value) {
424      super.beansRequireSomeProperties(value);
425      return this;
426   }
427
428   @Override /* BeanContextBuilder */
429   public UrlEncodingSerializerBuilder beanTypePropertyName(String value) {
430      super.beanTypePropertyName(value);
431      return this;
432   }
433
434   @Override /* BeanContextBuilder */
435   public UrlEncodingSerializerBuilder debug() {
436      super.debug();
437      return this;
438   }
439
440   @Override /* BeanContextBuilder */
441   public <T> UrlEncodingSerializerBuilder example(Class<T> c, T o) {
442      super.example(c, o);
443      return this;
444   }
445
446   @Override /* BeanContextBuilder */
447   public UrlEncodingSerializerBuilder ignoreInvocationExceptionsOnGetters(boolean value) {
448      super.ignoreInvocationExceptionsOnGetters(value);
449      return this;
450   }
451
452   @Override /* BeanContextBuilder */
453   public UrlEncodingSerializerBuilder ignoreInvocationExceptionsOnGetters() {
454      super.ignoreInvocationExceptionsOnGetters();
455      return this;
456   }
457
458   @Override /* BeanContextBuilder */
459   public UrlEncodingSerializerBuilder ignoreInvocationExceptionsOnSetters(boolean value) {
460      super.ignoreInvocationExceptionsOnSetters(value);
461      return this;
462   }
463
464   @Override /* BeanContextBuilder */
465   public UrlEncodingSerializerBuilder ignoreInvocationExceptionsOnSetters() {
466      super.ignoreInvocationExceptionsOnSetters();
467      return this;
468   }
469
470   @Override /* BeanContextBuilder */
471   public UrlEncodingSerializerBuilder ignorePropertiesWithoutSetters(boolean value) {
472      super.ignorePropertiesWithoutSetters(value);
473      return this;
474   }
475
476   @Override /* BeanContextBuilder */
477   public UrlEncodingSerializerBuilder ignoreUnknownBeanProperties(boolean value) {
478      super.ignoreUnknownBeanProperties(value);
479      return this;
480   }
481
482   @Override /* BeanContextBuilder */
483   public UrlEncodingSerializerBuilder ignoreUnknownBeanProperties() {
484      super.ignoreUnknownBeanProperties();
485      return this;
486   }
487
488   @Override /* BeanContextBuilder */
489   public UrlEncodingSerializerBuilder ignoreUnknownNullBeanProperties(boolean value) {
490      super.ignoreUnknownNullBeanProperties(value);
491      return this;
492   }
493
494   @Override /* BeanContextBuilder */
495   public <T> UrlEncodingSerializerBuilder implClass(Class<T> interfaceClass, Class<? extends T> implClass) {
496      super.implClass(interfaceClass, implClass);
497      return this;
498   }
499
500   @Override /* BeanContextBuilder */
501   public UrlEncodingSerializerBuilder implClasses(Map<String,Class<?>> values) {
502      super.implClasses(values);
503      return this;
504   }
505
506   @Override /* BeanContextBuilder */
507   public UrlEncodingSerializerBuilder locale(Locale value) {
508      super.locale(value);
509      return this;
510   }
511
512   @Override /* BeanContextBuilder */
513   public UrlEncodingSerializerBuilder mediaType(MediaType value) {
514      super.mediaType(value);
515      return this;
516   }
517
518   @Override /* BeanContextBuilder */
519   public UrlEncodingSerializerBuilder notBeanClasses(boolean append, Object...values) {
520      super.notBeanClasses(append, values);
521      return this;
522   }
523
524   @Override /* BeanContextBuilder */
525   public UrlEncodingSerializerBuilder notBeanClasses(Class<?>...values) {
526      super.notBeanClasses(values);
527      return this;
528   }
529
530   @Override /* BeanContextBuilder */
531   public UrlEncodingSerializerBuilder notBeanClasses(Object...values) {
532      super.notBeanClasses(values);
533      return this;
534   }
535
536   @Override /* BeanContextBuilder */
537   public UrlEncodingSerializerBuilder notBeanClassesRemove(Object...values) {
538      super.notBeanClassesRemove(values);
539      return this;
540   }
541
542   @Override /* BeanContextBuilder */
543   public UrlEncodingSerializerBuilder notBeanPackages(boolean append, Object...values) {
544      super.notBeanPackages(append, values);
545      return this;
546   }
547
548   @Override /* BeanContextBuilder */
549   public UrlEncodingSerializerBuilder notBeanPackages(Object...values) {
550      super.notBeanPackages(values);
551      return this;
552   }
553
554   @Override /* BeanContextBuilder */
555   public UrlEncodingSerializerBuilder notBeanPackages(String...values) {
556      super.notBeanPackages(values);
557      return this;
558   }
559
560   @Override /* BeanContextBuilder */
561   public UrlEncodingSerializerBuilder notBeanPackagesRemove(Object...values) {
562      super.notBeanPackagesRemove(values);
563      return this;
564   }
565
566   @Override /* BeanContextBuilder */
567   public UrlEncodingSerializerBuilder pojoSwaps(boolean append, Object...values) {
568      super.pojoSwaps(append, values);
569      return this;
570   }
571
572   @Override /* BeanContextBuilder */
573   public UrlEncodingSerializerBuilder pojoSwaps(Class<?>...values) {
574      super.pojoSwaps(values);
575      return this;
576   }
577
578   @Override /* BeanContextBuilder */
579   public UrlEncodingSerializerBuilder pojoSwaps(Object...values) {
580      super.pojoSwaps(values);
581      return this;
582   }
583
584   @Override /* BeanContextBuilder */
585   public UrlEncodingSerializerBuilder pojoSwapsRemove(Object...values) {
586      super.pojoSwapsRemove(values);
587      return this;
588   }
589
590   @Override /* BeanContextBuilder */
591   public UrlEncodingSerializerBuilder sortProperties(boolean value) {
592      super.sortProperties(value);
593      return this;
594   }
595
596   @Override /* BeanContextBuilder */
597   public UrlEncodingSerializerBuilder sortProperties() {
598      super.sortProperties();
599      return this;
600   }
601
602   @Override /* BeanContextBuilder */
603   public UrlEncodingSerializerBuilder timeZone(TimeZone value) {
604      super.timeZone(value);
605      return this;
606   }
607
608   @Override /* BeanContextBuilder */
609   public UrlEncodingSerializerBuilder useEnumNames() {
610      super.useEnumNames();
611      return this;
612   }
613
614   @Override /* BeanContextBuilder */
615   public UrlEncodingSerializerBuilder useInterfaceProxies(boolean value) {
616      super.useInterfaceProxies(value);
617      return this;
618   }
619
620   @Override /* BeanContextBuilder */
621   public UrlEncodingSerializerBuilder useJavaBeanIntrospector(boolean value) {
622      super.useJavaBeanIntrospector(value);
623      return this;
624   }
625
626   @Override /* BeanContextBuilder */
627   public UrlEncodingSerializerBuilder useJavaBeanIntrospector() {
628      super.useJavaBeanIntrospector();
629      return this;
630   }
631
632   @Override /* ContextBuilder */
633   public UrlEncodingSerializerBuilder set(String name, Object value) {
634      super.set(name, value);
635      return this;
636   }
637
638   @Override /* ContextBuilder */
639   public UrlEncodingSerializerBuilder set(boolean append, String name, Object value) {
640      super.set(append, name, value);
641      return this;
642   }
643
644   @Override /* ContextBuilder */
645   public UrlEncodingSerializerBuilder set(Map<String,Object> properties) {
646      super.set(properties);
647      return this;
648   }
649
650   @Override /* ContextBuilder */
651   public UrlEncodingSerializerBuilder add(Map<String,Object> properties) {
652      super.add(properties);
653      return this;
654   }
655
656   @Override /* ContextBuilder */
657   public UrlEncodingSerializerBuilder addTo(String name, Object value) {
658      super.addTo(name, value);
659      return this;
660   }
661
662   @Override /* ContextBuilder */
663   public UrlEncodingSerializerBuilder addTo(String name, String key, Object value) {
664      super.addTo(name, key, value);
665      return this;
666   }
667
668   @Override /* ContextBuilder */
669   public UrlEncodingSerializerBuilder removeFrom(String name, Object value) {
670      super.removeFrom(name, value);
671      return this;
672   }
673
674   @Override /* ContextBuilder */
675   public UrlEncodingSerializerBuilder apply(PropertyStore copyFrom) {
676      super.apply(copyFrom);
677      return this;
678   }
679
680   /**
681    * @deprecated Use {@link Serializer#SERIALIZER_addRootType}.
682    */
683   @Override
684   @Deprecated
685   public UrlEncodingSerializerBuilder abridged(boolean value) {
686      return this;
687   }
688
689   /**
690    * @deprecated Use {@link Serializer#SERIALIZER_addRootType}.
691    */
692   @Override
693   @Deprecated
694   public UrlEncodingSerializerBuilder abridged() {
695      return this;
696   }
697
698   /**
699    * @deprecated {@link #addBeanTypes(boolean)}
700    */
701   @Override
702   @Deprecated
703   public UrlEncodingSerializerBuilder addBeanTypeProperties(boolean value) {
704      this.addBeanTypes(value);
705      return this;
706   }
707}