-- -- Copyright (C) 2001, 2002 MIT -- -- This file is part of dotLRN. -- -- dotLRN is free software; you can redistribute it and/or modify it under the -- terms of the GNU General Public License as published by the Free Software -- Foundation; either version 2 of the License, or (at your option) any later -- version. -- -- dotLRN is distributed in the hope that it will be useful, but WITHOUT ANY -- WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS -- FOR A PARTICULAR PURPOSE. See the GNU General Public License for more -- details. -- -- -- create portal datasource package -- -- @author arjun@openforce.net -- @author yon@openforce.net -- @creation-date 2001-10-01 -- @version $Id: datasource-package-create.sql,v 1.2 2003/09/25 02:12:16 vinodk Exp $ -- select define_function_args('portal_datasource__new', 'name,shadeable_p;t,hideable_p;t,description'); create or replace function portal_datasource__new (varchar, varchar, varchar, varchar) returns integer as ' declare p_name alias for $1; p_shadeable_p alias for $2; p_hideable_p alias for $3; p_description alias for $4; v_datasource_id portal_datasources.datasource_id%TYPE; begin v_datasource_id := nextval(''portal_seq''); insert into portal_datasources (datasource_id, name, shadeable_p, hideable_p, description) values (v_datasource_id, p_name, p_shadeable_p, p_hideable_p, p_description); return v_datasource_id; end;' language 'plpgsql'; create or replace function portal_datasource__new (varchar, varchar) returns integer as ' declare p_name alias for $1; p_description alias for $2; v_datasource_id portal_datasources.datasource_id%TYPE; begin v_datasource_id := portal_datasource__new( p_name, ''t'', ''t'', p_description ); return v_datasource_id; end;' language 'plpgsql'; select define_function_args('portal_datasource__delete', 'datasource_id'); create or replace function portal_datasource__delete (integer) returns integer as ' declare p_datasource_id alias for $1; begin delete from portal_datasources where datasource_id = :p_datasource_id; return 0; end;' language 'plpgsql'; select define_function_args('portal_datasource__set_def_param', 'datasource_id,config_required_p,configured_p,key,value'); create or replace function portal_datasource__set_def_param (integer,varchar,varchar,varchar,varchar) returns integer as ' declare p_datasource_id alias for $1; p_config_required_p alias for $2; p_configured_p alias for $3; p_key alias for $4; p_value alias for $5; begin insert into portal_datasource_parameters (parameter_id, datasource_id, config_required_p, configured_p, key, value) values (nextval(''portal_seq''), p_datasource_id, p_config_required_p, p_configured_p, p_key, p_value); return 0; end;' language 'plpgsql';