-- Deploy camper:order_campsite_carousel to pg -- requires: roles -- requires: campsite_carousel -- requires: campsite begin; set search_path to camper, public; create or replace function order_campsite_carousel(label text, company_id integer, positions integer[]) returns void as $$ update campsite_carousel set position = cast(temp.position as integer) from unnest(positions) with ordinality as temp(media_id, position) join campsite on campsite.label = order_campsite_carousel.label and campsite.company_id = order_campsite_carousel.company_id where campsite_carousel.campsite_id = campsite.campsite_id and campsite_carousel.media_id = temp.media_id ; $$ language sql ; revoke execute on function order_campsite_carousel(text, integer, integer[]) from public; grant execute on function order_campsite_carousel(text, integer, integer[]) to admin; commit;