]> git.evergreen-ils.org Git - working/Evergreen.git/blob - Open-ILS/src/sql/Pg/upgrade/XXXX.function.allow_inactive_barcode_retrieve.sql
LP#1154235 Allow inactive patron barcode to be loaded
[working/Evergreen.git] / Open-ILS / src / sql / Pg / upgrade / XXXX.function.allow_inactive_barcode_retrieve.sql
1 CREATE OR REPLACE FUNCTION evergreen.get_barcodes(select_ou INT, type TEXT, in_barcode TEXT) RETURNS SETOF evergreen.barcode_set AS $$
2 DECLARE
3     cur_barcode TEXT;
4     barcode_len INT;
5     completion_len  INT;
6     asset_barcodes  TEXT[];
7     actor_barcodes  TEXT[];
8     do_asset    BOOL = false;
9     do_serial   BOOL = false;
10     do_booking  BOOL = false;
11     do_actor    BOOL = false;
12     completion_set  config.barcode_completion%ROWTYPE;
13 BEGIN
14
15     IF position('asset' in type) > 0 THEN
16         do_asset = true;
17     END IF;
18     IF position('serial' in type) > 0 THEN
19         do_serial = true;
20     END IF;
21     IF position('booking' in type) > 0 THEN
22         do_booking = true;
23     END IF;
24     IF do_asset OR do_serial OR do_booking THEN
25         asset_barcodes = asset_barcodes || in_barcode;
26     END IF;
27     IF position('actor' in type) > 0 THEN
28         do_actor = true;
29         actor_barcodes = actor_barcodes || in_barcode;
30     END IF;
31
32     barcode_len := length(in_barcode);
33
34     FOR completion_set IN
35       SELECT * FROM config.barcode_completion
36         WHERE active
37         AND org_unit IN (SELECT aou.id FROM actor.org_unit_ancestors(select_ou) aou)
38         LOOP
39         IF completion_set.prefix IS NULL THEN
40             completion_set.prefix := '';
41         END IF;
42         IF completion_set.suffix IS NULL THEN
43             completion_set.suffix := '';
44         END IF;
45         IF completion_set.length = 0 OR completion_set.padding IS NULL OR length(completion_set.padding) = 0 THEN
46             cur_barcode = completion_set.prefix || in_barcode || completion_set.suffix;
47         ELSE
48             completion_len = completion_set.length - length(completion_set.prefix) - length(completion_set.suffix);
49             IF completion_len >= barcode_len THEN
50                 IF completion_set.padding_end THEN
51                     cur_barcode = rpad(in_barcode, completion_len, completion_set.padding);
52                 ELSE
53                     cur_barcode = lpad(in_barcode, completion_len, completion_set.padding);
54                 END IF;
55                 cur_barcode = completion_set.prefix || cur_barcode || completion_set.suffix;
56             END IF;
57         END IF;
58         IF completion_set.actor THEN
59             actor_barcodes = actor_barcodes || cur_barcode;
60         END IF;
61         IF completion_set.asset THEN
62             asset_barcodes = asset_barcodes || cur_barcode;
63         END IF;
64     END LOOP;
65
66     IF do_asset AND do_serial THEN
67         RETURN QUERY SELECT 'asset'::TEXT, id, barcode FROM ONLY asset.copy WHERE barcode = ANY(asset_barcodes) AND deleted = false;
68         RETURN QUERY SELECT 'serial'::TEXT, id, barcode FROM serial.unit WHERE barcode = ANY(asset_barcodes) AND deleted = false;
69     ELSIF do_asset THEN
70         RETURN QUERY SELECT 'asset'::TEXT, id, barcode FROM asset.copy WHERE barcode = ANY(asset_barcodes) AND deleted = false;
71     ELSIF do_serial THEN
72         RETURN QUERY SELECT 'serial'::TEXT, id, barcode FROM serial.unit WHERE barcode = ANY(asset_barcodes) AND deleted = false;
73     END IF;
74     IF do_booking THEN
75         RETURN QUERY SELECT 'booking'::TEXT, id::BIGINT, barcode FROM booking.resource WHERE barcode = ANY(asset_barcodes);
76     END IF;
77     IF do_actor THEN
78         RETURN QUERY SELECT 'actor'::TEXT, c.usr::BIGINT, c.barcode FROM actor.card c JOIN actor.usr u ON c.usr = u.id WHERE
79             ((c.barcode = ANY(actor_barcodes) AND c.active) OR c.barcode = in_barcode) AND NOT u.deleted ORDER BY usr;
80     END IF;
81     RETURN;
82 END;
83 $$ LANGUAGE plpgsql;