001 /*
002 * Licensed to the Apache Software Foundation (ASF) under one
003 * or more contributor license agreements. See the NOTICE file
004 * distributed with this work for additional information
005 * regarding copyright ownership. The ASF licenses this file
006 * to you under the Apache License, Version 2.0 (the
007 * "License"); you may not use this file except in compliance
008 * with the License. You may obtain a copy of the License at
009 *
010 * http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing,
013 * software distributed under the License is distributed on an
014 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
015 * KIND, either express or implied. See the License for the
016 * specific language governing permissions and limitations
017 * under the License.
018 */
019
020 package javax.mail.internet;
021
022 // http://www.faqs.org/rfcs/rfc2183.html
023
024 /**
025 * @version $Rev: 669445 $ $Date: 2008-06-19 06:48:18 -0400 (Thu, 19 Jun 2008) $
026 */
027 public class ContentDisposition {
028 private String _disposition;
029 private ParameterList _list;
030
031 public ContentDisposition() {
032 setDisposition(null);
033 setParameterList(null);
034 }
035
036 public ContentDisposition(String disposition) throws ParseException {
037 // get a token parser for the type information
038 HeaderTokenizer tokenizer = new HeaderTokenizer(disposition, HeaderTokenizer.MIME);
039
040 // get the first token, which must be an ATOM
041 HeaderTokenizer.Token token = tokenizer.next();
042 if (token.getType() != HeaderTokenizer.Token.ATOM) {
043 throw new ParseException("Invalid content disposition");
044 }
045
046 _disposition = token.getValue();
047
048 // the remainder is parameters, which ParameterList will take care of parsing.
049 String remainder = tokenizer.getRemainder();
050 if (remainder != null) {
051 _list = new ParameterList(remainder);
052 }
053 }
054
055 public ContentDisposition(String disposition, ParameterList list) {
056 setDisposition(disposition);
057 setParameterList(list);
058 }
059
060 public String getDisposition() {
061 return _disposition;
062 }
063
064 public String getParameter(String name) {
065 if (_list == null) {
066 return null;
067 } else {
068 return _list.get(name);
069 }
070 }
071
072 public ParameterList getParameterList() {
073 return _list;
074 }
075
076 public void setDisposition(String string) {
077 _disposition = string;
078 }
079
080 public void setParameter(String name, String value) {
081 if (_list == null) {
082 _list = new ParameterList();
083 }
084 _list.set(name, value);
085 }
086
087 public void setParameterList(ParameterList list) {
088 if (list == null) {
089 _list = new ParameterList();
090 } else {
091 _list = list;
092 }
093 }
094
095 public String toString() {
096 // it is possible we might have a parameter list, but this is meaningless if
097 // there is no disposition string. Return a failure.
098 if (_disposition == null) {
099 return null;
100 }
101
102
103 // no parameter list? Just return the disposition string
104 if (_list == null) {
105 return _disposition;
106 }
107
108 // format this for use on a Content-Disposition header, which means we need to
109 // account for the length of the header part too.
110 return _disposition + _list.toString("Content-Disposition".length() + _disposition.length());
111 }
112 }