2010年11月18日木曜日

H2 DatabaseとJCIFSでWindows共有上のファイルの共有セキュリティを列挙する関数を作成する

H2 DatabaseとJCIFSでWindows共有上のファイルの共有セキュリティを列挙する関数を作成するには、以下のスクリプトを実行します。

drop alias if exists jcifs_get_share_security;
create alias if not exists jcifs_get_share_security as $$
import java.io.*;
import java.sql.*;
import java.util.*;
import jcifs.smb.*;
import org.h2.tools.*;
@CODE
ResultSet jcifs_get_share_security(String domain,
String user, String password, String server,
String path, String filename)
throws Exception
{
if( domain == null ){
throw new Exception("domain is not specified.");
}
user = (user == null)?"":user;
password = (password == null)?"":password;
if( server == null ){
throw new Exception("server is not specified.");
}
if( path == null ){
throw new Exception("path is not specified.");
}
if( filename == null ){
throw new Exception("filename is not specified.");
}

SimpleResultSet rs = new SimpleResultSet();
rs.addColumn("NAME", Types.VARCHAR, 512, 0);
rs.addColumn("FILE_APPEND_DATA", Types.BOOLEAN, 1, 0);
rs.addColumn("FILE_DELETE", Types.BOOLEAN, 1, 0);
rs.addColumn("FILE_EXECUTE", Types.BOOLEAN, 1, 0);
rs.addColumn("FILE_READ_ATTRIBUTES", Types.BOOLEAN, 1, 0);
rs.addColumn("FILE_READ_DATA", Types.BOOLEAN, 1, 0);
rs.addColumn("FILE_READ_EA", Types.BOOLEAN, 1, 0);
rs.addColumn("FILE_WRITE_ATTRIBUTES", Types.BOOLEAN, 1, 0);
rs.addColumn("FILE_WRITE_DATA", Types.BOOLEAN, 1, 0);
rs.addColumn("FILE_WRITE_EA", Types.BOOLEAN, 1, 0);

SmbFile sfile = new SmbFile(
"smb://" + domain + ";" + user + ":" + password +
"@" + server + "/" + path + "/" + filename);
ACE ace[] = sfile.getShareSecurity(true);

for(int fi=0;fi<ace.length;fi++){
rs.addRow(ace[fi].getSID().toDisplayString(),
((ace[fi].getAccessMask() & ACE.FILE_APPEND_DATA) != 0),
((ace[fi].getAccessMask() & ACE.FILE_DELETE) != 0),
((ace[fi].getAccessMask() & ACE.FILE_EXECUTE) != 0),
((ace[fi].getAccessMask() & ACE.FILE_READ_ATTRIBUTES) != 0),
((ace[fi].getAccessMask() & ACE.FILE_READ_DATA) != 0),
((ace[fi].getAccessMask() & ACE.FILE_READ_EA) != 0),
((ace[fi].getAccessMask() & ACE.FILE_WRITE_ATTRIBUTES) != 0),
((ace[fi].getAccessMask() & ACE.FILE_WRITE_DATA) != 0),
((ace[fi].getAccessMask() & ACE.FILE_WRITE_EA) != 0)
);
}
return rs;
}
$$


実行例
call jcifs_get_share_security('LIFERAY1', 
'test1', 'test1', 'liferay1',
'share', 'acetest.txt');


※システム環境変数CLASSPATHにtools.jarとJCIFSのjar
(jcifs-1.3.15.jar)を追加しておくこと。

動作環境
JDK6 Update 21, H2 Database 1.2.143 (2010-09-18), JCIFS 1.3.15

0 件のコメント:

コメントを投稿