View Javadoc
1   /*
2    * Copyright (C) 2013 4th Line GmbH, Switzerland
3    *
4    * The contents of this file are subject to the terms of either the GNU
5    * Lesser General Public License Version 2 or later ("LGPL") or the
6    * Common Development and Distribution License Version 1 or later
7    * ("CDDL") (collectively, the "License"). You may not use this file
8    * except in compliance with the License. See LICENSE.txt for more
9    * information.
10   *
11   * This program is distributed in the hope that it will be useful,
12   * but WITHOUT ANY WARRANTY; without even the implied warranty of
13   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
14   */
15  package org.fourthline.cling.support.model.dlna.message.header;
16  
17  import org.fourthline.cling.model.ServiceReference;
18  import org.fourthline.cling.model.message.header.InvalidHeaderException;
19  
20  /**
21   * @author Mario Franco
22   */
23  public class PeerManagerHeader extends DLNAHeader<ServiceReference> {
24  
25      public PeerManagerHeader() {
26      }
27  
28      @Override
29      public void setString(String s) throws InvalidHeaderException {
30          if (s.length() != 0) {
31              try {
32                  ServiceReference serviceReference = new ServiceReference(s);
33                  if (serviceReference.getUdn()!=null && serviceReference.getServiceId()!=null) {
34                      setValue(serviceReference);
35                      return;
36                  }
37              } catch (Exception ex) {
38              }
39          }
40          throw new InvalidHeaderException("Invalid PeerManager header value: " + s);
41      }
42  
43      @Override
44      public String getString() {
45          return getValue().toString();
46      }
47  }