This project has retired. For details please refer to its Attic page.
UddiSubscribeAssertionStatus xref
View Javadoc
1   /*
2    * Copyright 2001-2013 The Apache Software Foundation.
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   */
17  package org.apache.juddi.samples;
18  
19  import javax.xml.datatype.DatatypeFactory;
20  import org.apache.juddi.jaxb.PrintUDDI;
21  import org.apache.juddi.v3.client.config.UDDIClerk;
22  import org.apache.juddi.v3.client.config.UDDIClient;
23  import org.apache.juddi.v3.client.subscription.ISubscriptionCallback;
24  import org.apache.juddi.v3.client.subscription.SubscriptionCallbackListener;
25  import org.apache.juddi.v3.client.transport.Transport;
26  import org.uddi.api_v3.*;
27  import org.uddi.sub_v3.Subscription;
28  import org.uddi.sub_v3.SubscriptionFilter;
29  import org.uddi.sub_v3.SubscriptionResultsList;
30  
31  /**
32   * Thie class shows you how to create a business and a subscription using UDDI
33   * Subscription asynchronous callbacks for Assertion Status Reports
34   *
35   * @author <a href="mailto:alexoree@apache.org">Alex O'Ree</a>
36   */
37  public class UddiSubscribeAssertionStatus implements ISubscriptionCallback {
38  
39          boolean callbackRecieved = false;
40          private UDDIClerk clerk = null;
41          private UDDIClient client = null;
42  
43          public UddiSubscribeAssertionStatus() {
44                  try {
45                          // create a manager and read the config in the archive; 
46                          // you can use your config file name
47                          client = new UDDIClient("META-INF/simple-publish-uddi.xml");
48                          clerk = client.getClerk("default");
49  
50                  } catch (Exception e) {
51                          e.printStackTrace();
52                  }
53          }
54  
55  
56          public static void main(String args[]) throws Exception {
57                  UddiSubscribeAssertionStatus sp = new UddiSubscribeAssertionStatus();
58                  sp.fire("default");
59          }
60  
61          public void fire(String nodename) throws Exception {
62  
63                  TModel createKeyGenator = UDDIClerk.createKeyGenator("somebusiness", "A test key domain SubscriptionCallbackTest1", "SubscriptionCallbackTest1");
64  
65                  clerk.register(createKeyGenator);
66                  System.out.println("Registered tModel keygen: " + createKeyGenator.getTModelKey());
67  
68                  //setup the business to attach to
69                  BusinessEntity be = new BusinessEntity();
70                  be.setBusinessKey("uddi:somebusiness:somebusinesskey");
71                  be.getName().add(new Name("somebusiness SubscriptionCallbackTest1", null));
72                  be.setBusinessServices(new BusinessServices());
73                  BusinessService bs = new BusinessService();
74                  bs.setBusinessKey("uddi:somebusiness:somebusinesskey");
75                  bs.setServiceKey("uddi:somebusiness:someservicekey");
76                  bs.getName().add(new Name("service SubscriptionCallbackTest1", null));
77                  be.getBusinessServices().getBusinessService().add(bs);
78                  BusinessEntity register = clerk.register(be);
79                  System.out.println("Registered business keygen: " + register.getBusinessKey());
80  
81                  //start up our listener
82                  BindingTemplate start = SubscriptionCallbackListener.start(client, nodename);
83  
84                  //register for callbacks
85                  SubscriptionCallbackListener.registerCallback(this);
86  
87                  Subscription sub = new Subscription();
88                  sub.setNotificationInterval(DatatypeFactory.newInstance().newDuration(1000));
89                  sub.setBindingKey(start.getBindingKey());
90                  sub.setSubscriptionFilter(new SubscriptionFilter());
91                  sub.getSubscriptionFilter().setGetAssertionStatusReport(new GetAssertionStatusReport());
92                  //it's optional
93  
94                  //sub.getSubscriptionFilter().getGetAssertionStatusReport().setCompletionStatus(CompletionStatus.STATUS_COMPLETE);
95                  Subscription subscriptionBiz = clerk.register(sub, clerk.getUDDINode().getApiNode());
96  
97                  System.out.println("Registered GetAssertionStatus subscription key: " + (subscriptionBiz.getSubscriptionKey()) + " bindingkey: " + subscriptionBiz.getBindingKey());
98  
99                  System.out.println("Waiting for callbacks. Now would be a good time to launch either another program or juddi-gui to make some changes. Press any key to stop!");
100 
101                 System.in.read();
102 
103                 SubscriptionCallbackListener.stop(client, nodename, start.getBindingKey());
104                 clerk.unRegisterSubscription(subscriptionBiz.getSubscriptionKey());
105 
106                 clerk.unRegisterTModel(createKeyGenator.getTModelKey());
107 
108                 clerk.unRegisterBusiness("uddi:somebusiness:somebusinesskey");
109 
110         }
111 
112         private PrintUDDI<SubscriptionResultsList> printer = new PrintUDDI<SubscriptionResultsList>();
113 
114         @Override
115         public void handleCallback(SubscriptionResultsList body) {
116                 System.out.println("Callback received!");
117                 System.out.println(printer.print(body));
118         }
119 
120         @Override
121         public void notifyEndpointStopped() {
122                 System.out.println("The endpoint was stopped!");
123         }
124 
125 }