Permalink
Browse files

first commit.

  • Loading branch information...
1 parent ac63d80 commit 25a6e6b56db23bc079ded8069bfda03463ef9fc1 umi committed Dec 11, 2012
Showing with 367 additions and 0 deletions.
  1. BIN LiveSocketTest.air
  2. +232 −0 src/LiveSocketTest-app.xml
  3. +41 −0 src/LiveSocketTest.as
  4. +45 −0 src/server/Server.as
  5. +49 −0 src/server/SocketService.as
View
Binary file not shown.
@@ -0,0 +1,232 @@
+<?xml version="1.0" encoding="utf-8" standalone="no"?>
+<application xmlns="http://ns.adobe.com/air/application/3.1">
+
+<!-- Adobe AIR Application Descriptor File Template.
+
+ Specifies parameters for identifying, installing, and launching AIR applications.
+
+ xmlns - The Adobe AIR namespace: http://ns.adobe.com/air/application/3.1
+ The last segment of the namespace specifies the version
+ of the AIR runtime required for this application to run.
+
+ minimumPatchLevel - The minimum patch level of the AIR runtime required to run
+ the application. Optional.
+-->
+
+ <!-- A universally unique application identifier. Must be unique across all AIR applications.
+ Using a reverse DNS-style name as the id is recommended. (Eg. com.example.ExampleApplication.) Required. -->
+ <id>LiveSocketTest</id>
+
+ <!-- Used as the filename for the application. Required. -->
+ <filename>LiveSocketTest</filename>
+
+ <!-- The name that is displayed in the AIR application installer.
+ May have multiple values for each language. See samples or xsd schema file. Optional. -->
+ <name>LiveSocketTest</name>
+
+ <!-- A string value of the format <0-999>.<0-999>.<0-999> that represents application version which can be used to check for application upgrade.
+ Values can also be 1-part or 2-part. It is not necessary to have a 3-part value.
+ An updated version of application must have a versionNumber value higher than the previous version. Required for namespace >= 2.5 . -->
+ <versionNumber>0.0.0</versionNumber>
+
+ <!-- A string value (such as "v1", "2.5", or "Alpha 1") that represents the version of the application, as it should be shown to users. Optional. -->
+ <!-- <versionLabel></versionLabel> -->
+
+ <!-- Description, displayed in the AIR application installer.
+ May have multiple values for each language. See samples or xsd schema file. Optional. -->
+ <!-- <description></description> -->
+
+ <!-- Copyright information. Optional -->
+ <!-- <copyright></copyright> -->
+
+ <!-- Publisher ID. Used if you're updating an application created prior to 1.5.3 -->
+ <!-- <publisherID></publisherID> -->
+
+ <!-- Settings for the application's initial window. Required. -->
+ <initialWindow>
+ <!-- The main SWF or HTML file of the application. Required. -->
+ <!-- Note: In Flash Builder, the SWF reference is set automatically. -->
+ <content>[この値は Flash Builder の出力ファイル app.xml に上書きされます。]</content>
+
+ <!-- The title of the main window. Optional. -->
+ <!-- <title></title> -->
+
+ <!-- The type of system chrome to use (either "standard" or "none"). Optional. Default standard. -->
+ <!-- <systemChrome></systemChrome> -->
+
+ <!-- Whether the window is transparent. Only applicable when systemChrome is none. Optional. Default false. -->
+ <!-- <transparent></transparent> -->
+
+ <!-- Whether the window is initially visible. Optional. Default false. -->
+ <!-- <visible></visible> -->
+
+ <!-- Whether the user can minimize the window. Optional. Default true. -->
+ <!-- <minimizable></minimizable> -->
+
+ <!-- Whether the user can maximize the window. Optional. Default true. -->
+ <maximizable>false</maximizable>
+
+ <!-- Whether the user can resize the window. Optional. Default true. -->
+ <resizable>false</resizable>
+
+ <!-- The window's initial width in pixels. Optional. -->
+ <!-- <width></width> -->
+
+ <!-- The window's initial height in pixels. Optional. -->
+ <!-- <height></height> -->
+
+ <!-- The window's initial x position. Optional. -->
+ <!-- <x></x> -->
+
+ <!-- The window's initial y position. Optional. -->
+ <!-- <y></y> -->
+
+ <!-- The window's minimum size, specified as a width/height pair in pixels, such as "400 200". Optional. -->
+ <!-- <minSize></minSize> -->
+
+ <!-- The window's initial maximum size, specified as a width/height pair in pixels, such as "1600 1200". Optional. -->
+ <!-- <maxSize></maxSize> -->
+
+ <!-- The initial aspect ratio of the app when launched (either "portrait" or "landscape"). Optional. Mobile only. Default is the natural orientation of the device -->
+
+ <!-- <aspectRatio></aspectRatio> -->
+
+ <!-- Whether the app will begin auto-orienting on launch. Optional. Mobile only. Default false -->
+
+ <!-- <autoOrients></autoOrients> -->
+
+ <!-- Whether the app launches in full screen. Optional. Mobile only. Default false -->
+
+ <!-- <fullScreen></fullScreen> -->
+
+ <!-- The render mode for the app (either auto, cpu, gpu, or direct). Optional. Default auto -->
+
+ <!-- <renderMode></renderMode> -->
+
+ <!-- Whether or not to pan when a soft keyboard is raised or lowered (either "pan" or "none"). Optional. Defaults "pan." -->
+ <!-- <softKeyboardBehavior></softKeyboardBehavior> -->
+ <autoOrients>false</autoOrients>
+ <fullScreen>false</fullScreen>
+ <visible>true</visible>
+ </initialWindow>
+
+ <!-- We recommend omitting the supportedProfiles element, -->
+ <!-- which in turn permits your application to be deployed to all -->
+ <!-- devices supported by AIR. If you wish to restrict deployment -->
+ <!-- (i.e., to only mobile devices) then add this element and list -->
+ <!-- only the profiles which your application does support. -->
+ <!-- <supportedProfiles>desktop extendedDesktop mobileDevice extendedMobileDevice</supportedProfiles> -->
+
+ <!-- The subpath of the standard default installation location to use. Optional. -->
+ <!-- <installFolder></installFolder> -->
+
+ <!-- The subpath of the Programs menu to use. (Ignored on operating systems without a Programs menu.) Optional. -->
+ <!-- <programMenuFolder></programMenuFolder> -->
+
+ <!-- The icon the system uses for the application. For at least one resolution,
+ specify the path to a PNG file included in the AIR package. Optional. -->
+ <!-- <icon>
+ <image16x16></image16x16>
+ <image32x32></image32x32>
+ <image36x36></image36x36>
+ <image48x48></image48x48>
+ <image57x57></image57x57>
+ <image72x72></image72x72>
+ <image114x114></image114x114>
+ <image128x128></image128x128>
+ </icon> -->
+
+ <!-- Whether the application handles the update when a user double-clicks an update version
+ of the AIR file (true), or the default AIR application installer handles the update (false).
+ Optional. Default false. -->
+ <!-- <customUpdateUI></customUpdateUI> -->
+
+ <!-- Whether the application can be launched when the user clicks a link in a web browser.
+ Optional. Default false. -->
+ <!-- <allowBrowserInvocation></allowBrowserInvocation> -->
+
+ <!-- Listing of file types for which the application can register. Optional. -->
+ <!-- <fileTypes> -->
+
+ <!-- Defines one file type. Optional. -->
+ <!-- <fileType> -->
+
+ <!-- The name that the system displays for the registered file type. Required. -->
+ <!-- <name></name> -->
+
+ <!-- The extension to register. Required. -->
+ <!-- <extension></extension> -->
+
+ <!-- The description of the file type. Optional. -->
+ <!-- <description></description> -->
+
+ <!-- The MIME content type. -->
+ <!-- <contentType></contentType> -->
+
+ <!-- The icon to display for the file type. Optional. -->
+ <!-- <icon>
+ <image16x16></image16x16>
+ <image32x32></image32x32>
+ <image48x48></image48x48>
+ <image128x128></image128x128>
+ </icon> -->
+
+ <!-- </fileType> -->
+ <!-- </fileTypes> -->
+
+ <!-- iOS specific capabilities -->
+ <!-- <iPhone> -->
+ <!-- A list of plist key/value pairs to be added to the application Info.plist -->
+ <!-- <InfoAdditions>
+ <![CDATA[
+ <key>UIDeviceFamily</key>
+ <array>
+ <string>1</string>
+ <string>2</string>
+ </array>
+ <key>UIStatusBarStyle</key>
+ <string>UIStatusBarStyleBlackOpaque</string>
+ <key>UIRequiresPersistentWiFi</key>
+ <string>YES</string>
+ ]]>
+ </InfoAdditions> -->
+ <!-- A list of plist key/value pairs to be added to the application Entitlements.plist -->
+ <!-- <Entitlements>
+ <![CDATA[
+ <key>keychain-access-groups</key>
+ <array>
+ <string></string>
+ <string></string>
+ </array>
+ ]]>
+ </Entitlements> -->
+ <!-- Display Resolution for the app (either "standard" or "high"). Optional. Default "standard" -->
+ <!-- <requestedDisplayResolution></requestedDisplayResolution> -->
+ <!-- </iPhone> -->
+
+ <!-- Specify Android specific tags that get passed to AndroidManifest.xml file. -->
+ <!--<android> -->
+ <!-- <manifestAdditions>
+ <![CDATA[
+ <manifest android:installLocation="auto">
+ <uses-permission android:name="android.permission.INTERNET"/>
+ <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
+ <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
+ <uses-feature android:required="true" android:name="android.hardware.touchscreen.multitouch"/>
+ <application android:enabled="true">
+ <activity android:excludeFromRecents="false">
+ <intent-filter>
+ <action android:name="android.intent.action.MAIN"/>
+ <category android:name="android.intent.category.LAUNCHER"/>
+ </intent-filter>
+ </activity>
+ </application>
+ </manifest>
+ ]]>
+ </manifestAdditions> -->
+ <!-- Color depth for the app (either "32bit" or "16bit"). Optional. Default 16bit before namespace 3.0, 32bit after -->
+ <!-- <colorDepth></colorDepth> -->
+ <!-- </android> -->
+ <!-- End of the schema for adding the android specific tags in AndroidManifest.xml file -->
+
+</application>
View
@@ -0,0 +1,41 @@
+package
+{
+ import flash.display.Sprite;
+ import flash.net.Socket;
+ import flash.text.TextField;
+
+ import server.Server;
+
+[SWF(width="620", height="220", backgroundColor="0xFFCC00", frameRate="30")]
+
+ public class LiveSocketTest extends Sprite
+ {
+ private var txt:TextField;
+ private var server:Server;
+
+ public function LiveSocketTest(){
+ txt = _createText();
+ addChild(txt);
+
+ server = new Server(_log);
+ }
+
+ private function _createText():TextField{
+ var text:TextField = new TextField();
+ text.x = 10;
+ text.y = 10;
+ text.width = 600;
+ text.height = 200;
+ text.background = true;
+ text.backgroundColor = 0xFFFF99;
+ text.border = true;
+
+ return text;
+ }
+
+ private function _log(t:String):void{
+ txt.appendText(t + "\n");
+ txt.scrollV++;
+ }
+ }
+}
View
@@ -0,0 +1,45 @@
+package server
+{
+ import flash.events.Event;
+ import flash.events.ServerSocketConnectEvent;
+ import flash.net.ServerSocket;
+ import flash.net.Socket;
+
+ public class Server
+ {
+ private var serverSocket:ServerSocket;
+ private var clientSockets:Array;
+ private var log:Function;
+
+ public function Server(l:Function){
+ log = l;
+ clientSockets = new Array();
+ try{
+ serverSocket = new ServerSocket();
+ serverSocket.addEventListener(ServerSocketConnectEvent.CONNECT, _onConnectHandler);
+ serverSocket.addEventListener(Event.CLOSE, _onCloseHandler);
+ serverSocket.bind(8888, "127.0.0.1");
+ serverSocket.listen();
+ log(serverSocket.localPort + " port listening.");
+ }catch(e:Error){
+ log(e);
+ }
+ }
+
+ private function _onConnectHandler(e:ServerSocketConnectEvent):void{
+ var socketService:SocketService = new SocketService(e.socket, log);
+ socketService.addEventListener(Event.CLOSE, _onClientClose);
+ clientSockets.push(socketService);
+ }
+
+ private function _onClientClose(e:Event):void{
+ for each(var service:SocketService in clientSockets){
+ if(service.closed) service = null;
+ }
+ }
+
+ private function _onCloseHandler(e:Event):void{
+ log("socket closed.");
+ }
+ }
+}
@@ -0,0 +1,49 @@
+package server
+{
+ import flash.events.Event;
+ import flash.events.EventDispatcher;
+ import flash.events.IOErrorEvent;
+ import flash.events.ProgressEvent;
+ import flash.net.Socket;
+
+ public class SocketService extends EventDispatcher
+ {
+ private var socket:Socket;
+ private var log:Function;
+
+ public function SocketService(s:Socket, l:Function){
+ socket = s;
+ log = l;
+ socket.addEventListener(ProgressEvent.SOCKET_DATA, _socketDataHandler);
+ socket.addEventListener(Event.CLOSE, _onClientClose);
+ socket.addEventListener(IOErrorEvent.IO_ERROR, _onIOError);
+ log("connect " + socket.remoteAddress + ":" + socket.remotePort);
+ }
+
+ private function _socketDataHandler(e:ProgressEvent):void{
+ var socket:Socket = e.target as Socket;
+ var msg:String = socket.readUTFBytes(socket.bytesAvailable);
+ log("receive " + msg);
+ if(msg == "<policy-file-request/>"){
+ var policy:String = '<cross-domain-policy><allow-access-from domain="*" to-ports="8888" /></cross-domain-policy>\x00';
+ socket.writeUTFBytes(policy);
+ socket.flush();
+ }
+ }
+
+ private function _onClientClose(e:Event):void{
+ var socket:Socket = e.target as Socket;
+ log("close " + socket.remoteAddress + ":" + socket.remotePort);
+ dispatchEvent(new Event(Event.CLOSE));
+ }
+
+ private function _onIOError(e:IOErrorEvent):void{
+ log("IOError: " + e.text);
+ socket.close();
+ }
+
+ public function get closed():Boolean{
+ return socket.connected;
+ }
+ }
+}

0 comments on commit 25a6e6b

Please sign in to comment.