DBA Data[Home] [Help]

PACKAGE BODY: APPS.HR_SA_PERSON_API

Source


1 package body hr_sa_person_api as
2 /* $Header: pepersai.pkb 120.3 2005/06/20 02:05:11 adevanat noship $ */
3 
4    -- Package Variables
5    g_package   VARCHAR2(33) := 'hr_sa_person_api.';
6    g_debug boolean := hr_utility.debug_enabled;
7 
8 procedure update_sa_person
9   (p_validate                     in      boolean   default false
10   ,p_effective_date               in      date
11   ,p_datetrack_update_mode        in      varchar2
12   ,p_person_id                    in      number
13   ,p_object_version_number        in out nocopy  number
14   ,p_person_type_id               in      number   default hr_api.g_number
15   ,p_family_name                  in      varchar2 default hr_api.g_varchar2
16   ,p_applicant_number             in      varchar2 default hr_api.g_varchar2
17   ,p_comments                     in      varchar2 default hr_api.g_varchar2
18   ,p_date_employee_data_verified  in      date     default hr_api.g_date
19   ,p_date_of_birth                in      date     default hr_api.g_date
20   ,p_email_address                in      varchar2 default hr_api.g_varchar2
21   ,p_employee_number              in out nocopy  varchar2
22   ,p_expense_check_send_to_addres in      varchar2 default hr_api.g_varchar2
23   ,p_first_name                   in      varchar2 default hr_api.g_varchar2
24   ,p_known_as                     in      varchar2 default hr_api.g_varchar2
25   ,p_marital_status               in      varchar2 default hr_api.g_varchar2
26   ,p_nationality                  in      varchar2 default hr_api.g_varchar2
27   ,p_national_identifier          in      varchar2 default hr_api.g_varchar2
28   ,p_previous_last_name           in      varchar2 default hr_api.g_varchar2
29   ,p_registered_disabled_flag     in      varchar2 default hr_api.g_varchar2
30   ,p_sex                          in      varchar2 default hr_api.g_varchar2
31   ,p_title                        in      varchar2 default hr_api.g_varchar2
32   ,p_vendor_id                    in      number   default hr_api.g_number
33   ,p_work_telephone               in      varchar2 default hr_api.g_varchar2
34   ,p_attribute_category           in      varchar2 default hr_api.g_varchar2
35   ,p_attribute1                   in      varchar2 default hr_api.g_varchar2
36   ,p_attribute2                   in      varchar2 default hr_api.g_varchar2
37   ,p_attribute3                   in      varchar2 default hr_api.g_varchar2
38   ,p_attribute4                   in      varchar2 default hr_api.g_varchar2
39   ,p_attribute5                   in      varchar2 default hr_api.g_varchar2
40   ,p_attribute6                   in      varchar2 default hr_api.g_varchar2
41   ,p_attribute7                   in      varchar2 default hr_api.g_varchar2
42   ,p_attribute8                   in      varchar2 default hr_api.g_varchar2
43   ,p_attribute9                   in      varchar2 default hr_api.g_varchar2
44   ,p_attribute10                  in      varchar2 default hr_api.g_varchar2
45   ,p_attribute11                  in      varchar2 default hr_api.g_varchar2
46   ,p_attribute12                  in      varchar2 default hr_api.g_varchar2
47   ,p_attribute13                  in      varchar2 default hr_api.g_varchar2
48   ,p_attribute14                  in      varchar2 default hr_api.g_varchar2
49   ,p_attribute15                  in      varchar2 default hr_api.g_varchar2
50   ,p_attribute16                  in      varchar2 default hr_api.g_varchar2
51   ,p_attribute17                  in      varchar2 default hr_api.g_varchar2
52   ,p_attribute18                  in      varchar2 default hr_api.g_varchar2
53   ,p_attribute19                  in      varchar2 default hr_api.g_varchar2
54   ,p_attribute20                  in      varchar2 default hr_api.g_varchar2
55   ,p_attribute21                  in      varchar2 default hr_api.g_varchar2
56   ,p_attribute22                  in      varchar2 default hr_api.g_varchar2
57   ,p_attribute23                  in      varchar2 default hr_api.g_varchar2
58   ,p_attribute24                  in      varchar2 default hr_api.g_varchar2
59   ,p_attribute25                  in      varchar2 default hr_api.g_varchar2
60   ,p_attribute26                  in      varchar2 default hr_api.g_varchar2
61   ,p_attribute27                  in      varchar2 default hr_api.g_varchar2
62   ,p_attribute28                  in      varchar2 default hr_api.g_varchar2
63   ,p_attribute29                  in      varchar2 default hr_api.g_varchar2
64   ,p_attribute30                  in      varchar2 default hr_api.g_varchar2
65   ,p_father_name             	  in      varchar2 default hr_api.g_varchar2
66   ,p_grandfather_name             in      varchar2 default hr_api.g_varchar2
67   ,p_alt_first_name               in      varchar2 default hr_api.g_varchar2
68   ,p_alt_father_name              in      varchar2 default hr_api.g_varchar2
69   ,p_alt_grandfather_name         in      varchar2 default hr_api.g_varchar2
70   ,p_alt_family_name           	  in      varchar2 default hr_api.g_varchar2
71   ,p_religion			  in      varchar2 default hr_api.g_varchar2
72   ,p_hijrah_birth_date		  in      varchar2 default hr_api.g_varchar2
73   ,p_date_of_death                in      date     default hr_api.g_date
74   ,p_education_level              in      varchar2 default hr_api.g_varchar2
75   ,p_background_check_status      in      varchar2 default hr_api.g_varchar2
76   ,p_background_date_check        in      date     default hr_api.g_date
77   ,p_blood_type                   in      varchar2 default hr_api.g_varchar2
78   ,p_correspondence_language      in      varchar2 default hr_api.g_varchar2
79   ,p_fast_path_employee           in      varchar2 default hr_api.g_varchar2
80   ,p_fte_capacity                 in      number   default hr_api.g_number
81   ,p_hold_applicant_date_until    in      date     default hr_api.g_date
82   ,p_honors                       in      varchar2 default hr_api.g_varchar2
83   ,p_internal_location            in      varchar2 default hr_api.g_varchar2
84   ,p_last_medical_test_by         in      varchar2 default hr_api.g_varchar2
85   ,p_last_medical_test_date       in      date     default hr_api.g_date
86   ,p_mailstop                     in      varchar2 default hr_api.g_varchar2
87   ,p_office_number                in      varchar2 default hr_api.g_varchar2
88   ,p_on_military_service          in      varchar2 default hr_api.g_varchar2
89   ,p_projected_start_date         in      date     default hr_api.g_date
90   ,p_rehire_authorizor            in      varchar2 default hr_api.g_varchar2
91   ,p_rehire_recommendation        in      varchar2 default hr_api.g_varchar2
92   ,p_resume_exists                in      varchar2 default hr_api.g_varchar2
93   ,p_resume_last_updated          in      date     default hr_api.g_date
94   ,p_second_passport_exists       in      varchar2 default hr_api.g_varchar2
95   ,p_student_status               in      varchar2 default hr_api.g_varchar2
96   ,p_work_schedule                in      varchar2 default hr_api.g_varchar2
97   ,p_rehire_reason                in      varchar2 default hr_api.g_varchar2
98   ,p_benefit_group_id             in      number   default hr_api.g_number
99   ,p_receipt_of_death_cert_date   in      date     default hr_api.g_date
100   ,p_coord_ben_med_pln_no         in      varchar2 default hr_api.g_varchar2
101   ,p_coord_ben_no_cvg_flag        in      varchar2 default hr_api.g_varchar2
102   ,p_coord_ben_med_ext_er         in      varchar2 default hr_api.g_varchar2
103   ,p_coord_ben_med_pl_name        in      varchar2 default hr_api.g_varchar2
104   ,p_coord_ben_med_insr_crr_name  in      varchar2 default hr_api.g_varchar2
105   ,p_coord_ben_med_insr_crr_ident in      varchar2 default hr_api.g_varchar2
106   ,p_coord_ben_med_cvg_strt_dt    in      date     default hr_api.g_date
107   ,p_coord_ben_med_cvg_end_dt     in      date     default hr_api.g_date
108   ,p_uses_tobacco_flag            in      varchar2 default hr_api.g_varchar2
109   ,p_dpdnt_adoption_date          in      date     default hr_api.g_date
110   ,p_dpdnt_vlntry_svce_flag       in      varchar2 default hr_api.g_varchar2
111   ,p_original_date_of_hire        in      date     default hr_api.g_date
112   ,p_adjusted_svc_date            in      date     default hr_api.g_date
113   ,p_town_of_birth                in      varchar2 default hr_api.g_varchar2
114   ,p_region_of_birth              in      varchar2 default hr_api.g_varchar2
115   ,p_country_of_birth             in      varchar2 default hr_api.g_varchar2
116   ,p_global_person_id             in      varchar2 default hr_api.g_varchar2
117   ,p_party_id                     in      number   default hr_api.g_number
118   ,p_npw_number                   in      varchar2 default hr_api.g_varchar2
119   ,p_effective_start_date            out nocopy  date
120   ,p_effective_end_date              out nocopy  date
121   ,p_full_name                       out nocopy  varchar2
122   ,p_comment_id                      out nocopy  number
123   ,p_name_combination_warning        out nocopy  boolean
124   ,p_assign_payroll_warning          out nocopy  boolean
125   ,p_orig_hire_warning               out nocopy  boolean
126   ) is
127 
128   --
129   -- Declare cursors and local variables
130   --
131 
132   l_proc                 varchar2(72) := g_package||'update_sa_person';
133   l_effective_date       date;
134   l_legislation_code     per_business_groups.legislation_code%type;
135   l_discard_varchar2     varchar2(30);
136   --
137   cursor check_legislation
138     (c_person_id      per_people_f.person_id%TYPE,
139      c_effective_date date
140     )
141   is
142     select bgp.legislation_code
143     from per_people_f per,
144          per_business_groups bgp
145     where per.business_group_id = bgp.business_group_id
146     and   per.person_id     = c_person_id
147     and   c_effective_date
148       between per.effective_start_date and per.effective_end_date;
149   --
150 begin
151 
152  if g_debug then
153   hr_utility.set_location('Entering:'|| l_proc, 5);
154  end if;
155   --
156   -- Initialise local variables
157   --
158   l_effective_date := trunc(p_effective_date);
159   --
160   -- Validation in addition to Row Handlers
161   --
162   -- Check that the person exists.
163   --
164   open check_legislation(p_person_id, l_effective_date);
165   fetch check_legislation into l_legislation_code;
166   if check_legislation%notfound then
167     close check_legislation;
168     hr_utility.set_message(801,'HR_7220_INVALID_PRIMARY_KEY');
169     hr_utility.raise_error;
170   end if;
171   close check_legislation;
172  if g_debug then
173   hr_utility.set_location(l_proc, 20);
174  end if;
175   --
176   -- Check that the legislation of the specified business group is 'SA'.
177   --
178   if l_legislation_code <> 'SA' then
179     hr_utility.set_message(801, 'HR_7961_PER_BUS_GRP_INVALID');
180     hr_utility.set_message_token('LEG_CODE','SA');
181     hr_utility.raise_error;
182   end if;
183  if g_debug then
184   hr_utility.set_location(l_proc, 30);
185  end if;
186   --
187   -- Update the person record using the update_person
188   --
189   hr_person_api.update_person
190   (p_validate                     => p_validate
191   ,p_effective_date               => l_effective_date
192   ,p_datetrack_update_mode        => p_datetrack_update_mode
193   ,p_person_id                    => p_person_id
194   ,p_object_version_number        => p_object_version_number
195   ,p_person_type_id               => p_person_type_id
196   ,p_last_name                    => p_family_name
197   ,p_applicant_number             => p_applicant_number
198   ,p_comments                     => p_comments
199   ,p_date_employee_data_verified  => p_date_employee_data_verified
200   ,p_date_of_birth                => p_date_of_birth
201   ,p_email_address                => p_email_address
202   ,p_employee_number              => p_employee_number
203   ,p_expense_check_send_to_addres => p_expense_check_send_to_addres
204   ,p_first_name                   => p_first_name
205   ,p_known_as                     => p_known_as
206   ,p_marital_status               => p_marital_status
207   ,p_nationality                  => p_nationality
208   ,p_national_identifier          => p_national_identifier
209   ,p_previous_last_name           => p_previous_last_name
210   ,p_registered_disabled_flag     => p_registered_disabled_flag
211   ,p_sex                          => p_sex
212   ,p_title                        => p_title
213   ,p_vendor_id                    => p_vendor_id
214   ,p_work_telephone               => p_work_telephone
215   ,p_attribute_category           => p_attribute_category
216   ,p_attribute1                   => p_attribute1
217   ,p_attribute2                   => p_attribute2
218   ,p_attribute3                   => p_attribute3
219   ,p_attribute4                   => p_attribute4
220   ,p_attribute5                   => p_attribute5
221   ,p_attribute6                   => p_attribute6
222   ,p_attribute7                   => p_attribute7
223   ,p_attribute8                   => p_attribute8
224   ,p_attribute9                   => p_attribute9
225   ,p_attribute10                  => p_attribute10
226   ,p_attribute11                  => p_attribute11
227   ,p_attribute12                  => p_attribute12
228   ,p_attribute13                  => p_attribute13
229   ,p_attribute14                  => p_attribute14
230   ,p_attribute15                  => p_attribute15
231   ,p_attribute16                  => p_attribute16
232   ,p_attribute17                  => p_attribute17
233   ,p_attribute18                  => p_attribute18
234   ,p_attribute19                  => p_attribute19
235   ,p_attribute20                  => p_attribute20
236   ,p_attribute21                  => p_attribute21
237   ,p_attribute22                  => p_attribute22
238   ,p_attribute23                  => p_attribute23
239   ,p_attribute24                  => p_attribute24
240   ,p_attribute25                  => p_attribute25
241   ,p_attribute26                  => p_attribute26
242   ,p_attribute27                  => p_attribute27
243   ,p_attribute28                  => p_attribute28
244   ,p_attribute29                  => p_attribute29
245   ,p_attribute30                  => p_attribute30
246   ,p_per_information_category     => 'SA'
247   ,p_per_information1         	  => p_father_name
248   ,p_per_information2             => p_grandfather_name
249   ,p_per_information3             => p_alt_first_name
250   ,p_per_information4             => p_alt_father_name
251   ,p_per_information5             => p_alt_grandfather_name
252   ,p_per_information6          	  => p_alt_family_name
253   ,p_per_information7		  => p_religion
254   ,p_per_information8		  => p_hijrah_birth_date
255   ,p_per_information10	          => p_education_level
256   ,p_date_of_death                => p_date_of_death
257   ,p_background_check_status      => p_background_check_status
258   ,p_background_date_check        => p_background_date_check
259   ,p_blood_type                   => p_blood_type
260   ,p_correspondence_language      => p_correspondence_language
261   ,p_fast_path_employee           => p_fast_path_employee
262   ,p_fte_capacity                 => p_fte_capacity
263   ,p_hold_applicant_date_until    => p_hold_applicant_date_until
264   ,p_honors                       => p_honors
265   ,p_internal_location            => p_internal_location
266   ,p_last_medical_test_by         => p_last_medical_test_by
267   ,p_last_medical_test_date       => p_last_medical_test_date
268   ,p_mailstop                     => p_mailstop
269   ,p_office_number                => p_office_number
270   ,p_on_military_service          => p_on_military_service
271   ,p_projected_start_date         => p_projected_start_date
272   ,p_rehire_authorizor            => p_rehire_authorizor
273   ,p_rehire_recommendation        => p_rehire_recommendation
274   ,p_resume_exists                => p_resume_exists
275   ,p_resume_last_updated          => p_resume_last_updated
276   ,p_second_passport_exists       => p_second_passport_exists
277   ,p_student_status               => p_student_status
278   ,p_work_schedule                => p_work_schedule
279   ,p_rehire_reason                => p_rehire_reason
280   ,p_benefit_group_id             => p_benefit_group_id
281   ,p_receipt_of_death_cert_date   => p_receipt_of_death_cert_date
282   ,p_coord_ben_med_pln_no         => p_coord_ben_med_pln_no
283   ,p_coord_ben_no_cvg_flag        => p_coord_ben_no_cvg_flag
284   ,p_coord_ben_med_ext_er         => p_coord_ben_med_ext_er
285   ,p_coord_ben_med_pl_name        => p_coord_ben_med_pl_name
286   ,p_coord_ben_med_insr_crr_name  => p_coord_ben_med_insr_crr_name
287   ,p_coord_ben_med_insr_crr_ident => p_coord_ben_med_insr_crr_ident
288   ,p_coord_ben_med_cvg_strt_dt    => p_coord_ben_med_cvg_strt_dt
289   ,p_coord_ben_med_cvg_end_dt     => p_coord_ben_med_cvg_end_dt
290   ,p_uses_tobacco_flag            => p_uses_tobacco_flag
291   ,p_dpdnt_adoption_date          => p_dpdnt_adoption_date
292   ,p_dpdnt_vlntry_svce_flag       => p_dpdnt_vlntry_svce_flag
293   ,p_original_date_of_hire        => p_original_date_of_hire
294   ,p_adjusted_svc_date            => p_adjusted_svc_date
295   ,p_town_of_birth                => p_town_of_birth
296   ,p_region_of_birth              => p_region_of_birth
297   ,p_country_of_birth             => p_country_of_birth
298   ,p_global_person_id             => p_global_person_id
299   ,p_party_id                     => p_party_id
300   ,p_npw_number                   => p_npw_number
301   ,p_effective_start_date         => p_effective_start_date
302   ,p_effective_end_date           => p_effective_end_date
303   ,p_full_name                    => p_full_name
304   ,p_comment_id                   => p_comment_id
305   ,p_name_combination_warning     => p_name_combination_warning
306   ,p_assign_payroll_warning       => p_assign_payroll_warning
307   ,p_orig_hire_warning            => p_orig_hire_warning
308   );
309   --
310  if g_debug then
311   hr_utility.set_location(' Leaving:'||l_proc, 7);
312  end if;
313   --
314 end update_sa_person;
315 end hr_sa_person_api;