summaryrefslogtreecommitdiffstats
path: root/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java
diff options
context:
space:
mode:
Diffstat (limited to 'sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java')
-rw-r--r--sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/Expert.java67
-rw-r--r--sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/atom/AtomExpertiseLocator.java130
-rw-r--r--sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/atom/ExpertiseLocator.java29
-rw-r--r--sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/launch/Launch.java34
4 files changed, 260 insertions, 0 deletions
diff --git a/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/Expert.java b/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/Expert.java
new file mode 100644
index 0000000000..5bc3325a18
--- /dev/null
+++ b/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/Expert.java
@@ -0,0 +1,67 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package org.apache.tuscany.expertise;
+
+import java.io.Serializable;
+import java.util.ArrayList;
+import java.util.List;
+
+import org.apache.tuscany.expertise.Expert;
+
+public class Expert implements Serializable {
+ private static final long serialVersionUID = 2026687637313310397L;
+
+ private String id;
+ private String name;
+ private String location;
+ private List<String> expertises = new ArrayList<String>();
+
+ public Expert() {
+
+ }
+
+ public String getId() {
+ return id;
+ }
+
+ public void setId(String id) {
+ this.id = id;
+ }
+
+ public String getName() {
+ return name;
+ }
+
+ public void setName(String name) {
+ this.name = name;
+ }
+
+ public String getLocation() {
+ return location;
+ }
+
+ public void setLocation(String location) {
+ this.location = location;
+ }
+
+ public List<String> getExpertise() {
+ return this.expertises;
+ }
+
+}
diff --git a/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/atom/AtomExpertiseLocator.java b/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/atom/AtomExpertiseLocator.java
new file mode 100644
index 0000000000..a2fde8f938
--- /dev/null
+++ b/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/atom/AtomExpertiseLocator.java
@@ -0,0 +1,130 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+package org.apache.tuscany.expertise.atom;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import org.apache.tuscany.expertise.Expert;
+import org.apache.tuscany.sca.data.collection.Entry;
+import org.apache.tuscany.sca.data.collection.NotFoundException;
+import org.osoa.sca.annotations.Init;
+import org.osoa.sca.annotations.Scope;
+
+@Scope("COMPOSITE")
+public class AtomExpertiseLocator implements ExpertiseLocator {
+
+ private Map<String, Expert> experts = new HashMap<String, Expert>();
+
+ @Init
+ public void init() {
+ Expert expert;
+
+ expert = new Expert();
+ expert.setId("1");
+ expert.setName("John Smith");
+ expert.setLocation("CA");
+ expert.getExpertise().add("SOA");
+ expert.getExpertise().add("SCA");
+ expert.getExpertise().add("WAS");
+
+ experts.put(expert.getId(), expert);
+
+ expert = new Expert();
+ expert.setId("2");
+ expert.setName("Ken Johnson");
+ expert.setLocation("NY");
+ expert.getExpertise().add("Search");
+
+ experts.put(expert.getId(), expert);
+
+ expert = new Expert();
+ expert.setId("3");
+ expert.setName("Mark Smith");
+ expert.setLocation("CA");
+ expert.getExpertise().add("SCA");
+ expert.getExpertise().add("WASCE");
+
+ experts.put(expert.getId(), expert);
+ }
+
+
+ public Entry<String, Expert>[] getAll() {
+ Entry<String, Expert>[] entries = new Entry[experts.size()];
+ int i = 0;
+ for (Map.Entry<String, Expert> e: experts.entrySet()) {
+ entries[i++] = new Entry<String, Expert>(e.getKey(), e.getValue());
+ }
+ return entries;
+
+ }
+
+ public Expert get(String key) throws NotFoundException {
+ Expert item = experts.get(key);
+ if (item == null) {
+ throw new NotFoundException(key);
+ } else {
+ return item;
+ }
+ }
+
+ public String post(String key, Expert item) {
+ if (key == null) {
+ int size = experts.entrySet().size() + 1;
+ key = Integer.toString(size);
+ item.setId(key);
+ }
+ experts.put(key, item);
+ return key;
+ }
+
+ public void put(String key, Expert item) throws NotFoundException {
+ if (!experts.containsKey(key)) {
+ throw new NotFoundException(key);
+ }
+ experts.put(key, item);
+ }
+
+ public void delete(String key) throws NotFoundException {
+ if (key == null || key.equals("")) {
+ experts.clear();
+ } else {
+ Expert expert = experts.remove(key);
+ if (expert == null)
+ throw new NotFoundException(key);
+ }
+ }
+
+ public Entry<String, Expert>[] query(String queryString) {
+ List<Entry<String, Expert>> entries = new ArrayList<Entry<String,Expert>>();
+ if (queryString.startsWith("location=")) {
+ String location = queryString.substring(9);
+ for (Map.Entry<String, Expert> e: experts.entrySet()) {
+ Expert expert = e.getValue();
+ if (expert.getLocation().equals(location)) {
+ entries.add(new Entry<String, Expert>(e.getKey(), e.getValue()));
+ }
+ }
+ }
+ return entries.toArray(new Entry[entries.size()]);
+ }
+}
diff --git a/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/atom/ExpertiseLocator.java b/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/atom/ExpertiseLocator.java
new file mode 100644
index 0000000000..84683528cc
--- /dev/null
+++ b/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/atom/ExpertiseLocator.java
@@ -0,0 +1,29 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+package org.apache.tuscany.expertise.atom;
+
+import org.apache.tuscany.expertise.Expert;
+import org.apache.tuscany.sca.data.collection.Collection;
+import org.osoa.sca.annotations.Remotable;
+
+@Remotable
+public interface ExpertiseLocator extends Collection<String, Expert> {
+
+}
diff --git a/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/launch/Launch.java b/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/launch/Launch.java
new file mode 100644
index 0000000000..eb82100092
--- /dev/null
+++ b/sandbox/lresende/sca-1.x/samples/expertise-atom/src/main/java/org/apache/tuscany/expertise/launch/Launch.java
@@ -0,0 +1,34 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+package org.apache.tuscany.expertise.launch;
+
+import org.apache.tuscany.sca.host.embedded.SCADomain;
+
+public class Launch {
+ public static void main(String[] args) throws Exception {
+ System.out.println("Starting ...");
+ SCADomain scaDomain = SCADomain.newInstance("atom.composite");
+ System.out.println("atom.composite ready for big business !!!");
+ System.in.read();
+ System.out.println("Stopping ...");
+ scaDomain.close();
+ System.out.println();
+ }
+}