3
CREATE OR REPLACE FUNCTION valid_url_name(name text) RETURNS boolean AS
6
RETURN name ~ E'^[a-z0-9][a-z0-9_\+\.\-]*$';
10
CREATE OR REPLACE FUNCTION valid_login_name(name text) RETURNS boolean AS
13
RETURN name ~ E'^[a-z0-9][a-z0-9@_\+\.\-]*$';
15
$$ LANGUAGE 'plpgsql';
17
ALTER TABLE login ADD CONSTRAINT login_login_check CHECK (valid_login_name(login));
18
ALTER TABLE subject ADD CONSTRAINT subject_subj_short_name_check CHECK (valid_url_name(subj_short_name));
19
ALTER TABLE semester ADD CONSTRAINT semester_year_check CHECK (valid_url_name(year));
20
ALTER TABLE semester ADD CONSTRAINT semester_semester_check CHECK (valid_url_name(semester));
21
ALTER TABLE project ADD CONSTRAINT project_short_name_check CHECK (valid_url_name(short_name));
22
ALTER TABLE project_group ADD CONSTRAINT project_group_groupnm_check CHECK (valid_url_name(groupnm));
23
ALTER TABLE exercise ADD CONSTRAINT exercise_identifier_check CHECK (valid_url_name(identifier));
24
ALTER TABLE worksheet ADD CONSTRAINT worksheet_identifier_check CHECK (valid_url_name(identifier));