001/* 002 * Copyright (c) 2009 The openGion Project. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, 013 * either express or implied. See the License for the specific language 014 * governing permissions and limitations under the License. 015 */ 016package org.opengion.hayabusa.mail; 017 018import static org.opengion.fukurou.util.StringUtil.csv2ArrayOnly; 019import static org.opengion.fukurou.util.StringUtil.nval; 020 021import java.util.ArrayList; 022import java.util.List; 023import java.util.Map; 024import java.util.TreeMap; 025 026import javax.mail.internet.AddressException; 027import javax.mail.internet.InternetAddress; 028 029import org.opengion.fukurou.db.DBUtil; 030import org.opengion.hayabusa.common.HybsSystem; 031 032/** 033 * メール定型文及びそれも基づいて各項目の合成を行うクラスです。 034 * コンストラクタには定型文ID及びシステムIDで定型文マスタよりメールの定型文を取得します。 035 * メール各項目のゲッターでは、定型文の内容を元にパラメータ値とマージして各項目を合成します。 036 * 宛先について、セットした社員ID、グループIDと定型文の宛先設定に基づき、社員マスタと 037 * グループマスタよりメールアドレス情報を取得して宛先マップを作成します。 038 * 039 * 040 * @og.rev 5.6.6.0 (2013/07/05) host指定対応。GE37必須です。 041 * 042 * @og.group メールモジュール 043 * 044 * @version 4.0 045 * @author Sen.Li 046 * @since JDK1.6 047 */ 048public class MailPattern { 049 050 // 5.2.0.0 (2010/09/01) Ver4互換モード対応 051 private static final String CONTENTS = HybsSystem.sysBool( "VER4_COMPATIBLE_MODE" ) ? "CONTENT" : "CONTENTS"; 052 private static final String ADDRESS = HybsSystem.sysBool( "VER4_COMPATIBLE_MODE" ) ? "MEMBER" : "ADDRESS"; 053 private static final String NAME_JA = HybsSystem.sysBool( "VER4_COMPATIBLE_MODE" ) ? "NAME" : "NAME_JA"; 054 private static final String KBNAME = HybsSystem.sysBool( "VER4_COMPATIBLE_MODE" ) ? "NM_KBN" : "KBNAME"; 055 056 // 5.1.0.0 (2009/11/04) CONTENT ⇒ CONTENTS 057 // 5.2.0.0 (2010/09/01) Ver4互換モード対応 058// private static final String selGE31 = "SELECT PTN_ID,FROM_ID,TO_ID,CC_ID,BCC_ID,TITLE,CONTENTS" 059 private static final String selGE31 = "SELECT PTN_ID,FROM_ID,TO_ID,CC_ID,BCC_ID,TITLE,"+CONTENTS 060 + " ,JOKEN" // 5.6.6.0 (2013/07/05) 061 + " FROM GE31" 062 + " WHERE SYSTEM_ID =? AND PTN_ID=? AND FGJ='1'"; 063 // 5.1.0.0 (2009/11/04) MEMBER ⇒ ADDRESS , NM_KBN ⇒ KBNAME , NAME ⇒ NAME_JA 064 // 5.2.0.0 (2010/09/01) Ver4互換モード対応 065// private static final String selGE33 = "SELECT A.ADDRESS,A.NAME_JA,B.NAME_JA" 066 private static final String selGE33 = "SELECT A."+ADDRESS+",A."+NAME_JA+",B."+NAME_JA 067 + " FROM GE33 A,GE33 B" 068 + " WHERE A.FGJ='1' AND B.FGJ(+)='1' AND A.GROUP_ID=B.GROUP_ID(+)" 069// + " AND A.KBNAME='1' AND B.KBNAME(+)='0' AND A.SYSTEM_ID=B.SYSTEM_ID(+)" 070 + " AND A."+KBNAME+"='1' AND B."+KBNAME+"(+)='0' AND A.SYSTEM_ID=B.SYSTEM_ID(+)" 071 + " AND A.SYSTEM_ID =? " 072 + " AND A.GROUP_ID =?"; 073 // 5.3.5.0 (2011/05/01) Ver4対応漏れ対応 074 // 5.9.6.3 (2013/10/25) selGE35をpublic化 075// private static final String selGE35 = "SELECT NAME_JA,MAIL" 076// private static final String selGE35 = "SELECT "+NAME_JA+",MAIL" 077 /** 078 * GE35のメールアドレス検索文 079 */ 080 public static final String selGE35 = "SELECT "+NAME_JA+",MAIL" 081 + " FROM GE35" 082 + " WHERE USERID=?"; 083 084 // 5.6.6.0 (2013/07/05) 振り分け条件 085 private static final String selGE37 = "SELECT HOST,PORT,AUTH,AUTHUSER,AUTHPASS" 086 + " FROM GE37" 087 + " WHERE SYSTEM_ID = ?" 088 + " AND JOKEN = ?" 089 + " AND FGJ ='1'"; 090 091 // 内部データのカラム番号(定型文マスタテーブル) 092 // 5.1.9.0 (2010/09/01) public ⇒ private へ変更 093// private static final int GE31_PTN_ID = 0 ; // 未使用 094 private static final int GE31_FROM_ID = 1 ; 095 private static final int GE31_TO_ID = 2 ; 096 private static final int GE31_CC_ID = 3 ; 097 private static final int GE31_BCC_ID = 4 ; 098 private static final int GE31_TITLE = 5 ; 099 private static final int GE31_CONTENTS = 6 ; // 5.1.0.0 (2009/11/04) CONTENT ⇒ CONTENTS 100 private static final int GE31_JOKEN = 7 ; // 5.6.6.0 (2013/07/05) 101 102 // 内部データのカラム番号(グループマスタ) 103 private static final int GE33_ADDRESS = 0 ; // 5.1.0.0 (2009/11/04) MEMBER ⇒ ADDRESS 104 private static final int GE33_MNAME = 1 ; 105 private static final int GE33_GNAME = 2 ; 106 // 内部データのカラム番号(社員マスタ) 107 // 5.6.9.3 (2013/10/25) public化 108// private static final int GE35_NAME = 0 ; 109// private static final int GE35_MAIL = 1 ; 110 /** 111 * GE35のユーザ名称 112 */ 113 public static final int GE35_NAME = 0 ; 114 /** 115 * GE35のメールアドレス 116 */ 117 public static final int GE35_MAIL = 1 ; 118 119 // 内部データのカラム番号(送信ホストマスタ) 120 private static final int GE37_HOST = 0 ; 121 private static final int GE37_PORT = 1 ; 122 private static final int GE37_AUTH = 2 ; 123 private static final int GE37_AUTHUSER = 3 ; 124 private static final int GE37_AUTHPASS = 4 ; 125 126 // 内部データのカラム番号(宛先テーブル) 127 /** カラム番号(宛先テーブル) {@value} */ 128 public static final int IDX_DST_ID = 0 ; 129 /** カラム番号(宛先テーブル) {@value} */ 130 public static final int IDX_GROUP_ID = 1 ; 131 /** カラム番号(宛先テーブル) {@value} */ 132 public static final int IDX_GROUP_NAME = 2 ; 133 /** カラム番号(宛先テーブル) {@value} */ 134 public static final int IDX_DST_NAME = 3 ; 135 /** カラム番号(宛先テーブル) {@value} */ 136 public static final int IDX_DST_ADDR = 4 ; 137 /** カラム番号(宛先テーブル) {@value} */ 138 public static final int IDX_DST_KBN = 5 ; 139 /** カラム番号(宛先テーブル) {@value} */ 140 public static final int IDX_FGJ = 6 ; 141 142 /** メール送信区分 {@value} */ 143 public static final int KBN_TO = 0 ; // メール送信区分(TO) 144 /** メール送信区分 {@value} */ 145 public static final int KBN_CC = 1 ; // メール送信区分(CC) 146 /** メール送信区分 {@value} */ 147 public static final int KBN_BCC = 2 ; // メール送信区分(BCC) 148 149 private static final String PreFixGroup = "GP."; 150 private final List<String> errAddrList = new ArrayList<String>(); 151// private Map<String, String> paramMap = new HashMap<String, String>(); 152 private final Map<String, String> paramMap ; 153 private String fromId = null; 154 private final String toId ; 155 private final String ccId ; 156 private final String bccId ; 157 private String[][] title = null; 158 private String[][] content = null; 159 private Map<String, String[]> mailDstMap; 160 161 // 5.6.6.0 (2013/07/05) 162 private String host = HybsSystem.sys( "COMMON_MAIL_SERVER" ); 163 private String smtpPort = HybsSystem.sys( "SMTP_PORT" ); 164 private String auth = HybsSystem.sys( "MAIL_SEND_AUTH" ); 165 private String authPort = HybsSystem.sys( "MAIL_SEND_AUTH_PORT" ); // 5.8.1.1 (2014/11/14) 166 private String authUser = HybsSystem.sys( "MAIL_SEND_AUTH_USER" ); 167 private String authPass = HybsSystem.sys( "MAIL_SEND_AUTH_PASSWORD" ); 168 private boolean useTLS = HybsSystem.sysBool( "MAIL_SEND_USE_STARTTLS" ); // 5.9.29.2 (2018/02/16) 169 170 171 private final String DBID = HybsSystem.sys( "RESOURCE_DBID" ); // 5.5.5.1 (2012/08/07) リソース系DBID 付け忘れ対応 172 173 /** 174 * メール定型文オブジェクトを作成するコンストラクタです。 175 * 定型文マスタより取得したデータを各フィルードにセットします。 176 * 177 * @og.rev 5.5.5.1 (2012/08/07) リソース系DBID 付け忘れ対策 178 * @og.rev 5.6.6.0 (2013/07/05) 振り分け対応 179 * 180 * @param params パラメータのマップ 181 */ 182 public MailPattern( final Map<String, String> params ){ 183 paramMap = params; 184 String sysId = params.get( "SYSTEM_ID" ); 185 String pid = params.get( "PTN_ID" ); 186 String[] selGE30Args = { sysId,pid }; 187// String[][] ptn = DBUtil.dbExecute( selGE31, selGE30Args, AbstractMailManager.appInfo ); 188 String[][] ptn = DBUtil.dbExecute( selGE31, selGE30Args, AbstractMailManager.appInfo, DBID ); // 5.5.5.1 (2012/08/07) 189 if( ptn == null || ptn.length <=0 ) { 190 String errMsg = "定型文取得できません。システムID:" + sysId + "定型文ID:" + pid ; 191 throw new RuntimeException( errMsg ); 192 } 193 fromId = ptn[0][GE31_FROM_ID]; 194 toId = ptn[0][GE31_TO_ID]; 195 ccId = ptn[0][GE31_CC_ID]; 196 bccId = ptn[0][GE31_BCC_ID]; 197 String tit = ptn[0][GE31_TITLE]; 198 if( tit != null && tit.length() > 0 ) { 199 title = splitParam( tit ); 200 } 201 String con = ptn[0][GE31_CONTENTS]; // 5.1.0.0 (2009/11/04) CONTENT ⇒ CONTENTS 202 if( con != null && con.length() > 0 ) { 203 content = splitParam( con ); 204 } 205 // 5.6.6.0 (2013/07/05) 振り分け対応 206 String joken = ptn[0][GE31_JOKEN]; 207 if( joken != null && joken.length() > 0 ) { 208 String[] selGE37Args = { sysId,joken }; 209 String[][] jkn = DBUtil.dbExecute( selGE37, selGE37Args, AbstractMailManager.appInfo, DBID ); 210 if( ptn == null || ptn.length <=0 ) { 211 String errMsg = "メールホストの振分先が取得できません。システムID:" + sysId + "振分条件:" + joken ; 212 throw new RuntimeException( errMsg ); 213 } 214 host = jkn[0][GE37_HOST]; 215 smtpPort = jkn[0][GE37_PORT]; 216 auth = jkn[0][GE37_AUTH]; 217 authUser = jkn[0][GE37_AUTHUSER]; 218 authPass = jkn[0][GE37_AUTHPASS]; 219 } 220 } 221 222 /** 223 * 定型文の送信者ID欄の設定値とパラメータ{@FROM}を元に送信者アドレスを取得します。 224 * 定型文には{@FROM}とセットされている場合は、パラメータ{@FROM}の値を元に、社員IDをセット 225 * されている場合、直接そのIDを元に社員マスタから送信者アドレスを取得します。 226 * 送信者アドレス取得できなければ例外を投げます。 227 * 228 * @og.rev 4.3.7.5 (2009/07/08) 送信元名称が設定されていない場合は、アドレスを<>で囲わない 229 * 230 * @return 送信者アドレス 231 */ 232 public String getFromAddr(){ 233 // 定型文に{@FROM}⇒ユーザーよりセットしたデータで置換える、ユーザーIDの場合はそのまま 234 if( "{@FROM}".equals( fromId ) ) { 235 fromId = paramMap.get( "FROM" ); 236 } 237 paramMap.put( "FROM_ID" , fromId ); // 送信者ID 238 239 String[] userInf = getUserInfo( fromId ); 240 String fromAddr = null; 241 if( userInf != null && checkAddr ( fromId, userInf[1] ) ){ // 送信者メールアドレスチェック 242 paramMap.put( "FROM_NAME", userInf[0] ); // 送信者名前 243 // 4.3.7.5 (2009/07/08) 244 if( userInf[0] != null && userInf[0].length() > 0 ) { 245 fromAddr = userInf[0] + "<" + userInf[1] + ">" ; 246 } 247 else { 248 fromAddr = userInf[1]; 249 } 250 paramMap.put( "FROM_ADDR", fromAddr ); // 送信者メールアドレス 251 } 252 else { 253 String errMsg = "送信者ユーザー情報エラー。ユーザーID:" + fromId; 254 throw new RuntimeException( errMsg ); 255 } 256 257 return fromAddr; 258 } 259 260 /** 261 * マージ済のメールタイトルを返します。 262 * 263 * @return メールタイトル 264 * 265 */ 266 public String getTitle(){ 267 return marge( title ); 268 } 269 270 /** 271 * マージ済のメール本文を返します。 272 * 273 * @og.rev 5.1.0.0 (2009/11/04) HEADER ⇒ H_TXT , FOOTER ⇒ F_TXT カラム名変更 274 * 275 * @return メール本文 276 */ 277 public String getContent(){ 278 String header = paramMap.get( "HEADER" ); // 5.1.0.0 (2009/11/04) HEADER ⇒ H_TXT 279 StringBuilder contentBuf = new StringBuilder(); 280 if ( header != null ) { 281 contentBuf.append( header ).append( '\n' ); 282 } 283 contentBuf.append( marge( content ) ).append( '\n' ); 284 String fooder = paramMap.get( "FOOTER" ); // 5.1.0.0 (2009/11/04) FOOTER ⇒ F_TXT 285 if ( fooder != null ) { 286 contentBuf.append( fooder ); 287 } 288 289 return contentBuf.toString(); 290 } 291 292 /** 293 * 引数の文字列により、定数文字列の部分とパラメータの部分を分解します。 294 * 例:"A{@PARAM1}B"⇒rtn[0][0]="A",rtn[0][1]="B",rtn[1][0]="PARAM1" 295 * 296 * @param src 分解対象の文字列 297 * 298 * @return 定数文字列の部分とパラメータの部分を分解した配列 299 */ 300 private String[][] splitParam( final String src ) { 301 String[][] rtn = new String[2][]; 302 if( src == null ) { return new String[2][0]; } 303 304 ArrayList<String> listCons = new ArrayList<String>() ; 305 ArrayList<String> listPara = new ArrayList<String>() ; 306 307 int start = 0; 308 int index = src.indexOf( "{@" ); 309 while( index >= 0 ) { 310 listCons.add( src.substring( start, index ) ); 311 int end = src.indexOf( '}',index ); 312 if( end < 0 ) { 313 String errMsg = "{@ と } との対応関係がずれています。" 314 + "src=[" + src + "] : index=" + index ; 315 throw new RuntimeException( errMsg ); 316 } 317 listPara.add( src.substring( index + 2, end )); 318 319 start = end+1 ; 320 index = src.indexOf( "{@",start ); 321 } 322 listCons.add ( src.substring( start ) ); 323 324 rtn[0] = listCons.toArray( new String[listCons.size()] ); 325 rtn[1] = listPara.toArray( new String[listPara.size()] ); 326 327 return rtn; 328 } 329 330 /** 331 * 送信先のアドレスをセットします。 332 * 定型文に定義されている宛先(TO、CC、BCC)を引数として渡します。引数には{@TO}、{@CC}、{@BCC}が含まれています。 333 * {@TO}、{@CC}、{@BCC}を初期設定の値で置換えて、実のメールアドレスマップを作成します。 334 * 335 * @return 宛先のマップ 336 */ 337 public Map<String, String[]> getDstMap(){ 338 String[] toBuf = getDstArray( toId ); 339 String[] ccBuf = getDstArray( ccId ); 340 String[] bccBuf = getDstArray( bccId ); 341 342 // 送信先(TO、CC、BCC)のマップを作成します。 343 mailDstMap = (TreeMap<String, String[]>)getDstAddrMap( bccBuf, KBN_BCC ); 344 mailDstMap.putAll( (TreeMap<String, String[]>) getDstAddrMap( ccBuf, KBN_CC ) ); 345 mailDstMap.putAll( (TreeMap<String, String[]>) getDstAddrMap( toBuf, KBN_TO ) ); 346 setDstWord(); 347 348 return mailDstMap; 349 } 350 351 /** 352 * アドレスエラーのメッセージリストを返します。 353 * 354 * @return メッセージリスト 355 */ 356 public List<String> getErrList(){ 357 return errAddrList; 358 } 359 360 /** 361 * 送信先のアドレスをcsv形式から配列にセットします。 362 * 引数は定型文マスタにセットしたものです。例:{@TO},C12345,GP.IT 363 * {@TO}、{@CC}、{@BCC}はパラメータテーブルにセットしたもので置き換えます。 364 * 分解後の配列には、ユーザーID及びグループIDが混在します。 365 * 366 * @param csvId csv形式のアドレス 367 * 368 * @return 送信先のアドレスの配列 369 */ 370 private String[] getDstArray( final String csvId ){ 371 String[] csvArr = csv2ArrayOnly( csvId ); 372 ArrayList<String> list = new ArrayList<String>(); 373 374 String[] tmp; 375 int size = csvArr.length; 376 for( int i = 0; i < size; i++ ){ 377 if( csvArr[i].startsWith( "{@" )){ 378 tmp = csv2ArrayOnly( paramMap.get( csvArr[i].substring( 2, csvArr[i].length() - 1 ) ) ); 379 int len = tmp.length; 380 for(int j=0;j<len;j++){ 381 list.add( tmp[j] ); 382 } 383 } 384 else{ 385 list.add( csvArr[i]); 386 } 387 } 388 return list.toArray( new String[list.size()] ); 389 } 390 391 /** 392 * 送信先のアドレス・マップを作成します。 393 * 引数 dstBuf にはユーザーIDとグループID混在する配列です。 394 * ユーザーIDの場合、社員マスタのビューから名前及びメールアドレスを取得してマップにセットします。 395 * グループIDの場合、グループマスタより、名前及びメールアドレスを取得してマップにセットします。 396 * 重複のユーザーが存在する場合、最後にセットした方が採用されます。 397 * 398 * @og.rev 5.1.0.0 (2009/11/04) MEMBER ⇒ ADDRESS カラム名変更 399 * 400 * @param dstBuf ユーザーIDとグループID混在する配列 401 * @param kbn 送信区分[0:TO/1:CC/2:BCC] 402 * 403 * @return 送信先のアドレス・マップ 404 */ 405 private Map<String, String[]> getDstAddrMap( final String[] dstBuf, final int kbn ){ 406 Map<String,String[]> dstMap= new TreeMap<String,String[]>(); 407 // IDX_DST_ID ,IDX_GROUP_ID, IDX_GROUP_NAME ,IDX_DST_NAME ,IDX_DST_ADDR ,IDX_DST_KBN ,IDX_FGJ 408 String[] dstInit = { "", "", "", "", "", Integer.toString( kbn ), "7" }; 409 410 int len = dstBuf.length; 411 for( int i=0; i < len; i++ ){ 412 if( dstBuf[i].startsWith( PreFixGroup ) ) { // グループIDの場合、グループマスタより、メンバーを取得します。 413 String[][] groupUsers = getGroupUsers( dstBuf[i].substring( PreFixGroup.length() ) ); 414 if( groupUsers.length > 0 ) { 415 int memberCnt = groupUsers.length; 416 for( int j = 0; j < memberCnt; j++ ) { // グループメンバーの処理 417 String[] grpMember = dstInit.clone(); 418 grpMember[IDX_GROUP_ID] = dstBuf[i].substring( PreFixGroup.length() ); // グループID 419 grpMember[IDX_GROUP_NAME] = groupUsers[j][GE33_GNAME]; // グループ名 420 grpMember[IDX_DST_ID] = groupUsers[j][GE33_ADDRESS]; // 宛先ID 421 grpMember[IDX_DST_NAME] = groupUsers[j][GE33_MNAME]; // 宛先名 422 if( groupUsers[j][GE33_ADDRESS].contains( "@" ) ) { // メールアドレスがセットされる場合 423 grpMember[IDX_DST_ADDR] = groupUsers[j][GE33_ADDRESS]; // メールアドレス 424 } 425 else { // 社員IDがセットされた場合 426 String[] userAddr = getUserInfo( groupUsers[j][GE33_ADDRESS] ); 427 if ( userAddr != null && userAddr.length > 0 ){ 428 grpMember[IDX_DST_ADDR] = userAddr[GE35_MAIL]; // メールアドレス 429 } 430 } 431 if ( checkAddr( grpMember[IDX_DST_ID], grpMember[IDX_DST_ADDR] ) ){ // アドレス構文チェック 432 grpMember[IDX_FGJ] = AbstractMailManager.FGJ_SEND_WAIT; // 送信待 433 } 434 else { 435 grpMember[IDX_FGJ] = AbstractMailManager.FGJ_ADDR_ERR; // アドレス取得エラー 436 errAddrList.add( "アドレス取得エラー。ユーザーID:" + grpMember[IDX_DST_ID] + " アドレス:" + grpMember[IDX_DST_ADDR] ); 437 } 438 dstMap.put( groupUsers[j][GE33_ADDRESS], grpMember ); 439 } 440 } 441 else { // グループマスタよりメンバー取得できない場合 442 String[] emptyGp = dstInit.clone(); 443 emptyGp[IDX_GROUP_ID] = dstBuf[i]; // グループID 444 emptyGp[IDX_GROUP_NAME] = "*"; // グループID 445 emptyGp[IDX_DST_ID] = "NO-MEMBER"; // 宛先ID 446 dstMap.put( dstBuf[i], emptyGp ); 447 } 448 } 449 else { // ユーザーIDの場合 450 String[] indMember = dstInit.clone(); 451 indMember[IDX_DST_ID] = dstBuf[i]; // 宛先ID 452 indMember[IDX_GROUP_ID] = "*"; // グループID 453 indMember[IDX_GROUP_NAME] = "*"; // グループID 454 String[] userAddr = getUserInfo( dstBuf[i] ); 455 if ( userAddr != null && userAddr.length > 0 ){ 456 indMember[IDX_DST_NAME] = userAddr[GE35_NAME]; // 宛先名 457 indMember[IDX_DST_ADDR] = userAddr[GE35_MAIL]; // メールアドレス 458 if ( checkAddr( indMember[IDX_DST_ID], userAddr[1] ) ) { 459 indMember[IDX_FGJ] = AbstractMailManager.FGJ_SEND_WAIT; 460 } 461 else { 462 indMember[IDX_FGJ] = AbstractMailManager.FGJ_ADDR_ERR; 463 errAddrList.add( "アドレス取得エラー。ユーザーID:" + indMember[IDX_DST_ID] + " アドレス:" + indMember[IDX_DST_ADDR] ); 464 } 465 466 } 467 else { 468 indMember[IDX_FGJ] = AbstractMailManager.FGJ_ADDR_ERR; // 状況コード 469 } 470 dstMap.put( dstBuf[i], indMember ); 471 } 472 } 473 return dstMap; 474 } 475 476 /** 477 * グループマスタより、ユーザー情報を取得します。 478 * 戻り値の配列には、ユーザーIDまたはメールアドレス、ユーザー名、グループ名が格納されています。 479 * 480 * @og.rev 5.5.5.1 (2012/08/07) リソース系DBID 付け忘れ対策 481 * 482 * @param groupId グループID 483 * 484 * @return ユーザー情報 485 */ 486 private String[][] getGroupUsers( final String groupId ){ 487 String sysId = paramMap.get( "SYSTEM_ID" ); 488 String[] ge33SelArgs = { sysId,groupId }; 489// String[][] ge33Datas = DBUtil.dbExecute( selGE33,ge33SelArgs,AbstractMailManager.appInfo ); 490 String[][] ge33Datas = DBUtil.dbExecute( selGE33,ge33SelArgs,AbstractMailManager.appInfo, DBID ); // 5.5.5.1 (2012/08/07) 491 492 if ( ge33Datas.length == 0 ) { 493 String errMsg = "グループ情報取得できません。グループID:" + groupId ; 494 if( "true".equals( paramMap.get( "ADDR_CHECK" ) ) ){ 495 throw new RuntimeException( errMsg ); 496 } 497 else { 498 errAddrList.add( errMsg ); 499 } 500 } 501 return ge33Datas; 502 } 503 504 /** 505 * メール送信ホストを返します。 506 * GE31のJOKEN(振り分け条件)を元に、GE37テーブルの HOST を取得します。 507 * 振り分け条件が未設定の場合は、システム定数のCOMMON_MAIL_SERVER を使用します。 508 * 509 * (初期値:システム定数のCOMMON_MAIL_SERVER[={@og.value org.opengion.hayabusa.common.SystemData#COMMON_MAIL_SERVER}])。 510 * 511 * @og.rev 5.6.6.0 (2013/07/05) 512 * 513 * @return メール送信ホスト 514 */ 515 public String getHost(){ 516 return host; 517 } 518 519 /** 520 * メール送信ポート番号を返します 521 * GE31のJOKEN(振り分け条件)を元に、GE37テーブルの PORT を取得します。 522 * 振り分け条件が未設定の場合は、システム定数のSMTP_PORT を使用します。 523 * 524 * (初期値:システム定数のSMTP_PORT[={@og.value org.opengion.hayabusa.common.SystemData#SMTP_PORT}])。 525 * 526 * @og.rev 5.6.6.0 (2013/07/05) 527 * 528 * @return メール送信ポート番号 529 */ 530 public String getSmtpPort(){ 531 return smtpPort; 532 } 533 534 /** 535 * メール送信時認証有無を返します 536 * GE31のJOKEN(振り分け条件)を元に、GE37テーブルの AUTH を取得します。 537 * 振り分け条件が未設定の場合は、システム定数のMAIL_SEND_AUTH を使用します。 538 * 539 * (初期値:システム定数のMAIL_SEND_AUTH[={@og.value org.opengion.hayabusa.common.SystemData#MAIL_SEND_AUTH}])。 540 * 541 * @og.rev 5.6.6.0 (2013/07/05) 542 * 543 * @return メール送信時認証有無 544 */ 545 public String getAuth(){ 546 return auth; 547 } 548 549 /** 550 * メール送信認証ポートを返します。 551 * 「POP_BEFORE_SMTP」認証を行う場合に、POPサーバーに接続するポート番号を返します。 552 * GE37テーブルに指定するカラムはありません。 553 * 初期値は、システム定数のMAIL_SEND_AUTH_PORT を使用します。 554 * 555 * (初期値:システム定数のMAIL_SEND_AUTH_PORT[={@og.value org.opengion.hayabusa.common.SystemData#MAIL_SEND_AUTH_PORT}])。 556 * 557 * @og.rev 5.8.1.1 (2014/11/14) メール送信時認証「POP_BEFORE_SMTP」追加 558 * 559 * @return メール送信認証ポート 560 */ 561 public String getAuthPort(){ 562 return authPort; 563 } 564 565 /** 566 * メール送信認証ユーザを返します 567 * GE31のJOKEN(振り分け条件)を元に、GE37テーブルの AUTHUSER を取得します。 568 * 振り分け条件が未設定の場合は、システム定数のMAIL_SEND_AUTH_USER を使用します。 569 * 570 * (初期値:システム定数のMAIL_SEND_AUTH_USER[={@og.value org.opengion.hayabusa.common.SystemData#MAIL_SEND_AUTH_USER}])。 571 * 572 * @og.rev 5.6.6.0 (2013/07/05) 573 * 574 * @return メール送信認証ユーザ 575 */ 576 public String getAuthUser(){ 577 return authUser; 578 } 579 580 /** 581 * メール送信認証パスワードを返します 582 * GE31のJOKEN(振り分け条件)を元に、GE37テーブルの AUTHPASS を取得します。 583 * 振り分け条件が未設定の場合は、システム定数のMAIL_SEND_AUTH_PASSWORD を使用します。 584 * 585 * (初期値:システム定数のMAIL_SEND_AUTH_PASSWORD[={@og.value org.opengion.hayabusa.common.SystemData#MAIL_SEND_AUTH_PASSWORD}])。 586 * 587 * @og.rev 5.6.6.0 (2013/07/05) 588 * 589 * @return メール送信認証パスワード 590 */ 591 public String getAuthPass(){ 592 return authPass; 593 } 594 595 /** 596 * メール送信時にSTARTTLSの暗号化を行うかを指定します。 597 * 現在はシステム定数のMAIL_SEND_USE_STARTTLSをそのまま使用します。 598 * 599 * (初期値:システム定数のMAIL_SEND_AUTH_PASSWORD[={@og.value org.opengion.hayabusa.common.SystemData#MAIL_SEND_USE_STARTTLS}])。 600 * 601 * @og.rev 5.9.29.2 (2018/02/16) 602 * 603 * @return メール送信時TLS利用有無 604 */ 605 public boolean getUseTLS(){ 606 return useTLS; 607 } 608 609 /** 610 * アドレスの構文チェックを行います、合法の場合は'true'(取得できた)、違法の場合は'false'(有効アドレス取得できず)を返します。 611 * 612 * @param userId ユーザーID 613 * @param address アドレス 614 * 615 * @return アドレスの構文チェック結果(true:取得/false:取得できず) 616 */ 617 private boolean checkAddr( final String userId, final String address ) { 618 boolean rtn = true; 619 try { 620 new InternetAddress( address ); 621 } 622 catch ( AddressException aep ) { 623 if ( "true".equals( paramMap.get( "ADDR_CHECK" ) ) ) { 624 String errMsg = "ユーザーメールアドレスエラー。ユーザーID:" + userId + " アドレス:" + address; 625 throw new RuntimeException( errMsg,aep ); 626 } 627 rtn = false; 628 } 629 return rtn; 630 } 631 632 /** 633 * 引数の配列から文書を合成します。 634 * src[0]に配列には定数文字列、src[1]にはパラメータ 635 * 636 * @param src 引数の配列 637 * 638 * @return 合成された文章 639 */ 640 private String marge( final String[][] src ){ 641 StringBuilder rtnBuf = new StringBuilder(); 642 String rtn; 643 if ( src != null ){ 644 int len = src[1].length; 645 for(int i=0; i< len; i++) { 646 rtnBuf.append( src[0][i] ); 647 rtnBuf.append( paramMap.get( src[1][i] ) ); 648 } 649 rtnBuf.append( src[0][len] ); 650 rtn = rtnBuf.toString(); 651 } 652 else { 653 rtn = null; 654 } 655 656 return rtn; 657 } 658 659 /** 660 * 宛先(TO、CC、BCC)のID、名前、メールアドレスをパラメータマップにセットします。 661 * 662 */ 663 private void setDstWord() { 664 StringBuilder to_id = new StringBuilder(); 665 StringBuilder to_name = new StringBuilder(); 666 StringBuilder to_addr = new StringBuilder(); 667 StringBuilder cc_id = new StringBuilder(); 668 StringBuilder cc_name = new StringBuilder(); 669 StringBuilder cc_addr = new StringBuilder(); 670 StringBuilder bcc_id = new StringBuilder(); 671 StringBuilder bcc_name = new StringBuilder(); 672 StringBuilder bcc_addr = new StringBuilder(); 673 int kbn; 674 for( String dstId : mailDstMap.keySet() ) { 675 kbn = Integer.parseInt( mailDstMap.get( dstId )[IDX_DST_KBN]); 676 switch( kbn ) { 677 case KBN_TO: 678 to_id.append( ',' ).append( dstId ); 679 to_name.append( ',' ).append( mailDstMap.get( dstId )[IDX_DST_NAME] ); 680 to_addr.append( ',' ).append( mailDstMap.get( dstId )[IDX_DST_NAME] ); 681 to_addr.append( '<' ).append( mailDstMap.get( dstId )[IDX_DST_ADDR] ).append( ">" ); 682 break; 683 case KBN_CC: 684 cc_id.append( ',' ).append( dstId ); 685 cc_name.append( ',' ).append( mailDstMap.get( dstId )[IDX_DST_NAME] ); 686 cc_addr.append( ',' ).append( mailDstMap.get( dstId )[IDX_DST_NAME] ); 687 cc_addr.append( '<' ).append( mailDstMap.get( dstId )[IDX_DST_ADDR] ).append( ">" ); 688 break; 689 case KBN_BCC: 690 bcc_id.append( ',' ).append( dstId ); 691 bcc_name.append( ',' ).append( mailDstMap.get( dstId )[IDX_DST_NAME] ); 692 bcc_addr.append( ',' ).append( mailDstMap.get( dstId )[IDX_DST_NAME] ); 693 bcc_addr.append( '<' ).append( mailDstMap.get( dstId )[IDX_DST_ADDR] ).append( ">" ); 694 break; 695 default: 696 String errMsg = "このアドレス区分がサポートされません。区分:" + kbn; 697 throw new RuntimeException( errMsg ); 698 } 699 } 700 // 予約語マップに追加します。 701 paramMap.put( "TO_ID" , ( to_id.length() > 0 ) ? to_id.toString().substring( 1 ):"" ); 702 paramMap.put( "TO_NAME" , ( to_name.length() > 0 ) ? to_name.toString().substring( 1 ):"" ); 703 paramMap.put( "TO_ADDR" , ( to_addr.length() > 0 ) ? to_addr.toString().substring( 1 ):"" ); 704 paramMap.put( "CC_ID" , ( cc_id.length() > 0 ) ? cc_id.toString().substring( 1 ):"" ); 705 paramMap.put( "CC_NAME" , ( cc_name.length() > 0 ) ? cc_name.toString().substring( 1 ):"" ); 706 paramMap.put( "CC_ADDR" , ( cc_addr.length() > 0 ) ? cc_addr.toString().substring( 1 ):"" ); 707 paramMap.put( "BCC_ID" , ( bcc_id.length() > 0 ) ? bcc_id.toString().substring( 1 ):"" ); 708 paramMap.put( "BCC_NAME", ( bcc_name.length() > 0 ) ? bcc_name.toString().substring( 1 ):"" ); 709 paramMap.put( "BCC_ADDR", ( bcc_addr.length() > 0 ) ? bcc_addr.toString().substring( 1 ):"" ); 710 } 711 712 /** 713 * 社員マスタより名前、メールアドレスを取得します。 714 * 戻り値 rtn[0]:ユーザー名、 rtn[1]:ユーザーメールアドレス 715 * 716 * @og.rev 4.3.6.6 (2009/05/15) メールアドレスが直接指定された場合に対応 717 * @og.rev 5.5.5.1 (2012/08/07) リソース系DBID 付け忘れ対策 718 * 719 * @param userId ユーザーID 720 * 721 * @return 配列文字列(rtn[0]:ユーザー名、 rtn[1]:ユーザーメールアドレス) 722 */ 723 private String[] getUserInfo( final String userId ){ 724 String[] rtn = null; 725 726 if ( userId.contains( "@" ) ) { 727 rtn = new String[2]; 728 rtn[0] = ""; 729 rtn[1] = userId; 730 } 731 else { 732 String[] ge35SelArgs = { userId }; 733// String[][] ge35Datas = DBUtil.dbExecute( selGE35,ge35SelArgs,AbstractMailManager.appInfo ); 734 String[][] ge35Datas = DBUtil.dbExecute( selGE35,ge35SelArgs,AbstractMailManager.appInfo, DBID ); // 5.5.5.1 (2012/08/07) 735 if ( ge35Datas.length > 0) { 736 rtn = ge35Datas[0]; 737 } 738 else { 739 String errMsg = "ユーザー情報取得できません。ユーザーID:" + userId ; 740 if( "true".equals( paramMap.get( "ADDR_CHECK" ) ) ){ 741 throw new RuntimeException( errMsg ); 742 } 743 else { 744 errAddrList.add( errMsg ); 745 } 746 } 747 } 748 return rtn; 749 } 750}