diff options
author | Kjetil Ørbekk <kjetil.orbekk@gmail.com> | 2012-01-10 15:34:55 +0100 |
---|---|---|
committer | Kjetil Ørbekk <kjetil.orbekk@gmail.com> | 2012-01-10 15:34:55 +0100 |
commit | 9a554911174e096b95e99527eac04627400c41ba (patch) | |
tree | 2d36439a69ded1ca54051e3a1636106423c3d7c9 /master |
Initial import of maven projects.
jsonrpc - Common classes.
rpctest - A small xmlrpc project.
master - Android application containing broadcast code and ping service.
Diffstat (limited to 'master')
-rw-r--r-- | master/AndroidManifest.xml | 17 | ||||
-rw-r--r-- | master/pom.xml | 129 | ||||
-rw-r--r-- | master/project.properties | 11 | ||||
-rw-r--r-- | master/src/main/java/com/orbekk/Broadcast.java | 55 | ||||
-rw-r--r-- | master/src/main/java/com/orbekk/ConfigureLog4J.java | 18 | ||||
-rw-r--r-- | master/src/main/java/com/orbekk/HelloAndroidActivity.java | 62 | ||||
-rw-r--r-- | master/src/main/java/com/orbekk/PingServer.java | 50 |
7 files changed, 342 insertions, 0 deletions
diff --git a/master/AndroidManifest.xml b/master/AndroidManifest.xml new file mode 100644 index 0000000..6a596ed --- /dev/null +++ b/master/AndroidManifest.xml @@ -0,0 +1,17 @@ +<?xml version="1.0" encoding="utf-8"?> +<manifest xmlns:android="http://schemas.android.com/apk/res/android" + package="com.orbekk" android:versionCode="1" android:versionName="1.0-SNAPSHOT"> +<uses-permission android:name="android.permission.INTERNET"/> +<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/> + + <application android:icon="@drawable/icon" android:label="@string/app_name"> + <activity android:name=".HelloAndroidActivity"> + <intent-filter> + <action android:name="android.intent.action.MAIN" /> + <category android:name="android.intent.category.LAUNCHER" /> + </intent-filter> + </activity> + </application> + +</manifest> + diff --git a/master/pom.xml b/master/pom.xml new file mode 100644 index 0000000..77fb614 --- /dev/null +++ b/master/pom.xml @@ -0,0 +1,129 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> + <modelVersion>4.0.0</modelVersion> + <groupId>com.orbekk</groupId> + <artifactId>master</artifactId> + <version>1.0-SNAPSHOT</version> + <packaging>apk</packaging> + <name>master</name> + + <dependencies> + <dependency> + <groupId>com.google.android</groupId> + <artifactId>android</artifactId> + <version>2.1.2</version> + <scope>provided</scope> + </dependency> + + <dependency> + <groupId>log4j</groupId> + <artifactId>log4j</artifactId> + <version>1.2.16</version> + </dependency> + + <dependency> + <groupId>commons-logging</groupId> + <artifactId>commons-logging</artifactId> + <version>1.1.1</version> + <scope>provided</scope> + </dependency> + + <dependency> + <groupId>javax.servlet</groupId> + <artifactId>servlet-api</artifactId> + <version>2.5</version> + <scope>provided</scope> + </dependency> + + <dependency> + <groupId>javax.portlet</groupId> + <artifactId>portlet-api</artifactId> + <version>2.0</version> + <scope>provided</scope> + </dependency> + + <dependency> + <groupId>de.mindpipe.android</groupId> + <artifactId>android-logging-log4j</artifactId> + <version>1.0.2</version> + </dependency> + + + <dependency> + <groupId>com.orbekk</groupId> + <artifactId>jsonrpc</artifactId> + <version>0.0-SNAPSHOT</version> + </dependency> + </dependencies> + + <build> + <plugins> + <plugin> + <groupId>com.jayway.maven.plugins.android.generation2</groupId> + <artifactId>android-maven-plugin</artifactId> + <version>3.0.0</version> + <configuration> + <androidManifestFile>${project.basedir}/AndroidManifest.xml</androidManifestFile> + <assetsDirectory>${project.basedir}/assets</assetsDirectory> + <resourceDirectory>${project.basedir}/res</resourceDirectory> + <nativeLibrariesDirectory>${project.basedir}/src/main/native</nativeLibrariesDirectory> + <sdk> + <platform>8</platform> + </sdk> + <deleteConflictingFiles>true</deleteConflictingFiles> + <extractDuplicates>true</extractDuplicates> + <undeployBeforeDeploy>true</undeployBeforeDeploy> + </configuration> + <extensions>true</extensions> + </plugin> + + <plugin> + <artifactId>maven-compiler-plugin</artifactId> + <version>2.3.2</version> + <configuration> + <source>1.6</source> + <target>1.6</target> + </configuration> + </plugin> + </plugins> + <pluginManagement> + <plugins> + <!--This plugin's configuration is used to store Eclipse m2e settings only. It has no influence on the Maven build itself.--> + <plugin> + <groupId>org.eclipse.m2e</groupId> + <artifactId>lifecycle-mapping</artifactId> + <version>1.0.0</version> + <configuration> + <lifecycleMappingMetadata> + <pluginExecutions> + <pluginExecution> + <pluginExecutionFilter> + <groupId> + com.jayway.maven.plugins.android.generation2 + </groupId> + <artifactId> + android-maven-plugin + </artifactId> + <versionRange> + [3.0.0,) + </versionRange> + <goals> + <goal>proguard</goal> + <goal> + generate-sources + </goal> + </goals> + </pluginExecutionFilter> + <action> + <ignore></ignore> + </action> + </pluginExecution> + </pluginExecutions> + </lifecycleMappingMetadata> + </configuration> + </plugin> + </plugins> + </pluginManagement> + </build> +</project> diff --git a/master/project.properties b/master/project.properties new file mode 100644 index 0000000..ea89160 --- /dev/null +++ b/master/project.properties @@ -0,0 +1,11 @@ +# This file is automatically generated by Android Tools. +# Do not modify this file -- YOUR CHANGES WILL BE ERASED! +# +# This file must be checked in Version Control Systems. +# +# To customize properties used by the Ant build system use, +# "ant.properties", and override values to adapt the script to your +# project structure. + +# Project target. +target=android-8 diff --git a/master/src/main/java/com/orbekk/Broadcast.java b/master/src/main/java/com/orbekk/Broadcast.java new file mode 100644 index 0000000..bacde0d --- /dev/null +++ b/master/src/main/java/com/orbekk/Broadcast.java @@ -0,0 +1,55 @@ +package com.orbekk; + +import java.io.IOException; +import java.net.DatagramPacket; +import java.net.DatagramSocket; +import java.net.InetAddress; +import java.net.SocketException; +import java.net.UnknownHostException; + +import org.apache.log4j.Logger; + +import android.content.Context; +import android.net.DhcpInfo; +import android.net.wifi.WifiManager; + +public class Broadcast { + private Context context; + private Logger logger = Logger.getLogger(getClass()); + + public Broadcast(Context context) { + this.context = context; + } + + public InetAddress getBroadcastAddress() { + WifiManager wifi = (WifiManager)context.getSystemService(Context.WIFI_SERVICE); + DhcpInfo dhcp = wifi.getDhcpInfo(); + + int broadcast = (dhcp.ipAddress & dhcp.netmask) | ~dhcp.netmask; + byte[] quads = new byte[4]; + for (int k = 0; k < 4; k++) + quads[k] = (byte) ((broadcast >> k * 8) & 0xFF); + try { + return InetAddress.getByAddress(quads); + } catch (UnknownHostException e) { + logger.warn("Failed to find broadcast address."); + return null; + } + } + + public boolean sendBroadcast(byte[] data, int port) { + try { + DatagramSocket socket = new DatagramSocket(port); + socket.setBroadcast(true); + DatagramPacket packet = new DatagramPacket(data, data.length, getBroadcastAddress(), port); + socket.send(packet); + return true; + } catch (SocketException e) { + logger.warn("Failed to send broadcast.", e.fillInStackTrace()); + return false; + } catch (IOException e) { + logger.warn("Error when sending broadcast.", e.fillInStackTrace()); + return false; + } + } +}
\ No newline at end of file diff --git a/master/src/main/java/com/orbekk/ConfigureLog4J.java b/master/src/main/java/com/orbekk/ConfigureLog4J.java new file mode 100644 index 0000000..e6b1ac5 --- /dev/null +++ b/master/src/main/java/com/orbekk/ConfigureLog4J.java @@ -0,0 +1,18 @@ +package com.orbekk; +import org.apache.log4j.Level; +import android.os.Environment; +import de.mindpipe.android.logging.log4j.LogConfigurator; + +public class ConfigureLog4J { + static { + final LogConfigurator logConfigurator = new LogConfigurator(); + + logConfigurator.setFileName(Environment.getExternalStorageDirectory() + "myapp.log"); + logConfigurator.setRootLevel(Level.DEBUG); + logConfigurator.setUseLogCatAppender(true); + // Set log level of a specific logger + // logConfigurator.setLevel("org.apache", Level.ERROR); + logConfigurator.configure(); + System.err.println("GOT HERE."); + } +}
\ No newline at end of file diff --git a/master/src/main/java/com/orbekk/HelloAndroidActivity.java b/master/src/main/java/com/orbekk/HelloAndroidActivity.java new file mode 100644 index 0000000..a142214 --- /dev/null +++ b/master/src/main/java/com/orbekk/HelloAndroidActivity.java @@ -0,0 +1,62 @@ +package com.orbekk; + +import org.apache.log4j.Level; + +import de.mindpipe.android.logging.log4j.LogConfigurator; +import android.app.Activity; +import android.os.Bundle; +import android.util.Log; + +public class HelloAndroidActivity extends Activity { + + private static String TAG = "master"; + private PingServer pingServer; + + private void configureLog4j() { + final LogConfigurator logConfigurator = new LogConfigurator(); + + //logConfigurator.setFileName(Environment.getExternalStorageDirectory() + "myapp.log"); + logConfigurator.setRootLevel(Level.DEBUG); + logConfigurator.setUseLogCatAppender(true); + logConfigurator.setUseFileAppender(false); + // Set log level of a specific logger + // logConfigurator.setLevel("org.apache", Level.ERROR); + logConfigurator.configure(); + System.err.println("GOT HERE."); + } + + /** + * Called when the activity is first created. + * @param savedInstanceState If the activity is being re-initialized after + * previously being shut down then this Bundle contains the data it most + * recently supplied in onSaveInstanceState(Bundle). <b>Note: Otherwise it is null.</b> + */ + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + + System.setProperty("java.net.preferIPv4Stack", "true"); + System.setProperty("java.net.preferIPv6Addresses", "false"); + + Log.i(TAG, "onCreate"); + configureLog4j(); + setContentView(R.layout.main); + + pingServer = PingServer.createPingServer(10080); + try { + pingServer.start(); + } catch (Exception e) { + throw new RuntimeException(e.getMessage()); + } + + Broadcast broadcast = new Broadcast(this); + broadcast.sendBroadcast("Broadcast test".getBytes(), 10010); + } + + @Override + protected void onDestroy() { + pingServer.stop(); + super.onDestroy(); + } +} + diff --git a/master/src/main/java/com/orbekk/PingServer.java b/master/src/main/java/com/orbekk/PingServer.java new file mode 100644 index 0000000..b1126d4 --- /dev/null +++ b/master/src/main/java/com/orbekk/PingServer.java @@ -0,0 +1,50 @@ +package com.orbekk; + +import org.apache.log4j.Logger; +import org.eclipse.jetty.server.Server; + +import com.googlecode.jsonrpc4j.JsonRpcServer; +import com.orbekk.rpc.PingService; +import com.orbekk.rpc.PingServiceImpl; +import com.orbekk.rpc.RpcHandler; + +public class PingServer { + Server server; + Logger logger = Logger.getLogger(getClass()); + + public PingServer(Server server) { + this.server = server; + } + + public static PingServer createPingServer(int port) { + PingService service = new PingServiceImpl(); + JsonRpcServer jsonServer = new JsonRpcServer(service, PingService.class); + + Server server = new Server(port); + RpcHandler rpcHandler = new RpcHandler(jsonServer); + server.setHandler(rpcHandler); + + return new PingServer(server); + } + + public void start() throws Exception { + logger.info("Starting server."); + server.start(); + } + + public void join() { + try { + server.join(); + } catch (InterruptedException e) { + logger.info("Received InterruptException while waiting for server.", e.fillInStackTrace()); + } + } + + public void stop() { + try { + server.stop(); + } catch (Exception e) { + logger.warn("Exception when stopping server.", e.fillInStackTrace()); + } + } +} |