DELIMITER $$
CREATE OR REPLACE DEFINER=`vn`@`localhost` PROCEDURE `vn`.`ticket_setNextState`(
	vSelf INT
)
BEGIN
/**
 * Cambia el estado del ticket al siguiente estado segĂșn la tabla state.
 *
 * @param vSelf Id ticket
 */
	DECLARE vStateFk INT;
	DECLARE vNewStateFk INT;

	DECLARE EXIT HANDLER FOR SQLEXCEPTION
	BEGIN
		RESIGNAL;
	END;

	SELECT stateFk INTO vStateFk
		FROM ticketState
		WHERE ticketFk = vSelf;

	SELECT nextStateFk INTO vNewStateFk
		FROM state
		WHERE id = vStateFk;

	IF vNewStateFk IS NULL THEN
		CALL util.throw('The ticket not have next state');
	END IF;

	INSERT INTO ticketTracking(stateFk, ticketFk, userFk)
		VALUES (vNewStateFk, vSelf, account.myUser_getId());
END$$
DELIMITER ;