DBA Data[Home] [Help]

PACKAGE BODY: APPS.BEN_AGE_RATES_API

Source


1 Package Body ben_age_rates_api as
2 /* $Header: beartapi.pkb 115.5 2002/12/31 23:56:23 mmudigon ship $ */
3 --
4 -- Package Variables
5 --
6 g_package  varchar2(33) := '  ben_age_rates_api.';
7 --
8 -- ----------------------------------------------------------------------------
9 -- |------------------------< create_age_rates >------------------------------|
10 -- ----------------------------------------------------------------------------
11 --
12 procedure create_age_rates
13   (p_validate                       in  boolean   default false
14   ,p_age_rt_id                      out nocopy number
15   ,p_effective_start_date           out nocopy date
16   ,p_effective_end_date             out nocopy date
17   ,p_business_group_id              in  number    default null
18   ,p_vrbl_rt_prfl_id                in  number    default null
19   ,p_age_fctr_id                    in  number    default null
20   ,p_ordr_num                       in  number    default null
21   ,p_excld_flag                     in  varchar2  default null
22   ,p_art_attribute_category         in  varchar2  default null
23   ,p_art_attribute1                 in  varchar2  default null
24   ,p_art_attribute2                 in  varchar2  default null
25   ,p_art_attribute3                 in  varchar2  default null
26   ,p_art_attribute4                 in  varchar2  default null
27   ,p_art_attribute5                 in  varchar2  default null
28   ,p_art_attribute6                 in  varchar2  default null
29   ,p_art_attribute7                 in  varchar2  default null
30   ,p_art_attribute8                 in  varchar2  default null
31   ,p_art_attribute9                 in  varchar2  default null
32   ,p_art_attribute10                in  varchar2  default null
33   ,p_art_attribute11                in  varchar2  default null
34   ,p_art_attribute12                in  varchar2  default null
35   ,p_art_attribute13                in  varchar2  default null
36   ,p_art_attribute14                in  varchar2  default null
37   ,p_art_attribute15                in  varchar2  default null
38   ,p_art_attribute16                in  varchar2  default null
39   ,p_art_attribute17                in  varchar2  default null
40   ,p_art_attribute18                in  varchar2  default null
41   ,p_art_attribute19                in  varchar2  default null
42   ,p_art_attribute20                in  varchar2  default null
43   ,p_art_attribute21                in  varchar2  default null
44   ,p_art_attribute22                in  varchar2  default null
45   ,p_art_attribute23                in  varchar2  default null
46   ,p_art_attribute24                in  varchar2  default null
47   ,p_art_attribute25                in  varchar2  default null
48   ,p_art_attribute26                in  varchar2  default null
49   ,p_art_attribute27                in  varchar2  default null
50   ,p_art_attribute28                in  varchar2  default null
51   ,p_art_attribute29                in  varchar2  default null
52   ,p_art_attribute30                in  varchar2  default null
53   ,p_object_version_number          out nocopy number
54   ,p_effective_date                 in  date
55   ) is
56   --
57   -- Declare cursors and local variables
58   --
59   l_age_rt_id ben_age_rt_f.age_rt_id%TYPE;
60   l_effective_start_date ben_age_rt_f.effective_start_date%TYPE;
61   l_effective_end_date ben_age_rt_f.effective_end_date%TYPE;
62   l_proc varchar2(72) := g_package||'create_age_rates';
63   l_object_version_number ben_age_rt_f.object_version_number%TYPE;
64   --
65 begin
66   --
67   hr_utility.set_location('Entering:'|| l_proc, 10);
68   --
69   -- Issue a savepoint if operating in validation only mode
70   --
71   savepoint create_age_rates;
72   --
73   hr_utility.set_location(l_proc, 20);
74   --
75   -- Process Logic
76   --
77   begin
78     --
79     -- Start of API User Hook for the before hook of create_age_rates
80     --
81     ben_age_rates_bk1.create_age_rates_b
82       (
83        p_business_group_id              =>  p_business_group_id
84       ,p_vrbl_rt_prfl_id                =>  p_vrbl_rt_prfl_id
85       ,p_age_fctr_id                    =>  p_age_fctr_id
86       ,p_ordr_num                       =>  p_ordr_num
87       ,p_excld_flag                     =>  p_excld_flag
88       ,p_art_attribute_category         =>  p_art_attribute_category
89       ,p_art_attribute1                 =>  p_art_attribute1
90       ,p_art_attribute2                 =>  p_art_attribute2
91       ,p_art_attribute3                 =>  p_art_attribute3
92       ,p_art_attribute4                 =>  p_art_attribute4
93       ,p_art_attribute5                 =>  p_art_attribute5
94       ,p_art_attribute6                 =>  p_art_attribute6
95       ,p_art_attribute7                 =>  p_art_attribute7
96       ,p_art_attribute8                 =>  p_art_attribute8
97       ,p_art_attribute9                 =>  p_art_attribute9
98       ,p_art_attribute10                =>  p_art_attribute10
99       ,p_art_attribute11                =>  p_art_attribute11
100       ,p_art_attribute12                =>  p_art_attribute12
101       ,p_art_attribute13                =>  p_art_attribute13
102       ,p_art_attribute14                =>  p_art_attribute14
103       ,p_art_attribute15                =>  p_art_attribute15
104       ,p_art_attribute16                =>  p_art_attribute16
105       ,p_art_attribute17                =>  p_art_attribute17
106       ,p_art_attribute18                =>  p_art_attribute18
107       ,p_art_attribute19                =>  p_art_attribute19
108       ,p_art_attribute20                =>  p_art_attribute20
109       ,p_art_attribute21                =>  p_art_attribute21
110       ,p_art_attribute22                =>  p_art_attribute22
111       ,p_art_attribute23                =>  p_art_attribute23
112       ,p_art_attribute24                =>  p_art_attribute24
113       ,p_art_attribute25                =>  p_art_attribute25
114       ,p_art_attribute26                =>  p_art_attribute26
115       ,p_art_attribute27                =>  p_art_attribute27
116       ,p_art_attribute28                =>  p_art_attribute28
117       ,p_art_attribute29                =>  p_art_attribute29
118       ,p_art_attribute30                =>  p_art_attribute30
119       ,p_effective_date                 => trunc(p_effective_date)
120       );
121   exception
122     when hr_api.cannot_find_prog_unit then
123       hr_api.cannot_find_prog_unit_error
124         (
125          p_module_name => 'CREATE_age_rates'
126         ,p_hook_type   => 'BP'
127         );
128     --
129     -- End of API User Hook for the before hook of create_age_rates
130     --
131   end;
132   --
133   ben_art_ins.ins
134     (
135      p_age_rt_id                     => l_age_rt_id
136     ,p_effective_start_date          => l_effective_start_date
137     ,p_effective_end_date            => l_effective_end_date
138     ,p_business_group_id             => p_business_group_id
139     ,p_vrbl_rt_prfl_id               => p_vrbl_rt_prfl_id
140     ,p_age_fctr_id                   => p_age_fctr_id
141     ,p_ordr_num                      => p_ordr_num
142     ,p_excld_flag                    => p_excld_flag
143     ,p_art_attribute_category        => p_art_attribute_category
144     ,p_art_attribute1                => p_art_attribute1
145     ,p_art_attribute2                => p_art_attribute2
146     ,p_art_attribute3                => p_art_attribute3
147     ,p_art_attribute4                => p_art_attribute4
148     ,p_art_attribute5                => p_art_attribute5
149     ,p_art_attribute6                => p_art_attribute6
150     ,p_art_attribute7                => p_art_attribute7
151     ,p_art_attribute8                => p_art_attribute8
152     ,p_art_attribute9                => p_art_attribute9
153     ,p_art_attribute10               => p_art_attribute10
154     ,p_art_attribute11               => p_art_attribute11
155     ,p_art_attribute12               => p_art_attribute12
156     ,p_art_attribute13               => p_art_attribute13
157     ,p_art_attribute14               => p_art_attribute14
158     ,p_art_attribute15               => p_art_attribute15
159     ,p_art_attribute16               => p_art_attribute16
160     ,p_art_attribute17               => p_art_attribute17
161     ,p_art_attribute18               => p_art_attribute18
162     ,p_art_attribute19               => p_art_attribute19
163     ,p_art_attribute20               => p_art_attribute20
164     ,p_art_attribute21               => p_art_attribute21
165     ,p_art_attribute22               => p_art_attribute22
166     ,p_art_attribute23               => p_art_attribute23
167     ,p_art_attribute24               => p_art_attribute24
168     ,p_art_attribute25               => p_art_attribute25
169     ,p_art_attribute26               => p_art_attribute26
170     ,p_art_attribute27               => p_art_attribute27
171     ,p_art_attribute28               => p_art_attribute28
172     ,p_art_attribute29               => p_art_attribute29
173     ,p_art_attribute30               => p_art_attribute30
174     ,p_object_version_number         => l_object_version_number
175     ,p_effective_date                => trunc(p_effective_date)
176     );
177   --
178   begin
179     --
180     -- Start of API User Hook for the after hook of create_age_rates
181     --
182     ben_age_rates_bk1.create_age_rates_a
183       (
184        p_age_rt_id                      =>  l_age_rt_id
185       ,p_effective_start_date           =>  l_effective_start_date
186       ,p_effective_end_date             =>  l_effective_end_date
187       ,p_business_group_id              =>  p_business_group_id
188       ,p_vrbl_rt_prfl_id                =>  p_vrbl_rt_prfl_id
189       ,p_age_fctr_id                    =>  p_age_fctr_id
190       ,p_ordr_num                       =>  p_ordr_num
191       ,p_excld_flag                     =>  p_excld_flag
192       ,p_art_attribute_category         =>  p_art_attribute_category
193       ,p_art_attribute1                 =>  p_art_attribute1
194       ,p_art_attribute2                 =>  p_art_attribute2
195       ,p_art_attribute3                 =>  p_art_attribute3
196       ,p_art_attribute4                 =>  p_art_attribute4
197       ,p_art_attribute5                 =>  p_art_attribute5
198       ,p_art_attribute6                 =>  p_art_attribute6
199       ,p_art_attribute7                 =>  p_art_attribute7
200       ,p_art_attribute8                 =>  p_art_attribute8
201       ,p_art_attribute9                 =>  p_art_attribute9
202       ,p_art_attribute10                =>  p_art_attribute10
203       ,p_art_attribute11                =>  p_art_attribute11
204       ,p_art_attribute12                =>  p_art_attribute12
205       ,p_art_attribute13                =>  p_art_attribute13
206       ,p_art_attribute14                =>  p_art_attribute14
207       ,p_art_attribute15                =>  p_art_attribute15
208       ,p_art_attribute16                =>  p_art_attribute16
209       ,p_art_attribute17                =>  p_art_attribute17
210       ,p_art_attribute18                =>  p_art_attribute18
211       ,p_art_attribute19                =>  p_art_attribute19
212       ,p_art_attribute20                =>  p_art_attribute20
213       ,p_art_attribute21                =>  p_art_attribute21
214       ,p_art_attribute22                =>  p_art_attribute22
215       ,p_art_attribute23                =>  p_art_attribute23
216       ,p_art_attribute24                =>  p_art_attribute24
217       ,p_art_attribute25                =>  p_art_attribute25
218       ,p_art_attribute26                =>  p_art_attribute26
219       ,p_art_attribute27                =>  p_art_attribute27
220       ,p_art_attribute28                =>  p_art_attribute28
221       ,p_art_attribute29                =>  p_art_attribute29
222       ,p_art_attribute30                =>  p_art_attribute30
223       ,p_object_version_number          =>  l_object_version_number
224       ,p_effective_date                      => trunc(p_effective_date)
225       );
226   exception
227     when hr_api.cannot_find_prog_unit then
228       hr_api.cannot_find_prog_unit_error
229         (p_module_name => 'CREATE_age_rates'
230         ,p_hook_type   => 'AP'
231         );
232     --
233     -- End of API User Hook for the after hook of create_age_rates
234     --
235   end;
236   --
237   ben_profile_handler.event_handler
238     (p_event                       => 'CREATE',
239      p_base_table                  => 'BEN_VRBL_RT_PRFL_F',
240      p_base_table_column           => 'VRBL_RT_PRFL_ID',
241      p_base_table_column_value     => p_vrbl_rt_prfl_id,
242      p_base_table_reference_column => 'RT_AGE_FLAG',
243      p_reference_table             => 'BEN_AGE_RT_F',
244      p_reference_table_column      => 'VRBL_RT_PRFL_ID');
245   --
246   ben_derivable_rate.derivable_rate_handler
247    (p_event                       =>'CREATE',
248     p_vrbl_rt_prfl_id             =>p_vrbl_rt_prfl_id);
249  --
250   hr_utility.set_location(l_proc, 60);
251   --
252   -- When in validation only mode raise the Validate_Enabled exception
253   --
254   if p_validate then
255     raise hr_api.validate_enabled;
256   end if;
257   --
258   -- Set all output arguments
259   --
260   p_age_rt_id := l_age_rt_id;
261   p_effective_start_date := l_effective_start_date;
262   p_effective_end_date := l_effective_end_date;
263   p_object_version_number := l_object_version_number;
264   --
265   hr_utility.set_location(' Leaving:'||l_proc, 70);
266   --
267 exception
268   --
269   when hr_api.validate_enabled then
270     --
271     -- As the Validate_Enabled exception has been raised
272     -- we must rollback to the savepoint
273     --
274     ROLLBACK TO create_age_rates;
275     --
276     -- Only set output warning arguments
277     -- (Any key or derived arguments must be set to null
278     -- when validation only mode is being used.)
279     --
280     p_age_rt_id := null;
281     p_effective_start_date := null;
282     p_effective_end_date := null;
283     p_object_version_number  := null;
284     hr_utility.set_location(' Leaving:'||l_proc, 80);
285     --
286   when others then
287     --
288     -- A validation or unexpected error has occured
289     --
290     ROLLBACK TO create_age_rates;
291     raise;
292     --
293 end create_age_rates;
294 -- ----------------------------------------------------------------------------
295 -- |------------------------< update_age_rates >--- ------------------|
296 -- ----------------------------------------------------------------------------
297 --
298 procedure update_age_rates
299   (p_validate                       in  boolean   default false
300   ,p_age_rt_id                      in  number
301   ,p_effective_start_date           out nocopy date
302   ,p_effective_end_date             out nocopy date
303   ,p_business_group_id              in  number    default hr_api.g_number
304   ,p_vrbl_rt_prfl_id                in  number    default hr_api.g_number
305   ,p_age_fctr_id                    in  number    default hr_api.g_number
306   ,p_ordr_num                       in  number    default hr_api.g_number
307   ,p_excld_flag                     in  varchar2  default hr_api.g_varchar2
308   ,p_art_attribute_category         in  varchar2  default hr_api.g_varchar2
309   ,p_art_attribute1                 in  varchar2  default hr_api.g_varchar2
310   ,p_art_attribute2                 in  varchar2  default hr_api.g_varchar2
311   ,p_art_attribute3                 in  varchar2  default hr_api.g_varchar2
312   ,p_art_attribute4                 in  varchar2  default hr_api.g_varchar2
313   ,p_art_attribute5                 in  varchar2  default hr_api.g_varchar2
314   ,p_art_attribute6                 in  varchar2  default hr_api.g_varchar2
315   ,p_art_attribute7                 in  varchar2  default hr_api.g_varchar2
316   ,p_art_attribute8                 in  varchar2  default hr_api.g_varchar2
317   ,p_art_attribute9                 in  varchar2  default hr_api.g_varchar2
318   ,p_art_attribute10                in  varchar2  default hr_api.g_varchar2
319   ,p_art_attribute11                in  varchar2  default hr_api.g_varchar2
320   ,p_art_attribute12                in  varchar2  default hr_api.g_varchar2
321   ,p_art_attribute13                in  varchar2  default hr_api.g_varchar2
322   ,p_art_attribute14                in  varchar2  default hr_api.g_varchar2
323   ,p_art_attribute15                in  varchar2  default hr_api.g_varchar2
324   ,p_art_attribute16                in  varchar2  default hr_api.g_varchar2
328   ,p_art_attribute20                in  varchar2  default hr_api.g_varchar2
325   ,p_art_attribute17                in  varchar2  default hr_api.g_varchar2
326   ,p_art_attribute18                in  varchar2  default hr_api.g_varchar2
327   ,p_art_attribute19                in  varchar2  default hr_api.g_varchar2
329   ,p_art_attribute21                in  varchar2  default hr_api.g_varchar2
330   ,p_art_attribute22                in  varchar2  default hr_api.g_varchar2
331   ,p_art_attribute23                in  varchar2  default hr_api.g_varchar2
332   ,p_art_attribute24                in  varchar2  default hr_api.g_varchar2
333   ,p_art_attribute25                in  varchar2  default hr_api.g_varchar2
334   ,p_art_attribute26                in  varchar2  default hr_api.g_varchar2
335   ,p_art_attribute27                in  varchar2  default hr_api.g_varchar2
336   ,p_art_attribute28                in  varchar2  default hr_api.g_varchar2
337   ,p_art_attribute29                in  varchar2  default hr_api.g_varchar2
338   ,p_art_attribute30                in  varchar2  default hr_api.g_varchar2
339   ,p_object_version_number          in out nocopy number
340   ,p_effective_date                 in  date
341   ,p_datetrack_mode                 in  varchar2
342   ) is
343   --
344   -- Declare cursors and local variables
345   --
346   l_proc varchar2(72) := g_package||'update_age_rates';
347   l_object_version_number ben_age_rt_f.object_version_number%TYPE;
348   l_effective_start_date ben_age_rt_f.effective_start_date%TYPE;
349   l_effective_end_date ben_age_rt_f.effective_end_date%TYPE;
350   --
351 begin
352   --
353   hr_utility.set_location('Entering:'|| l_proc, 10);
354   --
355   -- Issue a savepoint if operating in validation only mode
356   --
357   savepoint update_age_rates;
358   --
359   hr_utility.set_location(l_proc, 20);
360   --
361   -- Process Logic
362   --
363   l_object_version_number := p_object_version_number;
364   --
365   begin
366     --
367     -- Start of API User Hook for the before hook of update_age_rates
368     --
369     ben_age_rates_bk2.update_age_rates_b
370       (
371        p_age_rt_id                      =>  p_age_rt_id
372       ,p_business_group_id              =>  p_business_group_id
373       ,p_vrbl_rt_prfl_id                =>  p_vrbl_rt_prfl_id
374       ,p_age_fctr_id                    =>  p_age_fctr_id
375       ,p_ordr_num                       =>  p_ordr_num
376       ,p_excld_flag                     =>  p_excld_flag
377       ,p_art_attribute_category         =>  p_art_attribute_category
378       ,p_art_attribute1                 =>  p_art_attribute1
379       ,p_art_attribute2                 =>  p_art_attribute2
380       ,p_art_attribute3                 =>  p_art_attribute3
381       ,p_art_attribute4                 =>  p_art_attribute4
382       ,p_art_attribute5                 =>  p_art_attribute5
383       ,p_art_attribute6                 =>  p_art_attribute6
384       ,p_art_attribute7                 =>  p_art_attribute7
385       ,p_art_attribute8                 =>  p_art_attribute8
386       ,p_art_attribute9                 =>  p_art_attribute9
387       ,p_art_attribute10                =>  p_art_attribute10
388       ,p_art_attribute11                =>  p_art_attribute11
389       ,p_art_attribute12                =>  p_art_attribute12
390       ,p_art_attribute13                =>  p_art_attribute13
391       ,p_art_attribute14                =>  p_art_attribute14
392       ,p_art_attribute15                =>  p_art_attribute15
393       ,p_art_attribute16                =>  p_art_attribute16
394       ,p_art_attribute17                =>  p_art_attribute17
395       ,p_art_attribute18                =>  p_art_attribute18
396       ,p_art_attribute19                =>  p_art_attribute19
397       ,p_art_attribute20                =>  p_art_attribute20
398       ,p_art_attribute21                =>  p_art_attribute21
399       ,p_art_attribute22                =>  p_art_attribute22
400       ,p_art_attribute23                =>  p_art_attribute23
401       ,p_art_attribute24                =>  p_art_attribute24
402       ,p_art_attribute25                =>  p_art_attribute25
403       ,p_art_attribute26                =>  p_art_attribute26
404       ,p_art_attribute27                =>  p_art_attribute27
405       ,p_art_attribute28                =>  p_art_attribute28
406       ,p_art_attribute29                =>  p_art_attribute29
407       ,p_art_attribute30                =>  p_art_attribute30
408       ,p_object_version_number          =>  p_object_version_number
409     ,p_effective_date                      => trunc(p_effective_date)
410     ,p_datetrack_mode                      => p_datetrack_mode
411       );
412   exception
413     when hr_api.cannot_find_prog_unit then
414       hr_api.cannot_find_prog_unit_error
415         (p_module_name => 'UPDATE_age_rates'
416         ,p_hook_type   => 'BP'
417         );
418     --
419     -- End of API User Hook for the before hook of update_age_rates
420     --
421   end;
422   --
423   ben_art_upd.upd
424     (
425      p_age_rt_id                     => p_age_rt_id
426     ,p_effective_start_date          => l_effective_start_date
427     ,p_effective_end_date            => l_effective_end_date
428     ,p_business_group_id             => p_business_group_id
429     ,p_vrbl_rt_prfl_id               => p_vrbl_rt_prfl_id
430     ,p_age_fctr_id                   => p_age_fctr_id
431     ,p_ordr_num                      => p_ordr_num
432     ,p_excld_flag                    => p_excld_flag
436     ,p_art_attribute3                => p_art_attribute3
433     ,p_art_attribute_category        => p_art_attribute_category
434     ,p_art_attribute1                => p_art_attribute1
435     ,p_art_attribute2                => p_art_attribute2
437     ,p_art_attribute4                => p_art_attribute4
438     ,p_art_attribute5                => p_art_attribute5
439     ,p_art_attribute6                => p_art_attribute6
440     ,p_art_attribute7                => p_art_attribute7
441     ,p_art_attribute8                => p_art_attribute8
442     ,p_art_attribute9                => p_art_attribute9
443     ,p_art_attribute10               => p_art_attribute10
444     ,p_art_attribute11               => p_art_attribute11
445     ,p_art_attribute12               => p_art_attribute12
446     ,p_art_attribute13               => p_art_attribute13
447     ,p_art_attribute14               => p_art_attribute14
448     ,p_art_attribute15               => p_art_attribute15
449     ,p_art_attribute16               => p_art_attribute16
450     ,p_art_attribute17               => p_art_attribute17
451     ,p_art_attribute18               => p_art_attribute18
452     ,p_art_attribute19               => p_art_attribute19
453     ,p_art_attribute20               => p_art_attribute20
454     ,p_art_attribute21               => p_art_attribute21
455     ,p_art_attribute22               => p_art_attribute22
456     ,p_art_attribute23               => p_art_attribute23
457     ,p_art_attribute24               => p_art_attribute24
458     ,p_art_attribute25               => p_art_attribute25
459     ,p_art_attribute26               => p_art_attribute26
460     ,p_art_attribute27               => p_art_attribute27
461     ,p_art_attribute28               => p_art_attribute28
462     ,p_art_attribute29               => p_art_attribute29
463     ,p_art_attribute30               => p_art_attribute30
464     ,p_object_version_number         => l_object_version_number
465     ,p_effective_date                => trunc(p_effective_date)
466     ,p_datetrack_mode                => p_datetrack_mode
467     );
468   --
469   begin
470     --
471     -- Start of API User Hook for the after hook of update_age_rates
472     --
473     ben_age_rates_bk2.update_age_rates_a
474       (
475        p_age_rt_id                      =>  p_age_rt_id
476       ,p_effective_start_date           =>  l_effective_start_date
477       ,p_effective_end_date             =>  l_effective_end_date
478       ,p_business_group_id              =>  p_business_group_id
479       ,p_vrbl_rt_prfl_id                =>  p_vrbl_rt_prfl_id
480       ,p_age_fctr_id                    =>  p_age_fctr_id
481       ,p_ordr_num                       =>  p_ordr_num
482       ,p_excld_flag                     =>  p_excld_flag
483       ,p_art_attribute_category         =>  p_art_attribute_category
484       ,p_art_attribute1                 =>  p_art_attribute1
485       ,p_art_attribute2                 =>  p_art_attribute2
486       ,p_art_attribute3                 =>  p_art_attribute3
487       ,p_art_attribute4                 =>  p_art_attribute4
488       ,p_art_attribute5                 =>  p_art_attribute5
489       ,p_art_attribute6                 =>  p_art_attribute6
490       ,p_art_attribute7                 =>  p_art_attribute7
491       ,p_art_attribute8                 =>  p_art_attribute8
492       ,p_art_attribute9                 =>  p_art_attribute9
493       ,p_art_attribute10                =>  p_art_attribute10
494       ,p_art_attribute11                =>  p_art_attribute11
495       ,p_art_attribute12                =>  p_art_attribute12
496       ,p_art_attribute13                =>  p_art_attribute13
497       ,p_art_attribute14                =>  p_art_attribute14
498       ,p_art_attribute15                =>  p_art_attribute15
499       ,p_art_attribute16                =>  p_art_attribute16
500       ,p_art_attribute17                =>  p_art_attribute17
501       ,p_art_attribute18                =>  p_art_attribute18
502       ,p_art_attribute19                =>  p_art_attribute19
503       ,p_art_attribute20                =>  p_art_attribute20
504       ,p_art_attribute21                =>  p_art_attribute21
505       ,p_art_attribute22                =>  p_art_attribute22
506       ,p_art_attribute23                =>  p_art_attribute23
507       ,p_art_attribute24                =>  p_art_attribute24
508       ,p_art_attribute25                =>  p_art_attribute25
509       ,p_art_attribute26                =>  p_art_attribute26
510       ,p_art_attribute27                =>  p_art_attribute27
511       ,p_art_attribute28                =>  p_art_attribute28
512       ,p_art_attribute29                =>  p_art_attribute29
513       ,p_art_attribute30                =>  p_art_attribute30
514       ,p_object_version_number          =>  l_object_version_number
515       ,p_effective_date                     => trunc(p_effective_date)
516       ,p_datetrack_mode                     => p_datetrack_mode
517       );
518   exception
519     when hr_api.cannot_find_prog_unit then
520       hr_api.cannot_find_prog_unit_error
521         (p_module_name => 'UPDATE_age_rates'
522         ,p_hook_type   => 'AP'
523         );
524     --
525     -- End of API User Hook for the after hook of update_age_rates
526     --
527   end;
528   --
529   hr_utility.set_location(l_proc, 60);
530   --
531   -- When in validation only mode raise the Validate_Enabled exception
532   --
533   if p_validate then
534     raise hr_api.validate_enabled;
535   end if;
536   --
537   -- Set all output arguments
538   --
542   --
539   p_object_version_number := l_object_version_number;
540   p_effective_start_date := l_effective_start_date;
541   p_effective_end_date := l_effective_end_date;
543   hr_utility.set_location(' Leaving:'||l_proc, 70);
544   --
545 exception
546   --
547   when hr_api.validate_enabled then
548     --
549     -- As the Validate_Enabled exception has been raised
550     -- we must rollback to the savepoint
551     --
552     ROLLBACK TO update_age_rates;
553     --
554     -- Only set output warning arguments
555     -- (Any key or derived arguments must be set to null
556     -- when validation only mode is being used.)
557     --
558     p_effective_start_date := null;
559     p_effective_end_date := null;
560     hr_utility.set_location(' Leaving:'||l_proc, 80);
561     --
562   when others then
563     --
564     -- A validation or unexpected error has occured
565     --
566     ROLLBACK TO update_age_rates;
567     /* Inserted for nocopy changes */
568     p_object_version_number := l_object_version_number;
569     p_effective_start_date := null;
570     p_effective_end_date := null;
571     raise;
572     --
573 end update_age_rates;
574 -- ----------------------------------------------------------------------------
575 -- |------------------------< delete_age_rates >----------------------|
576 -- ----------------------------------------------------------------------------
577 --
578 procedure delete_age_rates
579   (p_validate                       in  boolean  default false
580   ,p_age_rt_id                      in  number
581   ,p_effective_start_date           out nocopy date
582   ,p_effective_end_date             out nocopy date
583   ,p_object_version_number          in out nocopy number
584   ,p_effective_date                 in  date
585   ,p_datetrack_mode                 in  varchar2
586   ) is
587   --
588   -- Declare cursors and local variables
589   --
590   l_proc varchar2(72) := g_package||'update_age_rates';
591   l_object_version_number ben_age_rt_f.object_version_number%TYPE;
592   l_effective_start_date ben_age_rt_f.effective_start_date%TYPE;
593   l_effective_end_date ben_age_rt_f.effective_end_date%TYPE;
594   --
595 begin
596   --
597   hr_utility.set_location('Entering:'|| l_proc, 10);
598   --
599   -- Issue a savepoint if operating in validation only mode
600   --
601   savepoint delete_age_rates;
602   --
603   hr_utility.set_location(l_proc, 20);
604   --
605   -- Process Logic
606   --
607   l_object_version_number := p_object_version_number;
608   --
609   --
610   begin
611     --
612     -- Start of API User Hook for the before hook of delete_age_rates
613     --
614     ben_age_rates_bk3.delete_age_rates_b
615       (
616        p_age_rt_id                      =>  p_age_rt_id
617       ,p_object_version_number          =>  p_object_version_number
618     ,p_effective_date                      => trunc(p_effective_date)
619     ,p_datetrack_mode                      => p_datetrack_mode
620       );
621   exception
622     when hr_api.cannot_find_prog_unit then
623       hr_api.cannot_find_prog_unit_error
624         (p_module_name => 'DELETE_age_rates'
625         ,p_hook_type   => 'BP'
626         );
627     --
628     -- End of API User Hook for the before hook of delete_age_rates
629     --
630   end;
631   --
632   ben_art_del.del
633     (
634      p_age_rt_id                     => p_age_rt_id
635     ,p_effective_start_date          => l_effective_start_date
636     ,p_effective_end_date            => l_effective_end_date
637     ,p_object_version_number         => l_object_version_number
638     ,p_effective_date                => p_effective_date
639     ,p_datetrack_mode                => p_datetrack_mode
640     );
641   --
642   begin
643     --
644     -- Start of API User Hook for the after hook of delete_age_rates
645     --
646     ben_age_rates_bk3.delete_age_rates_a
647       (
648        p_age_rt_id                      =>  p_age_rt_id
649       ,p_effective_start_date           =>  l_effective_start_date
650       ,p_effective_end_date             =>  l_effective_end_date
651       ,p_object_version_number          =>  l_object_version_number
652     ,p_effective_date                      => trunc(p_effective_date)
653     ,p_datetrack_mode                      => p_datetrack_mode
654       );
655   exception
656     when hr_api.cannot_find_prog_unit then
657       hr_api.cannot_find_prog_unit_error
658         (p_module_name => 'DELETE_age_rates'
659         ,p_hook_type   => 'AP'
660         );
661     --
662     -- End of API User Hook for the after hook of delete_age_rates
663     --
664   end;
665   --
666   ben_profile_handler.event_handler
667     (p_event                       => 'DELETE',
668      p_base_table                  => 'BEN_VRBL_RT_PRFL_F',
669      p_base_table_column           => 'VRBL_RT_PRFL_ID',
670      p_base_table_column_value     => ben_art_shd.g_old_rec.vrbl_rt_prfl_id,
671      p_base_table_reference_column => 'RT_AGE_FLAG',
672      p_reference_table             => 'BEN_AGE_RT_F',
673      p_reference_table_column      => 'VRBL_RT_PRFL_ID');
674   --
675   ben_derivable_rate.derivable_rate_handler
676    (p_event                       =>'DELETE',
677     p_vrbl_rt_prfl_id             =>ben_art_shd.g_old_rec.vrbl_rt_prfl_id);
681   --
678   hr_utility.set_location(l_proc, 60);
679   --
680   -- When in validation only mode raise the Validate_Enabled exception
682   if p_validate then
683     raise hr_api.validate_enabled;
684   end if;
685   --
686   hr_utility.set_location(' Leaving:'||l_proc, 70);
687   --
688 exception
689   --
690   when hr_api.validate_enabled then
691     --
692     -- As the Validate_Enabled exception has been raised
693     -- we must rollback to the savepoint
694     --
695     ROLLBACK TO delete_age_rates;
696     --
697     -- Only set output warning arguments
698     -- (Any key or derived arguments must be set to null
699     -- when validation only mode is being used.)
700     --
701     --
702   when others then
703     --
704     -- A validation or unexpected error has occured
705     --
706     ROLLBACK TO delete_age_rates;
707     /* Inserted for nocopy changes */
708     p_object_version_number := l_object_version_number;
709     p_effective_start_date := null;
710     p_effective_end_date := null;
711     raise;
712     --
713 end delete_age_rates;
714 --
715 -- ----------------------------------------------------------------------------
716 -- |-------------------------------< lck >------------------------------------|
717 -- ----------------------------------------------------------------------------
718 --
719 procedure lck
720   (
721    p_age_rt_id                   in     number
722   ,p_object_version_number          in     number
723   ,p_effective_date                 in     date
724   ,p_datetrack_mode                 in     varchar2
725   ,p_validation_start_date          out nocopy    date
726   ,p_validation_end_date            out nocopy    date
727   ) is
728   --
729   --
730   -- Declare cursors and local variables
731   --
732   l_proc varchar2(72) := g_package||'lck';
733   l_validation_start_date date;
734   l_validation_end_date date;
735   --
736 begin
737   --
738   hr_utility.set_location('Entering:'|| l_proc, 10);
739   --
740   ben_art_shd.lck
741     (
742       p_age_rt_id                 => p_age_rt_id
743      ,p_validation_start_date      => l_validation_start_date
744      ,p_validation_end_date        => l_validation_end_date
748     );
745      ,p_object_version_number      => p_object_version_number
746      ,p_effective_date             => p_effective_date
747      ,p_datetrack_mode             => p_datetrack_mode
749   --
750   hr_utility.set_location(' Leaving:'||l_proc, 70);
751   --
752 end lck;
753 --
754 end ben_age_rates_api;