martedì 26 gennaio 2010

Get Ldap data with SQL

Do you work with Oracle Database?
Have you ever thought that you'd rather use a plain Oracle table than dealing with LDAP?

If the answer is yes, keep reading.

With this tiny PL/SQL package (downloadable here) you can access an LDAP Directory, formulate a query and get a table result.

Follow this simple example:
  • Download the package, unzip it and install it in any database schema. It needs only access (execute grant) to the DBMS_LDAP package.
  • Try (first) this query:
  • select c1 from table(TL.ask('&(cn=SMITH*)',null,'C=IT', 'certificati.postecert.it', 'mail,cn,uid,sn' ));
    
  • Then dare a bit more structured examples:

SELECT tl.f (c1, 1) mail, tl.f (c1, 2) cn, tl.f (c1, 3) u_id, tl.f (c1, 4) sn
  FROM TABLE (tl.ask ('&(cn=SMITH*)',   -- Query Conditions
                      NULL,             -- Unique ID Condition
                      'C=IT',           -- Base dn
                      'certificati.postecert.it', -- Ldap Address
                      'mail,cn,uid,sn'  -- Attributes
                     )
             );

SELECT tl.f (c1, 1) mail, tl.f (c1, 2) nomeresp, tl.f (c1, 3) cognomeresp,
       tl.f (c1, 4) description, tl.f (c1, 5) mails
  FROM TABLE (tl.ask ('&(CognomeResp=Blas*)',  -- Query Conditions
                      NULL,                    -- Unique ID Condition
                      'c=it',                  -- Base dn 
                      'indicepa.gov.it',       -- Ldap Address 
       -- Attributes (fields)
                      'mail,NomeResp,CognomeResp,description,mailS'                      )
             );

If you find it useful and you’d like technical details, just post a comment and we will try to accomplish.

Have fun

venerdì 22 gennaio 2010

Retrieving Mail with Java


Software Designers and Programmers don't make a great use of incoming mail automation.
It is a pity, because handling incoming mail can offer important application advantages.
We try to explain why with the help of 2 small scenarios:

Replies to Invitations/Surveys Processing


Let’s imagine that you send mail to a group of people in order to invite them to an event, make a survey, or some other scope.
After the sending, you have to process replies, by means of:

  • a Form in an Internet/Application (costly and awkward for the user),
  • a Secretary that receives and registers replies from people involved,
  • a simple Reply to the mail

In this last case you don’t need to have an internet application (hosted by some provider) or dedicated human resources.

Document Management


If you deal with a Document Management system you know well that the activity most annoying for users is to upload files into the System.
You can easily make the System do it by itself just sending a mail to the proper MailBox.

How to write a class for incoming mail handling


Now, we are going to explain how manage mail retrieval with Java.

Additional Library


The first, trivial but important issue is that you need to download to an additional (javax.mail) library, not generally included into J2EE Application Servers.

We need to use the following classes:

  • javax.mail.Session: represents a mail session
  • javax.mail.Store: an abstract class that models a message store and its access protocol, for storing and retrieving messages
  • javax.mail.Folder: An abstract class that represents a folder for mail messages
  • javax.mail.Message: Represents an email message

Coding Step by Step


First of all get a Session object:
Properties props = new Properties(); 
Session session = Session.getDefaultInstance(props, null); 

and then make a connection to the Store with the getStore() method::

Store store = session.getStore(“pop3”);

From the Store object we can connect to server with three parameters: host, username and password:

String host = "mypop.it";
String username = "myusername";
String password = "mypassword";
store.connect(host, username, password);

Once we are connected, we need to access the appropriate Folder before mail retrieval.

If POP mail is used, only one folder is available, INBOX.
In case of IMAP Server type, the Folder can be INBOX or any other folder name that was set up. Assuming you want to read mail from your INBOX, simply connect to the folder with the getFolder() method of Session and then open the Folder with the open() method:

Folder folder = store.getFolder("INBOX");     
folder.open(Folder.READ_WRITE); 

You can use the getMessage() method to get an individual message, or as in the following example, use the getMessages() method to get all the messages::

Message[] messages = folder.getMessages(); 

Now, for example, we can save all messages in a directory:

for (int i = 0; i < messages.length; i++){
File mymail = new File(“C:/dir_email/nome_email.eml”);
OutputStream out=new FileOutputStream(mymail);              
mess[i].writeTo(out); 
mess[i].setFlag(Flags.Flag.DELETED,true); /*set flag=true to delete file */
}
Finally, close folder and connection:
folder.close(true); 
store.close(); 



Complete example

A complete example can be retrieved here: ServiceMail.java.

sabato 16 gennaio 2010

Flash Charts Step by Step Instructions

Here you can find the instructions for building the Flash Charts described in our previous post.

Download and Test


  • First of all, download here the Plotgen Working Demo.
  • Then unzip it into a Web Folder. Important!! Flash requires a folder pointed out by a Web/Application Server for security reasons.
  • Last, from your browser call the URL of PLOTGEN.htnl or index.html and check that all is working properly.
    If not, check Flash plugin (it must be version 9 or above).

How it works


  • Prepare, in your HTML Page, a DIV element (html container) where the Chart will appear
  • Write an XML Document containing Chart Data and Metadata (check the living demo for instructions)
  • Call the javascript function loadSWF passing the name of the SWF object (PLOTGEN), the ID of the (html container) and the XML document Text
  • That's all. All the code you may need (and more) is in the plot.js file.
  • The example shows how to have multiple occurrences of the same SWF object customized in different ways.


The html Container


You can position the chart into any html container (span, div...); you have to declare the container dimensions (width and height), like in the following code:
<div id="myDiv" style="width:200px;height:200px;"></div>


SWF file loading


The function loadSWF performs the loading. Here is the code:
function loadSWF(swf_id, cont_id,num_in, parms_in) {
  if (!num_in) num_in=0;
  try {
   if (swf_id.indexOf(".")>0) swf_id.substring(0,swf_id.indexOf("."));
   var cont=I$(cont_id); if (!cont) {alert("No cont "+cont_id); return;}
   var wdt=parseInt(cont.offsetWidth); var hdt=parseInt(cont.offsetHeight);
   if (wdt<100) wdt=screen.availWidth;
   if (hdt<100) hdt=400;
   var flashvars = {};
   var params = {menu: "true", quality:"high", play: "false", wmode : "transparent"};
   var attributes = {};
   var X='<object  classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" id="'+cont_id+'_swf" width="100%" height="100%" codebase="http://fpdownload.macromedia.com/get/flashplayer/current/swflash.cab">';
   X+='<param name="movie" value="'+swf_id+'.swf" />';
   X+='<param name="wmode" value="transparent"  />';
   X+='<param name="flashvars" value="bridgeName=flex'+num_in;
   if (parms_in!=null && parms_in.length>0) X+='&'+parms_in;
   X+='"/>';
   X+='<param name="quality" value="high" />';
   X+='<param name="allowScriptAccess" value="sameDomain" />';
   X+='<embed src="'+swf_id+'.swf" quality="high" flashvars="bridgeName=flex'+num_in;
   if (parms_in!=null && parms_in.length>0) X+='&'+parms_in;
   X+='" ';
   X+='width="100%" height="400px" name="'+swf_id+'" align="middle" ';
   X+='play="true" loop="false" quality="high" wmode="transparent" allowScriptAccess="sameDomain" ';
   X+='type="application/x-shockwave-flash" ';
   X+='pluginspage="http://www.adobe.com/go/getflashplayer">';
   X+='</embed></object>';
   cont.innerHTML=X;
   cont.setAttribute("hasObj",1);
  }
  catch (exception) {}
 }

Well, the code for building the param and embed elements is mostly given from Adobe as it is for this kind of operations.
The only issues you have to notice are:
  • swf_id is the path/URL of the SWF object. In out case PLOTGEN (you can omit the extension).
  • cont_id is the id of the html object in which the Chart will appear (in our case myDiv)
  • num_in if the number of the Chart in the page
  • parms_in are the additional parameters that will be transmitted to the Flash object: in our case the XML file with customization
  • Notice this: param name="flashvars" value="bridgeName=flex'+num_in: it is needed to give the right communication path at each Flash object
This code puts and activate the Flash Object into our DIV.

Chart Customization


PLOTGEN.swf is a single Flash Object but it can show different Chart Types, like in our example.
The bast way to learn the commands is to follow the Live Demo. Here we explain how to change with javascript the Chart appearance:

  • If it is the first time the Plot is generated, the function loadSWF is called; the XML is passed into the md parameter (into parm_in)
  • otherwise, the md parameters is directly communicated to the Flash Object by means of the function freshJS
  • The communication between javascript and Flash is managed with FABridge; you have to study that only if you are going to develop in flex
  • All this logic is in the following function (called plot)

function plot(MDin,num_in) { var parms=null;
 var swf_id='PLOTGEN';
 if (!num_in) num_in=0;
 if (MDin) {var re=/\</g; MDin=MDin.replace(re,"[");
  var re=/\>/g; MDin=MDin.replace(re,"]");
  var re=/\"/g; MDin=MDin.replace(re,"^");
  parms='md='+MDin;
  try {
   if ( !flexApps[num_in]) {var myfunct= new Function("return FABridge.flex"+num_in+".root();");
   flexApps[num_in]= myfunct(); }
   flexApps[num_in].freshJS(MDin);
  }
  catch (exception)
  { loadSWF(swf_id, "swf"+num_in, num_in, parms);} 
 }
 else loadSWF(swf_id, "swf"+num_in, num_in, null);
 }

  • Following is the code for building the MD parameter:
var sa='';
  sa+='<plot>\n';
  sa+='<md graphtype="col" palette="azzurro" urlDefault="plotdefault.xml"\n';
  sa+=' mis3="Physicians/1000"  mis2="Hospital Beds/1000" mis1="Smokers/100" \n';
  sa+=' dim1="Countries"\n';
  sa+=' WallsColors="#00,#999999" WallsAphas="0.1,0.6" WallsAngle="90" \n';
  sa+=' fillColors="#dddddd,#aaaaaa" fillAlphas=".5,.5" labelColorX="#444" labelColorY="#444" />\n';
  sa+=' <dim1>\n';
  sa+='  <d key="Austria" mis3="3.4"  mis2="8.8" mis1="36.3" />\n';
  sa+='  <d key="France"  mis3="3.37" mis2="8.4" mis1="27.0" />\n';
  sa+='  <d key="Germany" mis3="3.4"  mis2="9.2" mis1="24.3" />\n';
  sa+='  <d key="Italy"   mis3="4.2"  mis2="4.9" mis1="24.2" />\n';
  sa+='  <d key="Japan"   mis3="2.0"  mis2="16.4" mis1="30.3" />\n';
  sa+='  <d key="Spain"   mis3="3.2"  mis2="4.1" mis1="28.1" />\n';
  sa+='  <d key="UK"      mis3="2.2"  mis2="4.1" mis1="26.0" />\n';
  sa+='  <d key="USA"     mis3="2.2"  mis2="3.6" mis1="17.5" />\n';
  sa+=' </dim1>\n';
  sa+='</plot>\n';


Chart and Palette Defaults


We don't need to communicate each time all the parameters. We have a special XML Document that supplies default data and color palettes. Its name is pointed by the urlDefault attribute into the Customization XML (urlDefault ="plotdefault.xml").

Here is the XML Document we used into the Demo. If you don't dislike the result, you can just ignore it.

<plotdefault>
<md graphtype="clusterpie" curPalette="Skyblu" alpha="0.9" fillColors="#dddddd,#444444" fillAlphas="0.5,0.5" showlegend="y" labelColor="#444" 
WallsColors="#111,#eee" WallsAphas="0.9,0.1" />
<palettes>
 <p key="orange" values="#F9B832,#D53825,#AA1C09,#F99831,#D36800" />
 <p key="redviolet" values="#E92011,#AB0A29,#7D155F,#3F1595,#2B2BBD" />  
 <p key="azzurro" values="#107FC9,#0E4EAD,#0B108C,#0C0F66,#07093D" /> 
 <p key="blu" values="#5081B5,#36689E,#22558C,#0D3D70,#022245" /> 
 <p key="PD" values="#3E9865,#300901,#7E1A1C,#3F835D,#530709" /> 
 <p key="blu" values="#003E5F,#025D8C,#107FC9,#23B0DB,#1693A5" /> 
 <p key="petrolio" values="#000018,#001830,#003048,#187860,#F0A830" /> 
 <p key="zucchero" values="#07629B,#215A7D,#38525E,#574A49,#6F4221" /> 
 <p key="reddish" values="#B83422,#DA5D3E,#D49B93,#C46D33,#996E31" /> 
 <p key="terra" values="#4D2922,#713327,#9A402E,#AF4C38,#C55B49" /> 
 <p key="ocra" values="#EFAC41,#DE8531,#B32900,#6C1305,#330A04" /> 
 <p key="ciliegia" values="#D11C1C,#9E0B0B,#5E0505,#E76969,#DF3E3E" /> 
 <p key="militare" values="#EDE3A1,#EDB83B,#ED7F3B,#ED5311,#ED3013" /> 
 <p key="rosso" values="#F9D4C2,#AF3236,#7E1A1C,#530709,#300901" /> 
 <p key="viola" values="#9E0B03,#BA2222,#C4423B,#936AB0,#714C8C" /> 
 <p key="gialloblu" values="#DA9F16,#D8D830,#909030,#186078,#184878" /> 
 <p key="verde" values="#219652,#146629,#093B15,#05260E,#021206" /> 
 <p key="verdechiaro" values="#BEFF9E,#73CC59,#4D994D,#266640,#003333" /> 
 <p key="grigio" values="#90BECE,#79ACB0,#6C9E9D,#5D8B8B ,#4D716F" /> 
 <p key="grigioblu" values="#90BECE,#79ACB0,#5D8B8B ,#4D716F,#022245" /> 
 <p key="grigioverde" values="#C5BE88,#AC966F,#3E664B,#204B41,#274432" />
</palettes>
</plotdefault>

sabato 9 gennaio 2010

Advanced (but easy) Flash Charts

You are looking for a Data Visualization Tool with great impact but easy and quick to implement? We did, too, but without success for the second issue. So, we took the more impressive Charts we could find (ILOG Elixir and Axiis) and realized an interface easy to use with just a bit of javascript.

First of all, let’us have a look. If you like them, click on any of the picture to reach a living Demo.

Column Chart

The "graphtype" is col or colstacked or coloverlaid (1°, 2° and 3° example). If you drag the mouse (in the demo page..click) you can change the position and orientation of the Chart.







Bar Chart

The "graphtype" is bar. You can choose the palette and customize colors, name and palette types. Any Chart feature can be dynamically changed.



Cluster Bar Chart

This is the first Axiis Chart, the "graphtype" is clusterbar. We used the original palette, simply because it is beautiful.




Area Chart

The "graphtype" is area. Data is defined by means of dimension (customer, product..) and measures (sales, quantities, percentages...).




Pie Chart

The "graphtype" is pie. Like all Flash objects, it will take a few seconds to load the first time (the object weights about 500k). On the other hand, it is used the same cached object for all the Charts (any type, data and colors) that you want to show. So, once loaded, it is fast.



Cluster Pie Chart

The "graphtype" is clusterpie. It is a Pie Chart with grouping. May be useful.