schemas/_regproc.postgres.sql
author Sylvain Thénault <sylvain.thenault@logilab.fr>
Thu, 03 Dec 2009 09:55:18 +0100 (2009-12-03)
branchstable
changeset 3978 2c95e3033f64
parent 3928 2ced335a9b55
child 4126 2eb47c1efee1
permissions -rw-r--r--
finish yesterday work on rql constraints: * Fix inheritance pb: there are some places where we filter constraints according to the class hierarchy, so rql unique constraint should'nt be neither a RQLContraint nor a RQLVocabularyConstraint subclass. Added test in unittest_schema reflecting this. * So now we have to get explicitly RQLUniqueConstraint where desired (eg in server/hooks.py) * Update i18ncubicweb command to include constraint types in generated pot file (this should have been there for a while...) * Update unittest_schemaserial which has been broken when serializing format for rql constraints has changed
/* -*- sql -*- 

   postgres specific registered procedures, 
   require the plpgsql language installed 

*/

CREATE FUNCTION comma_join (anyarray) RETURNS text AS $$
    SELECT array_to_string($1, ', ')
$$ LANGUAGE SQL;;

CREATE AGGREGATE group_concat (
  basetype = anyelement,
  sfunc = array_append,
  stype = anyarray,
  finalfunc = comma_join,
  initcond = '{}'
);;



CREATE FUNCTION limit_size (fulltext text, format text, maxsize integer) RETURNS text AS $$
DECLARE
    plaintext text;
BEGIN
    IF char_length(fulltext) < maxsize THEN
       RETURN fulltext;
    END IF;
    IF format = 'text/html' OR format = 'text/xhtml' OR format = 'text/xml' THEN
       plaintext := regexp_replace(fulltext, '<[\\w/][^>]+>', '', 'g');
    ELSE
       plaintext := fulltext;
    END IF;
    IF char_length(plaintext) < maxsize THEN
       RETURN plaintext;
    ELSE
       RETURN substring(plaintext from 1 for maxsize) || '...';
    END IF;
END
$$ LANGUAGE plpgsql;;


CREATE FUNCTION text_limit_size (fulltext text, maxsize integer) RETURNS text AS $$
BEGIN
    RETURN limit_size(fulltext, 'text/plain', maxsize);
END
$$ LANGUAGE plpgsql;;