Advertisement
Advertisement
| 07.22.2008 at 06:35AM PDT, ID: 23585015 |
|
[x]
Attachment Details
|
||
1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47: 48: 49: 50: 51: 52: 53: 54: 55: 56: 57: 58: 59: 60: 61: 62: 63: 64: 65: 66: 67: 68: 69: |
create or replace function "GET_ACCESS"
(pPID NUMBER,
pUSER_TYPE in VARCHAR2,
pPAGE_TYPE in VARCHAR2)
return BOOLEAN
is
lcnt NUMBER;
begin
CASE
WHEN pPAGE_TYPE='ENTER' THEN
select count(*) into lcnt
from AUDIT_USE U, AUDIT_TEMPLATE T
where U.AUDIT_TEMPLATE_ID = t.AUDIT_TEMPLATE_ID
AND ( (pUSER_TYPE IN ('ADMIN','TPM'))
OR (pUSER_TYPE IN ('CLIENT','SUPER')
AND U.AUDIT_TEMPLATE_ID IN
(Select AUDIT_TEMPLATE_ID from SECURE_TEMPLATE
where PID = pPID
and (ALLX = 'Y' OR AUDIT_AUTH = 'Y')
)
)
);
WHEN pPAGE_TYPE='EDIT' THEN
select count(*) into lcnt
from AUDIT_USE U, AUDIT_TEMPLATE T
where U.AUDIT_TEMPLATE_ID = t.AUDIT_TEMPLATE_ID
AND ( (pUSER_TYPE = 'ADMIN')
OR (pUSER_TYPE = 'TPM' AND U.AUDITOR_ID IN
(select PID from PERSON where user_type = 'TPM')
)
OR (pUSER_TYPE IN ('CLIENT','SUPER')
AND t.AUDIT_TEMPLATE_ID IN
(Select AUDIT_TEMPLATE_ID from SECURE_TEMPLATE
where PID = pPID
AND (ALLX = 'Y' OR AUDIT_AUTH = 'Y')
)
)
);
WHEN pPAGE_TYPE='VIEW' OR pPAGE_TYPE='REPORT' THEN
select count(*) into lcnt
from AUDIT_USE U, AUDIT_TEMPLATE T
where U.AUDIT_TEMPLATE_ID = t.AUDIT_TEMPLATE_ID
AND ( (pUSER_TYPE IN ('ADMIN','TPM'))
OR (pUSER_TYPE IN ('CLIENT','SUPER')
AND t.AUDIT_TEMPLATE_ID IN
(Select AUDIT_TEMPLATE_ID from SECURE_TEMPLATE
where PID = pPID
AND (ALLX = 'Y' OR AUDIT_AUTH = 'Y')
)
)
OR (U.EXAMINER_ID = pPID AND U.COMPLETE = 'Y')
OR (pUSER_TYPE = 'SUPER'
AND (U.EXAMINER_ID = U.SUPERVISOR_ID
OR U.EXAMINER_ID IN (select E.PID
from PERSON E, PERSON S
where S.PID = pPID
and E.REPORTS_TO_1 = S.position_id
OR E.REPORTS_TO_2 = S.position_id
OR E.REPORTS_TO_3 = S.position_id
OR E.REPORTS_TO_4 = S.position_id
)
)
)
);
END CASE;
if(lcnt >0)then return true; end if;
return false;
end;
|