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 */ 016 package org.opengion.hayabusa.resource; 017 018 import org.opengion.hayabusa.common.HybsSystem; 019 import org.opengion.hayabusa.common.HybsSystemException; 020 import org.opengion.fukurou.util.StringUtil; 021 022 import java.util.Map; 023 import java.util.WeakHashMap ; 024 import java.util.Collections ; 025 026 /** 027 * ロールモード?、画面オブジェクトやカラ?ブジェクト?ロール-モード制御の??? 028 * 管?るクラスです? 029 * ROLES ??は、AAA|BBB|CCC と 『|』で区?れた?のロールを持って?す? 030 * 通常、ユーザーロールは画面?ラ???ブジェクトに対してロール制御可能です? 031 * ログインユーザーは、???身のロールを?画面?ラ?持って?かを判定します? 032 * 画面に関しては、従来の?ォルトアクセスがなくなり?ロールを登録する場合?? 033 * ? ユーザーロールとの比?行われます?画面ロールを登録しな??合?、アクセス 034 * 可能と判断されます?つまり?画面の場合?、なにも設定しなければ、アクセス可能と 035 * 判断されます? 036 * カラ?ールも同様に、何も設定しなければフルアクセスできます?通常、ほとんどの 037 * ケースでカラ?ールが使われることはありません? 038 * RWMODE ??は、各ロールに対して?つの?で表して?す? 039 * ??-" メニュー非表示 "m" メニュー表示 "p" メニュー表示(強制プル?ン表示) 040 * ??-" アクセス拒否 "r" 読取許可 "w" 読取?書込許可 041 * ??-" 未対? "d" ファイル出? "u" ファイル入? "f" ファイル入出? 042 * … こ?d,u,f では、?出力方法設定?タブ?表示されません? 043 * "o" 表示???み可 … こ?設定では、?表示?設定? タブで位置と表示??み変更できます? 044 * "e" 画面編? … こ?設定で、編??がフルに使えます? 045 * 互換性の関係より?"" は?e" と同等とします? 046 * 設定キーの関係より?"o" と "e" を設定すると?f" が?動的に設定されます? 047 * 048 * こ???目を?次つな??--","-r","-w","mr","mw" などの設定を行います? 049 * モードが設定されて?場合?、?通モードとして、すべてのロールに同じモードを 050 * 割り当てます?個別に割り当てる?合?、ROLES ??の後ろに () 付きで追記します? 051 * 例えば、AAA|BBB(-r)|CCC とすれば、BBB ロールの場合?、読取専用になります? 052 * ロールを?つける場合?、AND 演算になります? 053 * 過去(Ver3)のモードとの互換性をとる?合?"rw" は "mw" へ?r-" は"mr" へ変換 054 * してください? 055 * 056 * @og.rev 4.0.0.0 (2004/01/31) 新規作? 057 * @og.rev 4.3.3.0 (2008/10/01) pモード追? 058 * @og.group リソース管? 059 * 060 * @version 4.0 061 * @author Kazuhiko Hasegawa 062 * @since JDK5.0, 063 */ 064 public final class RoleMode { 065 private static final Map<String,RoleMode> roleMap 066 = Collections.synchronizedMap( 067 new WeakHashMap<String,RoleMode>( HybsSystem.BUFFER_SMALL ) 068 ); 069 070 // 4.0.0 (2005/01/31) param属?追? 071 // 4.3.3.0 (2008/10/01) pを追?るため?ビット表現を拡張 072 // public static final byte FULL_MODE = (byte)0x1f; // mwf = 11111 = 0x1f 073 // public static final byte M_MODE = (byte)0x10; // m-- = 10000 = 0x10 074 // public static final byte R_MODE = (byte)0x04; // -r- = 00100 = 0x04 075 // public static final byte W_MODE = (byte)0x0C; // -w- = 01100 = 0x0C 076 // public static final byte D_MODE = (byte)0x01; // --d = 00001 = 0x01 077 // public static final byte U_MODE = (byte)0x02; // --u = 00010 = 0x02 078 // public static final byte F_MODE = (byte)0x03; // --f = 00011 = 0x03 079 080 // /** MODE 定義 ( mwf ) */ 081 // public static final byte FULL_MODE = (byte)0x3f; // mwf = 111111 = 0x3f 082 // /** MODE 定義 ( m-- ) */ 083 // public static final byte M_MODE = (byte)0x30; // m-- = 110000 = 0x30 084 // /** MODE 定義 ( p-- ) */ 085 // public static final byte P_MODE = (byte)0x10; // p-- = 010000 = 0x10 086 // /** MODE 定義 ( -r- ) */ 087 // public static final byte R_MODE = (byte)0x04; // -r- = 000100 = 0x04 088 // /** MODE 定義 ( -w- ) */ 089 // public static final byte W_MODE = (byte)0x0C; // -w- = 001100 = 0x0C 090 // /** MODE 定義 ( --d ) */ 091 // public static final byte D_MODE = (byte)0x01; // --d = 000001 = 0x01 092 // /** MODE 定義 ( --u ) */ 093 // public static final byte U_MODE = (byte)0x02; // --u = 000010 = 0x02 094 // /** MODE 定義 ( --f ) */ 095 // public static final byte F_MODE = (byte)0x03; // --f = 000011 = 0x03 096 // 097 // public static final String DEFAULT_MODE = "mwf"; 098 099 // 5.4.2.0 (2011/12/01) eを追?るため?ビット表現を拡張 100 // /** MODE 定義 ( mwf ) */ 101 // public static final byte FULL_MODE = (byte)0x3f; // mwe = 1111111 = 0x7f 102 // /** MODE 定義 ( m-- ) */ 103 // public static final byte M_MODE = (byte)0x60; // m-- = 1100000 = 0x60 104 // /** MODE 定義 ( p-- ) */ 105 // public static final byte P_MODE = (byte)0x20; // p-- = 0100000 = 0x20 106 // /** MODE 定義 ( -r- ) */ 107 // public static final byte R_MODE = (byte)0x08; // -r- = 0001000 = 0x08 108 // /** MODE 定義 ( -w- ) */ 109 // public static final byte W_MODE = (byte)0x18; // -w- = 0011000 = 0x18 110 // /** MODE 定義 ( --d ) */ 111 // public static final byte D_MODE = (byte)0x02; // --d = 0000010 = 0x02 112 // /** MODE 定義 ( --u ) */ 113 // public static final byte U_MODE = (byte)0x04; // --u = 0000100 = 0x04 114 // /** MODE 定義 ( --f ) */ 115 // public static final byte F_MODE = (byte)0x06; // --f = 0000110 = 0x06 116 // /** MODE 定義 ( --f ) */ 117 // public static final byte E_MODE = (byte)0x07; // --e = 0000111 = 0x07 118 119 120 // 5.5.5.2 (2012/08/10) oを追?るため?ビット表現を拡張 121 // 5.7.4.3 (2014/03/28) publicをprivateに変更します? 122 /** MODE 定義 全許可 ( mwe ) */ 123 private static final byte FULL_MODE = (byte)0x7f; // mwe = 01 11 11 11 = 0x7f 124 /** MODE 定義 メニュー表示 ( m-- ) */ 125 private static final byte M_MODE = (byte)0xc0; // m-- = 11 00 00 00 = 0xc0 126 /** MODE 定義 強制プル?ン表示 ( p-- ) */ 127 private static final byte P_MODE = (byte)0x40; // p-- = 01 00 00 00 = 0x40 128 129 /** MODE 定義 読取許可 ( -r- ) */ 130 private static final byte R_MODE = (byte)0x10; // -r- = 00 01 00 00 = 0x10 131 /** MODE 定義 書込許可 ( -w- ) */ 132 private static final byte W_MODE = (byte)0x30; // -w- = 00 11 00 00 = 0x30 133 134 /** MODE 定義 ファイル出? ( --d ) */ 135 private static final byte D_MODE = (byte)0x04; // --d = 00 00 01 00 = 0x04 136 /** MODE 定義 ファイル入? ( --u ) */ 137 private static final byte U_MODE = (byte)0x08; // --u = 00 00 10 00 = 0x08 138 /** MODE 定義 ファイル入出? ( --f ) */ 139 private static final byte F_MODE = (byte)0x0c; // --f = 00 00 11 00 = 0x0c 140 141 /** MODE 定義 表示???み可 ( --o ) */ 142 private static final byte O_MODE = (byte)0x0e; // --o = 00 00 11 10 = 0x0e 143 // ~ ←?出力方法設定?タブ?表示 144 // ~ ←?表示?設定?タブ?表示?用 145 /** MODE 定義 画面編? ( --e ) */ 146 private static final byte E_MODE = (byte)0x0f; // --e = 00 00 11 11 = 0x0f 147 148 /** 初期のモー?*/ 149 public static final String DEFAULT_MODE = "mwe"; 150 151 private final String roles ; // ロールズ 152 private final String rwmode ; // モー? 153 private final String[] roleArray ; // ロール配? 154 private final byte[] bitModes ; // モード?ビット版(-:00, p:01, m:11, 155 // -:00, r:01, w:11, 156 // -:000, d:010, u:100, f:110, o:111, e:111) 157 // private final byte comBitMode ; 158 private final boolean fullAccessFlag; // フルアクセス許可時?フラグ 159 // private final boolean oneModeFlag; // ?つのモードですべてのロールを表現する場?true 160 161 private static final RoleMode FULL_ACCESS_ROLE_MODE_OBJ = new RoleMode() ; 162 163 /** 164 * フルアクセスの RoleMode を構築します? 165 * ?からのみ構築できるように private コンストラクタにしておきます? 166 * 167 * @og.rev 4.3.0.0 (2008/07/04) ロールモード?ルチ対? 168 */ 169 private RoleMode() { 170 roles = "FullAccess"; 171 rwmode = DEFAULT_MODE; 172 roleArray = null; 173 bitModes = new byte[] { FULL_MODE }; // mwf = 01111111 = 0x7f 174 // comBitMode = FULL_MODE; 175 fullAccessFlag = true; 176 // oneModeFlag = true; 177 } 178 179 /** 180 * ロールとモードを?、RoleModeオブジェクトを構築します? 181 * こ?コンストラクタは、他?パッケージから呼び出せな??? 182 * パッケージプライベ?トにしておきます? 183 * 184 * @og.rev 4.3.0.0 (2008/07/04) ロールモード?ルチ対? 185 * 186 * @param roles "|"で区?れた ロール?? 187 * @param mode "|"で区?れ?ロール??と対応付けられたモード文字?。唯??場合?共通モードになる? 188 */ 189 private RoleMode( final String roles,final String mode ) { 190 this.roles = roles ; // ロールズ 191 this.rwmode = mode ; // モー? 192 193 // if( rwmode == null || ( rwmode.length() < 2 ) ) { 194 // String errMsg = "RWMODE の桁数は?桁以上?です?" 195 // + " roles [" + roles + "] Mode [" + rwmode + "]" 196 // + HybsSystem.CR + toString() ; 197 // throw new HybsSystemException( errMsg ); 198 // } 199 200 // roleArray = StringUtil.csv2Array( roles,HybsSystem.GUI_DELIMITER ) ; // ロール配? 201 202 // roles="root" また?、roleArray がな??合?、フルアクセス 203 // fullAccessFlag = "root".equals( roles ) || ( roleArray.length == 0 ); 204 fullAccessFlag = "root".equals( roles ) || ( roles == null ) || ( roles.length() == 0 ); 205 206 // modes が??の場合?、ワンモー? 207 // String[] modes = StringUtil.csv2Array( mode,HybsSystem.GUI_DELIMITER ) ; // モー? 208 // oneModeFlag = ( modes.length == 1 ); 209 210 roleArray = StringUtil.csv2Array( roles,HybsSystem.GUI_DELIMITER ) ; // ロール配? 211 212 // bitModes を求めます??1つは作?します?同時に、roleArray もセ?します? 213 // bitModes = makeBitMode( modes ); 214 bitModes = makeBitMode( roleArray,rwmode ); 215 } 216 217 /** 218 * ロールとモードを?、RoleModeオブジェクトを構築します? 219 * 条件が同?RoleModeオブジェク?があれ?、キャ?ュから返します? 220 * キャ?ュになければ、新規に作?します? 221 * こ?キャ?ュは、完?な?キャ?ュなので、いつクリアされるか保障がありません? 222 * 223 * @og.rev 4.3.0.0 (2008/07/04) ロールモード?ルチ対? 224 * 225 * @param roles "|"で区?れた ロール?? 226 * 227 * @return RoleModeオブジェク? 228 */ 229 public static RoleMode newInstance( final String roles ) { 230 if( roles == null || roles.length() == 0 ) { 231 return FULL_ACCESS_ROLE_MODE_OBJ; 232 } 233 234 return newInstance( roles,DEFAULT_MODE ); 235 } 236 237 /** 238 * ロールとモードを?、RoleModeオブジェクトを構築します? 239 * 条件が同?RoleModeオブジェク?があれ?、キャ?ュから返します? 240 * キャ?ュになければ、新規に作?します? 241 * こ?キャ?ュは、完?な?キャ?ュなので、いつクリアされるか保障がありません? 242 * 243 * @og.rev 4.3.0.0 (2008/07/04) ロールモード?ルチ対? 244 * 245 * @param roles "|"で区?れた ロール?? 246 * @param mode "|"で区?れ?ロール??と対応付けられたモード文字?。唯??場合?共通モードになる? 247 * 248 * @return RoleModeオブジェク? 249 */ 250 public static RoleMode newInstance( final String roles,final String mode ) { 251 if( mode == null || mode.length() < 2 ) { 252 String errMsg = "RWMODE の桁数は?桁以上?です?" 253 + " roles [" + roles + "] mode [" + mode + "]" 254 + HybsSystem.CR; 255 throw new HybsSystemException( errMsg ); 256 } 257 258 if( ( roles == null || roles.length() == 0 ) && 259 ( "mw".equals( mode ) || DEFAULT_MODE.equals( mode ) ) ) { 260 return FULL_ACCESS_ROLE_MODE_OBJ ; 261 } 262 263 String key = roles + mode ; 264 RoleMode roleMode = roleMap.get( key ); 265 if( roleMode == null ) { 266 roleMode = new RoleMode( roles,mode ); 267 roleMap.put( key,roleMode ); 268 } 269 270 return roleMode; 271 } 272 273 /** 274 * フルアクセスできるRoleModeオブジェクトを返します? 275 * これは、カラ?ブジェクトなど、ほとんどのケースでフルアクセスできる場合に? 276 * 同じオブジェクトを常に返すようにすることで、メモリの??以降?処??共通化? 277 * 図る為の機?です?シングルトン対応?NULLオブジェクトパターンに近いです? 278 * 279 * @return RoleMode フルアクセスできるRoleModeオブジェク? 280 */ 281 // static RoleMode getFullAccessRoleMode() { 282 // return FULL_ACCESS_ROLE_MODE_OBJ ; 283 // } 284 285 /** 286 * ロールズを返します? 287 * 288 * @return ロールズ?? 289 */ 290 public String getRoles() { return roles; } 291 292 /** 293 * モード?列を返します? 294 * 295 * @return モード?? 296 */ 297 public String getMode() { return rwmode; } 298 299 /** 300 * ユーザーロール配?と比?てアクセス可否を返します? 301 * 302 * @param userRoles ユーザーロール配? 303 * 304 * @return アクセスできる(true)/出来な?false) 305 */ 306 // public boolean isAccess( final String[] userRoles ) { 307 // if( fullAccessFlag ) { return ( bitModes[0] > 0 ); } 308 // 309 // // ユーザーロールが無??合?、アクセス不許可 310 // if( userRoles == null || userRoles.length == 0 ) { 311 // return false; 312 // } 313 // 314 // for( int g=0; g<roleArray.length; g++ ) { 315 //// byte bit = ( oneModeFlag ) ? bitModes[0] : bitModes[g] ; 316 // byte bit = bitModes[g] ; 317 // for( int u=0; u<userRoles.length; u++ ) { 318 // // 4.0.0.0 (2007/11/29) 入れ子if の統? 319 // if( bit > 0 && roleArray[g].equalsIgnoreCase( userRoles[u] ) ) { 320 // return true; 321 // } 322 // } 323 // } 324 // return false; 325 // } 326 327 /** 328 * ??ユーザーロールに対する?的なアクセス条件を取得します? 329 * アクセス条件は、?あるユーザーロールの中で、最大のアクセス条件を算?します? 330 * 例えば、AAA(-r)|BBB(-w)|CCC(mr) の?つのロール/モードが設定されて?場合? 331 * ユーザーが?AAA ?の場合??r ですが、AAA|BBB を持って?場合??w になります? 332 * さらに、BBB|CCC と持って?場合??-w:書き込み許可)と(mr:メニューから読取許可)の 333 * 権限により、mw:メニューからの書き込み許可が与えられます? 334 * モード指定がある場合?、AND演算になります? 335 * 例えば、AAA(-r)|BBB(-w)|CCC(mr) と BBB|CCC(-r) の場合?(-r)+(-w)+(mr)*(-r)=-w に 336 * なります?ロールは、OR ですが、モード?、同?ールでのAND になります? 337 * 実際には、メニュー表示の可否は、???ア??系によく用?れます?で、上記?ような 338 * 許可が実際にあるかど?は不?ですが、すべてのモード?OR条件での結合になります? 339 * 340 * @param userRoles ユーザーロール配? 341 * @param isRoot ルートロールフラグ 342 * 343 * @return ビットモード??"--:000","-r:001","-w:010","mr:101","mw:110" に対応した数?0,1,2,5,6) 344 */ 345 // public byte getAccessBitMode( final String[] userRoles,final boolean isRoot ) { 346 // if( fullAccessFlag ) { return bitModes[0]; } 347 // 348 // byte bitMode = 0; 349 // for( int g=0; g<roleArray.length; g++ ) { 350 //// byte bit = ( oneModeFlag ) ? bitModes[0] : bitModes[g] ; 351 // byte bit = bitModes[g] ; 352 // if( isRoot ) { 353 // bitMode |= bit; 354 // } 355 // else { 356 // String role = roleArray[g]; 357 // for( int u=0; u<userRoles.length; u++ ) { 358 // if( role.equalsIgnoreCase( userRoles[u] ) ) { 359 // bitMode |= bit; 360 // break; // ??すれば、?側のループを抜ける? 361 // } 362 // } 363 // } 364 // if( bitMode >= 6 ) { break; } // "mw:110" は?なので、以後判定不要? 365 // } 366 // 367 // return bitMode; 368 // } 369 370 /** 371 * ??ユーザーロールに対する?的なアクセス条件を取得します? 372 * アクセス条件は、?あるユーザーロールの中で、最大のアクセス条件を算?します? 373 * 例えば、AAA(-r)|BBB(-w)|CCC(mr) の?つのロール/モードが設定されて?場合? 374 * ユーザーが?AAA ?の場合??r ですが、AAA|BBB を持って?場合??w になります? 375 * さらに、BBB|CCC と持って?場合??-w:書き込み許可)と(mr:メニューから読取許可)の 376 * 権限により、mw:メニューからの書き込み許可が与えられます? 377 * モード指定がある場合?、AND演算になります? 378 * 例えば、AAA(-r)|BBB(-w)|CCC(mr) と BBB|CCC(-r) の場合?(-r)+(-w)+(mr)*(-r)=-w に 379 * なります?ロールは、OR ですが、モード?、同?ールでのAND になります? 380 * 実際には、メニュー表示の可否は、???ア??系によく用?れます?で、上記?ような 381 * 許可が実際にあるかど?は不?ですが、すべてのモード?OR条件での結合になります? 382 * 383 * @og.rev 4.3.0.0 (2008/07/04) ロールモード?ルチ対? 384 * 385 * @param other ロールモー? 386 * 387 * @return アクセスビッ? 388 */ 389 public byte getAccessBitMode( final RoleMode other ) { 390 if( fullAccessFlag || other.fullAccessFlag ) { 391 return (byte)(bitModes[0] & other.bitModes[0]) ; 392 } 393 394 String[] othRoleArray = other.roleArray ; // ロール配? 395 byte[] othBitModes = other.bitModes ; // モード?ビッ? 396 397 byte bitMode = 0; 398 for( int i=0; i<roleArray.length; i++ ) { 399 for( int j=0; j<othRoleArray.length; j++ ) { 400 if( roleArray[i].equals( othRoleArray[j] ) ) { 401 bitMode |= (byte)(bitModes[i] & othBitModes[j]) ; 402 if( bitMode == FULL_MODE ) { return FULL_MODE; } // 途中打ち? 403 } 404 } 405 } 406 407 return bitMode; 408 } 409 410 /** 411 * ビットロールのメニュー表示可否を返します? 412 * 413 * ロールが?m## , p## の場合に、true になります? 414 * これは、メニューに表示されるかど?の判定に使われます? 415 * 416 * @param bitMode ビットロール 417 * 418 * @return メニュー表示できる(true)/出来な?false) 419 */ 420 public static boolean isMenu( final byte bitMode ) { 421 return ( (bitMode & M_MODE) > 0 ); 422 } 423 424 /** 425 * ビットロールのプル?ン化を返します? 426 * 427 * ロールが?p## の場合に、true になります? 428 * ボタンメニュー時でも強制?従来のプル?ンにします? 429 * 今後??の方向です? 430 * 431 * @og.rev 4.3.3.0 (2008/10/01) メソ?追? 432 * @param bitMode ビットロール 433 * 434 * @return true:プル?ン? 435 */ 436 public static boolean isPulldown( final byte bitMode ) { 437 // M_MODEとの比?P_MODEの場合?強制プル?ン? 438 return ( (bitMode & M_MODE) == P_MODE ); 439 } 440 441 /** 442 * ビットロールの読込アクセス可否を返します? 443 * 444 * ロールが?#r# , #w# の場合に、true になります? 445 * 読み取り属?がある?合?画面が利用可能になります? 446 * #-# の場合?、画面へのアクセスができな?め? 447 * メニューアクセス許可を与える?m-# の設定?無意味です? 448 * こ?場合?、メニューにも表示されません? 449 * 450 * @param bitMode ビットロール 451 * 452 * @return 読込アクセスできる(true)/出来な?false) 453 */ 454 public static boolean isRead( final byte bitMode ) { 455 return ( (bitMode & R_MODE) > 0 ); 456 } 457 458 /** 459 * ビットロールの書込アクセス可否を返します? 460 * 461 * ロールが?#w# の場合に、true になります? 462 * 463 * これは、読込、書込みの判断ではなく?書込みができる? 464 * ど?の判断をして?す? 465 * 画面にアクセスできるかど?の判断は、isAccess を使用してください? 466 * 467 * @param bitMode ビットロール 468 * 469 * @return 書込アクセスできる(true)/出来な?false) 470 */ 471 public static boolean isWrite( final byte bitMode ) { 472 // 注意:W_MODE は、R_MODE と合?されて?ので? 0 で判断できな?? 473 return ( (bitMode & W_MODE) == W_MODE ); 474 } 475 476 /** 477 * ビットロールの画面アクセス可否を返します? 478 * 479 * これは、画面にアクセスできるかど?の判断です? 480 * ロールが?#r# , #w# の場合に、true になります? 481 * 現時点では、isRead(byte) と計算方法?異なりますが、同じ結果になって?す? 482 * これは、たまたま、現時点のロールの種類がそうなって??で、?? 483 * 同じかど?は、保障されて?せん? 484 * よって、読み取り許可と、画面アクセス許可は、?けて?てください? 485 * 486 * @param bitMode ビットロール 487 * 488 * @return 画面アクセスできる(true)/出来な?false) 489 */ 490 public static boolean isAccess( final byte bitMode ) { 491 return ( (bitMode & W_MODE) > 0 ); 492 } 493 494 /** 495 * ビットロールのファイル出力可否を返します? 496 * 497 * ロールが?##d , ##f , ##o , ##e(= ##) の場合に、true になります? 498 * ##u の場合に、false になります? 499 * ファイル出力?可否を判定します? 500 * ## は、互換性の関係で?#e と同じです? 501 * 502 * @param bitMode ビットロール 503 * 504 * @return ファイル出力できる(true)/出来な?false) 505 */ 506 public static boolean isDownload( final byte bitMode ) { 507 return ( (bitMode & D_MODE) > 0 ); 508 } 509 510 /** 511 * ビットロールのファイル入力可否を返します? 512 * 513 * ロールが?##u , ##f , ##o , ##e(= ##) の場合に、true になります? 514 * ##d の場合に、false になります? 515 * ファイル入力?可否を判定します? 516 * ## は、互換性の関係で?#e と同じです? 517 * ?ンロード?させな?、ア??ロードを行う場合に使?す? 518 * ここでのア??ロードとは、基本???タの取り込みになります?で? 519 * ア??ロード?みと?扱??、あまりありません? 520 * 521 * @param bitMode ビットロール 522 * 523 * @return ファイル入力できる(true)/出来な?false) 524 */ 525 public static boolean isUpload( final byte bitMode ) { 526 return ( (bitMode & U_MODE) > 0 ); 527 } 528 529 /** 530 * ビットロールの画面編?否を返します? 531 * 532 * ロールが?##o , ##e(= ##) の場合に、true になります? 533 * こ?ビットロール?特殊で、フラグ?ON の場合に、機?制限がかかります? 534 * 535 * @og.rev 5.4.2.0 (2011/12/01) 新規作? 536 * @og.rev 5.5.5.2 (2012/08/10) oモード追?伴?更 537 * 538 * @param bitMode ビットロール 539 * 540 * @return アクセスできる(true)/出来な?false) 541 */ 542 public static boolean isEdit( final byte bitMode ) { 543 // return ( (bitMode & E_MODE) == E_MODE ); 544 return ( (bitMode & O_MODE) == O_MODE ); 545 } 546 547 /** 548 * ビットロールの画面編??フルコントロール可否を返します? 549 * 550 * ロールが?##e(= ##) の場合に、true になります? 551 * これは、フルコントロールの状態を?ます? 552 * 553 * @og.rev 5.5.5.2 (2012/08/10) 新規作? 554 * 555 * @param bitMode ビットロール 556 * 557 * @return アクセスできる(true)/出来な?false) 558 */ 559 public static boolean isFullEdit( final byte bitMode ) { 560 // return ( (bitMode & E_MODE) == E_MODE ); 561 return ( (bitMode & E_MODE) == E_MODE ); 562 } 563 564 565 /** 566 * こ?画面のmode アクセス条件をビ?化します? 567 * 568 * RWMODE ??は、各ロールに対して?つの?で表して?す? 569 * ??-" メニュー非表示 "m" メニュー表示 "p" メニュー表示(強制プル?ン表示) 570 * ??-" アクセス拒否 "r" 読取許可 "w" 読取?書込許可 571 * ??-" 未対? "d" ファイル出? "u" ファイル入? "f" ファイル入出? 572 * … こ?d,u,f では、?出力方法設定?タブ?表示されません? 573 * "o" 表示???み可 … こ?設定では、?表示?設定? タブで位置と表示??み変更できます? 574 * "e" 画面編? … こ?設定で、編??がフルに使えます? 575 * 互換性の関係より?"" は?e" と同等とします? 576 * 577 * 区???|』で同じ?で?します? 578 * roles がな?、modes が?か?roles と modes の個数が異なる?? 579 * 唯??モー?共通モー?として、modes[0] を割り当てます? 580 * 互換性のため?rw" と "r-" も??きるようにします? 581 * こ???目を?次つな??--","-r","-w","mr","mw" などの設定を行います? 582 * モードが設定されて?場合?、?通モードとして、すべてのロールに同じモードを 583 * 割り当てます?個別に割り当てる?合?、ROLES ??の後ろに () 付きで追記します? 584 * 例えば、AAA|BBB(-r)|CCC とすれば、BBB ロールの場合?、読取専用になります? 585 * ロールを?つける場合?、AND 演算になります? 586 * 587 * @og.rev 4.3.0.0 (2008/07/04) ロールモード?ルチ対? 588 * 589 * @param roles 画面ロール配? 590 * @param mode 画面モー? 591 * 592 * @return ビットモード??"--:000","-r:001","-w:010","mr:101","mw:110" に対応した数?0,1,2,5,6) 593 */ 594 // private byte[] makeBitMode( final String[] modes ) { 595 private byte[] makeBitMode( final String[] roles,final String mode ) { 596 byte[] bits = null; 597 598 byte commnMode = bitMode( mode ); // 共通MODEの設? 599 600 int size = roles.length ; 601 if( size == 0 ) { 602 bits = new byte[] { commnMode }; 603 } 604 else { 605 bits = new byte[size] ; 606 for( int i=0; i<size; i++ ) { 607 String roleMode = null; 608 String role = roles[i]; 609 int adrs = ( role != null ) ? role.indexOf( '(' ) : -1 ; 610 if( adrs >= 0 ) { 611 roleMode = role.substring( adrs+1,role.length() -1 ); 612 // 注意:roleArray に書き戻して?す?(副作用処? 613 roles[i] = role.substring( 0,adrs ); 614 } 615 bits[i] = (byte)(commnMode & bitMode( roleMode )) ; 616 } 617 } 618 619 return bits ; 620 } 621 622 /** 623 * モード文字?に対するビット変換を行います? 624 * 625 * RWMODE ??は?つの?で表して?す? 626 * ??-" メニュー非表示 "m" メニュー表示 627 * ??-" アクセス拒否 "r" 読取許可 "w" 読取?書込許可 628 * ??-" 未対? "d" ファイル出? "u" ファイル入? "f" ファイル入出? 629 * … こ?d,u,f では、?出力方法設定?タブ?表示されません? 630 * "o" 表示???み可 … こ?設定では、?表示?設定? タブで位置と表示??み変更できます? 631 * "e" 画面編? … こ?設定で、編??がフルに使えます? 632 * 互換性の関係より?"" は?e" と同等とします? 633 * 634 * それぞれのキーワードに対して、ビ?制御を行います? 635 * こ?メソ?には、ロールモー?ロール単位に追?るモー?の判定も 636 * 行う事が出来るよ?、引数?null の場合?、FULL_MODE を返します? 637 * 638 * 全許可 ( mwe ) FULL_MODE 639 * メニュー表示 ( m-- ) M_MODE 640 * 強制プル?ン表示 ( p-- ) P_MODE 641 * 読取許可 ( -r- ) R_MODE 642 * 書込許可 ( -w- ) W_MODE 643 * ファイル出? ( --d ) D_MODE 644 * ファイル入? ( --u ) U_MODE 645 * ファイル入出? ( --f ) F_MODE 646 * 表示???み可 ( --o ) O_MODE 647 * 画面編? ( --e ) E_MODE 648 * 649 * @og.rev 4.3.0.0 (2008/07/04) ロールモード?ルチ対? 650 * @og.rev 4.3.3.0 (2008/10/01) pモード対?mと同じ扱? 651 * @og.rev 5.4.2.0 (2011/12/01) eモード対? 652 * @og.rev 5.5.5.2 (2012/08/10) oモード対? 653 * 654 * @param mode モード文字? 655 * 656 * @return ビットモー? 657 */ 658 private byte bitMode( final String mode ) { 659 byte bit = 0x00; 660 661 if( mode == null ) { 662 bit = FULL_MODE; 663 } 664 else { 665 int len = mode.length(); 666 for( int i=0; i<len; i++ ) { 667 switch( mode.charAt(i) ) { 668 case 'm' : bit |= M_MODE; break; 669 case 'p' : bit |= P_MODE; break; // 4.3.3.0 (2008/10/01) Pモード追? 670 case 'r' : bit |= R_MODE; break; 671 case 'w' : bit |= W_MODE; break; 672 case 'd' : bit |= D_MODE; break; 673 case 'u' : bit |= U_MODE; break; 674 case 'f' : bit |= F_MODE; break; 675 case 'e' : bit |= E_MODE; break; // 5.4.2.0 (2011/12/01) Eモード追? 676 case 'o' : bit |= O_MODE; break; // 5.5.5.2 (2011/12/10) Oモード追? 677 case '-' : break; 678 default : 679 String errMsg = "RWMODE に不正な記号が使用されて?す?" 680 + " mrwdufe- のみ、使用可能です?" 681 + " roles [" + roles + "] mode [" + mode + "]" 682 + HybsSystem.CR; 683 throw new HybsSystemException( errMsg ); 684 } 685 } 686 // if( len < 3 ) { bit |= F_MODE; } // 互換性暫定対? 687 if( len < 3 ) { bit |= E_MODE; } // 互換性暫定対?// 5.4.2.0 (2011/12/01) 688 689 // RWアクセスできな??合?、ファイルアクセスも禁止します? 690 if( ( bit & W_MODE ) == 0 ) { bit = 0x00; } 691 } 692 693 return bit ; 694 } 695 696 /** 697 * オブジェクト?識別子として?詳細なユーザー??を返します? 698 * 699 * @return 詳細な画面?? 700 */ 701 @Override 702 public String toString() { 703 StringBuilder rtn = new StringBuilder( HybsSystem.BUFFER_MIDDLE ); 704 rtn.append( "roles : " ).append( roles ).append( HybsSystem.CR ); 705 rtn.append( "rwmode : " ).append( rwmode ).append( HybsSystem.CR ); 706 return rtn.toString(); 707 } 708 }