CREATE OR REPLACE FUNCTION user_password() RETURNS trigger
AS $_X$
DECLARE
+ old_password TEXT;
BEGIN
- IF COALESCE(NEW.password <> OLD.password,TRUE) AND
+ IF TG_OP = 'UPDATE'
+ THEN
+ old_password := OLD.password;
+ END IF;
+ IF COALESCE(NEW.password <> old_password,TRUE) AND
NOT NEW.password SIMILAR TO '$2a$\d+$[a-zA-Z0-9./]+'
THEN
NEW.password := crypt(NEW.password,gen_salt('bf',10));
uid integer NOT NULL,
username citext NOT NULL,
pid integer,
- password text NOT NULL,
+ password text,
attack_points numeric(3,0) DEFAULT 0 NOT NULL,
defense_points numeric(4,1) DEFAULT 0 NOT NULL,
scan_points numeric(5,0) DEFAULT 0 NOT NULL,