USE demo; SELECT CONCAT('WARNING: Table ', TABLE_SCHEMA, '.', TABLE_NAME, ' already exists.') AS msg_warning FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = 'demo' AND TABLE_NAME = 'PH_Apply_Founding_Partner_Form' ; CREATE TABLE IF NOT EXISTS demo.PH_Apply_Founding_Partner_Form ( id_apply_founding_partner_form INT NOT NULL AUTO_INCREMENT PRIMARY KEY , name_contact VARCHAR(255) NOT NULL , email VARCHAR(255) NOT NULL , phone_number VARCHAR(255) NOT NULL , name_company VARCHAR(255) NOT NULL , website VARCHAR(1000) NOT NULL , dog_count INT NOT NULL , id_years_of_experience INT NOT NULL , ids_speciality VARCHAR(255) NOT NULL , ids_existing_system VARCHAR(255) NOT NULL , id_existing_challenges INT NOT NULL , id_existing_time_sink_weekly INT NOT NULL , id_commitment_frequency INT NOT NULL -- , most_valuable_features TEXT NOT NULL , notes TEXT , active BIT NOT NULL DEFAULT 1 , created_on DATETIME , id_user_created_by INT , CONSTRAINT FK_PH_Apply_Founding_Partner_Form_id_user_created_by FOREIGN KEY (id_user_created_by) REFERENCES demo.DOG_User(id_user) , id_change_set INT , CONSTRAINT FK_PH_Apply_Founding_Partner_Form_id_change_set FOREIGN KEY (id_change_set) REFERENCES demo.PH_Contact_Form_Change_Set(id_change_set) ); USE demo; SELECT CONCAT('WARNING: Table ', TABLE_SCHEMA, '.', TABLE_NAME, ' already exists.') AS msg_warning FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = 'demo' AND TABLE_NAME = 'PH_Apply_Founding_Partner_Form_Audit' ; CREATE TABLE IF NOT EXISTS demo.PH_Apply_Founding_Partner_Form_Audit ( id_audit INT NOT NULL AUTO_INCREMENT PRIMARY KEY , id_apply_founding_partner_form INT NOT NULL , CONSTRAINT FK_PH_AFP_Form_Audit_id_apply_founding_partner_form FOREIGN KEY (id_apply_founding_partner_form) REFERENCES demo.PH_Apply_Founding_Partner_Form(id_apply_founding_partner_form) , name_field VARCHAR(50) NOT NULL , value_prev TEXT , value_new TEXT , id_change_set INT NOT NULL , CONSTRAINT FK_PH_AFP_Form_Audit_id_change_set FOREIGN KEY (id_change_set) REFERENCES demo.PH_Contact_Form_Change_Set(id_change_set) ); USE demo; SELECT CONCAT('WARNING: Table ', TABLE_SCHEMA, '.', TABLE_NAME, ' already exists.') AS msg_warning FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = 'demo' AND TABLE_NAME = 'PH_Apply_Founding_Partner_Form_Temp' ; CREATE TABLE IF NOT EXISTS demo.PH_Apply_Founding_Partner_Form_Temp ( id_temp INT NOT NULL AUTO_INCREMENT PRIMARY KEY , id_apply_founding_partner_form INT NOT NULL , name_contact VARCHAR(255) , email VARCHAR(255) , phone_number VARCHAR(255) , name_company VARCHAR(255) , website VARCHAR(1000) , dog_count INT , id_years_of_experience INT , ids_speciality VARCHAR(255) , ids_existing_system VARCHAR(255) , id_existing_challenges INT , id_existing_time_sink_weekly INT , id_commitment_frequency INT , most_valuable_features TEXT , notes TEXT , active BIT , guid BINARY(36) ); USE demo; DROP TRIGGER IF EXISTS demo.before_insert_PH_Apply_Founding_Partner_Form; DROP TRIGGER IF EXISTS demo.before_update_PH_Apply_Founding_Partner_Form; DELIMITER // CREATE TRIGGER demo.before_insert_PH_Apply_Founding_Partner_Form BEFORE INSERT ON demo.PH_Apply_Founding_Partner_Form FOR EACH ROW BEGIN SET NEW.created_on := IFNULL(NEW.created_on, NOW()); END // DELIMITER ; DELIMITER // CREATE TRIGGER demo.before_update_PH_Apply_Founding_Partner_Form BEFORE UPDATE ON demo.PH_Apply_Founding_Partner_Form FOR EACH ROW BEGIN IF OLD.id_change_set <=> NEW.id_change_set THEN SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'New Change Set ID must be provided.'; END IF; INSERT INTO demo.PH_Apply_Founding_Partner_Form_Audit ( id_Apply_Founding_Partner_Form, name_field, value_prev, value_new, id_change_set ) -- Changed name_contact SELECT NEW.id_Apply_Founding_Partner_Form, 'name_contact', OLD.name_contact, NEW.name_contact, NEW.id_change_set WHERE NOT OLD.name_contact <=> NEW.name_contact UNION -- Changed email SELECT NEW.id_Apply_Founding_Partner_Form, 'email', OLD.email, NEW.email, NEW.id_change_set WHERE NOT OLD.email <=> NEW.email UNION -- Changed phone_number SELECT NEW.id_Apply_Founding_Partner_Form, 'phone_number', OLD.phone_number, NEW.phone_number, NEW.id_change_set WHERE NOT OLD.phone_number <=> NEW.phone_number UNION -- Changed name_company SELECT NEW.id_Apply_Founding_Partner_Form, 'name_company', OLD.name_company, NEW.name_company, NEW.id_change_set WHERE NOT OLD.name_company <=> NEW.name_company UNION -- Changed website SELECT NEW.id_Apply_Founding_Partner_Form, 'website', OLD.website, NEW.website, NEW.id_change_set WHERE NOT OLD.website <=> NEW.website UNION -- Changed dog_count SELECT NEW.id_Apply_Founding_Partner_Form, 'dog_count', CONVERT(OLD.dog_count, CHAR), CONVERT(NEW.dog_count, CHAR), NEW.id_change_set WHERE NOT (OLD.dog_count <=> NEW.dog_count) UNION -- Changed id_years_of_experience SELECT NEW.id_Apply_Founding_Partner_Form, 'id_years_of_experience', CONVERT(OLD.id_years_of_experience, CHAR), CONVERT(NEW.id_years_of_experience, CHAR), NEW.id_change_set WHERE NOT (OLD.id_years_of_experience <=> NEW.id_years_of_experience) UNION -- Changed ids_speciality SELECT NEW.id_Apply_Founding_Partner_Form, 'ids_speciality', OLD.ids_speciality, NEW.ids_speciality, NEW.id_change_set WHERE NOT OLD.ids_speciality <=> NEW.ids_speciality UNION -- Changed ids_existing_system SELECT NEW.id_Apply_Founding_Partner_Form, 'ids_existing_system', OLD.ids_existing_system, NEW.ids_existing_system, NEW.id_change_set WHERE NOT OLD.ids_existing_system <=> NEW.ids_existing_system UNION -- Changed id_existing_challenges SELECT NEW.id_Apply_Founding_Partner_Form, 'id_existing_challenges', CONVERT(OLD.id_existing_challenges, CHAR), CONVERT(NEW.id_existing_challenges, CHAR), NEW.id_change_set WHERE NOT (OLD.id_existing_challenges <=> NEW.id_existing_challenges) UNION -- Changed id_existing_time_sink_weekly SELECT NEW.id_Apply_Founding_Partner_Form, 'id_existing_time_sink_weekly', CONVERT(OLD.id_existing_time_sink_weekly, CHAR), CONVERT(NEW.id_existing_time_sink_weekly, CHAR), NEW.id_change_set WHERE NOT (OLD.id_existing_time_sink_weekly <=> NEW.id_existing_time_sink_weekly) UNION -- Changed id_commitment_frequency SELECT NEW.id_Apply_Founding_Partner_Form, 'id_commitment_frequency', CONVERT(OLD.id_commitment_frequency, CHAR), CONVERT(NEW.id_commitment_frequency, CHAR), NEW.id_change_set WHERE NOT (OLD.id_commitment_frequency <=> NEW.id_commitment_frequency) UNION -- Changed most_valuable_features SELECT NEW.id_Apply_Founding_Partner_Form, 'most_valuable_features', OLD.most_valuable_features, NEW.most_valuable_features, NEW.id_change_set WHERE NOT OLD.most_valuable_features <=> NEW.most_valuable_features UNION -- Changed notes SELECT NEW.id_Apply_Founding_Partner_Form, 'notes', OLD.notes, NEW.notes, NEW.id_change_set WHERE NOT OLD.notes <=> NEW.notes UNION -- Changed active SELECT NEW.id_Apply_Founding_Partner_Form, 'active', CONVERT(CONVERT(OLD.active, SIGNED), CHAR), CONVERT(CONVERT(NEW.active, SIGNED), CHAR), NEW.id_change_set WHERE NOT (OLD.active <=> NEW.active) ; END // DELIMITER ; USE demo; DROP PROCEDURE IF EXISTS demo.p_ph_save_apply_founding_partner_form; DELIMITER // CREATE PROCEDURE demo.p_ph_save_apply_founding_partner_form ( IN a_comment VARCHAR(500), IN a_guid BINARY(36), IN a_id_user INT, IN a_debug BIT ) BEGIN DECLARE v_code_type_error_bad_data VARCHAR(100); DECLARE v_id_access_level_view INT; DECLARE v_id_access_level_edit INT; DECLARE v_id_change_set INT; DECLARE v_id_permission_apply_founding_partner_form_admin INT; DECLARE v_id_permission_apply_founding_partner_form_new INT; DECLARE v_id_type_error_bad_data INT; DECLARE v_time_start TIMESTAMP(6); DECLARE v_can_admin BIT; DECLARE v_can_create BIT; DECLARE exit handler for SQLEXCEPTION BEGIN GET DIAGNOSTICS CONDITION 1 @sqlstate = RETURNED_SQLSTATE , @errno = MYSQL_ERRNO , @text = MESSAGE_TEXT ; ROLLBACK; CREATE TEMPORARY TABLE IF NOT EXISTS tmp_Msg_Error ( display_order INT NOT NULL PRIMARY KEY AUTO_INCREMENT , id_type INT , code VARCHAR(50) NOT NULL , msg VARCHAR(4000) NOT NULL ); INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT MET.id_type , @errno , @text FROM demo.CORE_Msg_Error_Type MET WHERE MET.code = 'MYSQL_ERROR' ; SELECT * FROM tmp_Msg_Error; DROP TABLE IF EXISTS tmp_Msg_Error ; END; SET v_time_start := CURRENT_TIMESTAMP(6); SET v_code_type_error_bad_data := 'BAD_DATA'; SET v_id_type_error_bad_data := (SELECT id_type FROM demo.CORE_Msg_Error_Type WHERE code = v_code_type_error_bad_data LIMIT 1); SET v_id_permission_apply_founding_partner_form_admin := (SELECT id_permission FROM demo.DOG_Permission P WHERE P.code = 'CONTACT_FORM_ADMIN' LIMIT 1); SET v_id_permission_apply_founding_partner_form_new := (SELECT id_permission FROM demo.DOG_Permission P WHERE P.code = 'CONTACT_FORM_CREATE' LIMIT 1); CALL demo.p_core_validate_guid ( a_guid ); DROP TABLE IF EXISTS tmp_Apply_Founding_Partner_Form; CREATE TEMPORARY TABLE tmp_Apply_Founding_Partner_Form ( id_apply_founding_partner_form INT NOT NULL , name_contact VARCHAR(255) , email VARCHAR(255) , phone_number VARCHAR(255) , name_company VARCHAR(255) , website VARCHAR(1000) , dog_count INT , id_years_of_experience INT , ids_speciality VARCHAR(255) , ids_existing_system VARCHAR(255) , id_existing_challenges INT , id_existing_time_sink_weekly INT , id_commitment_frequency INT , most_valuable_features TEXT , notes TEXT , active BIT NOT NULL , name_error VARCHAR(255) , is_new BIT NOT NULL ); CREATE TEMPORARY TABLE IF NOT EXISTS tmp_Msg_Error ( display_order INT NOT NULL PRIMARY KEY AUTO_INCREMENT , id_type INT , code VARCHAR(50) NOT NULL , msg VARCHAR(4000) NOT NULL ); -- Get data from Temp table INSERT INTO tmp_Apply_Founding_Partner_Form ( id_apply_founding_partner_form , name_contact , email , phone_number , name_company , website , dog_count , id_years_of_experience , ids_speciality , ids_existing_system , id_existing_challenges , id_existing_time_sink_weekly , id_commitment_frequency , most_valuable_features , notes , active , is_new ) SELECT AFPF_T.id_apply_founding_partner_form AS id_apply_founding_partner_form , IFNULL(AFPF_T.name_contact, AFPF.name_contact) AS name_contact , IFNULL(AFPF_T.email, AFPF.email) AS email , IFNULL(AFPF_T.phone_number, AFPF.phone_number) AS phone_number , IFNULL(AFPF_T.name_company, AFPF.name_company) AS name_company , IFNULL(AFPF_T.website, AFPF.website) AS website , IFNULL(AFPF_T.dog_count, AFPF.dog_count) AS dog_count , IFNULL(AFPF_T.id_years_of_experience, AFPF.id_years_of_experience) AS id_years_of_experience , IFNULL(AFPF_T.ids_speciality, AFPF.ids_speciality) AS ids_speciality , IFNULL(AFPF_T.ids_existing_system, AFPF.ids_existing_system) AS ids_existing_system , IFNULL(AFPF_T.id_existing_challenges, AFPF.id_existing_challenges) AS id_existing_challenges , IFNULL(AFPF_T.id_existing_time_sink_weekly, AFPF.id_existing_time_sink_weekly) AS id_existing_time_sink_weekly , IFNULL(AFPF_T.id_commitment_frequency, AFPF.id_commitment_frequency) AS id_commitment_frequency , IFNULL(AFPF_T.most_valuable_features, AFPF.most_valuable_features) AS most_valuable_features , IFNULL(AFPF_T.notes, AFPF.notes) AS notes , COALESCE(AFPF_T.active, AFPF.active, 1) AS active , CASE WHEN IFNULL(AFPF_T.id_apply_founding_partner_form, 0) < 1 THEN 1 ELSE 0 END AS is_new FROM demo.PH_Apply_Founding_Partner_Form_Temp AFPF_T LEFT JOIN demo.PH_Apply_Founding_Partner_Form AFPF ON AFPF_T.id_apply_founding_partner_form = AFPF.id_apply_founding_partner_form WHERE AFPF_T.guid = a_guid ; UPDATE tmp_Apply_Founding_Partner_Form t_AFPF SET name_error = COALESCE(t_AFPF.email, t_AFPF.name_company, t_AFPF.name_contact, t_AFPF.message, '(No Apply Founding Partner Form)') ; -- Validation -- Missing mandatory fields -- name_contact IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.name_contact) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Contact Name: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.name_contact) ; END IF; -- email IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.email) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have an Email: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.email) ; END IF; -- phone_number IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.phone_number) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Phone_number: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.phone_number) ; END IF; -- name_company IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.name_company) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Company Name: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.name) ; END IF; -- website IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.website) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Website: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.website) ; END IF; -- dog_count IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.dog_count) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Dog_count: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.dog_count) ; END IF; -- id_years_of_experience IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.id_years_of_experience) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Id_years_of_experience: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.id_years_of_experience) ; END IF; -- ids_speciality IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.ids_speciality) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Ids_speciality: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.ids_speciality) ; END IF; -- ids_existing_system IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.ids_existing_system) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Ids_existing_system: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.ids_existing_system) ; END IF; -- id_existing_challenges IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.id_existing_challenges) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Id_existing_challenges: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.id_existing_challenges) ; END IF; -- id_existing_time_sink_weekly IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.id_existing_time_sink_weekly) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Id_existing_time_sink_weekly: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.id_existing_time_sink_weekly) ; END IF; -- id_commitment_frequency IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.id_commitment_frequency) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Id_commitment_frequency: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.id_commitment_frequency) ; END IF; -- most_valuable_features IF EXISTS (SELECT * FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.most_valuable_features) LIMIT 1) THEN INSERT INTO tmp_Msg_Error ( id_type , code , msg ) SELECT v_id_type_error_bad_data , v_code_type_error_bad_data , CONCAT('The following Apply Founding Partner Form(s) do not have a Most_valuable_features: ', GROUP_CONCAT(t_AFPF.name_error SEPARATOR ', ')) AS msg FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE ISNULL(t_AFPF.most_valuable_features) ; END IF; -- Permissions IF a_debug = 1 THEN SELECT a_guid , 0 -- get_all_user , 0 -- get_inactive_user , a_id_user -- ids_user , '' -- a_auth0_ids_user , '' -- a_names_user , '' -- a_emails_user , 1 -- a_require_all_id_search_filters_met , 1 -- a_require_any_id_search_filters_met , 0 -- a_require_all_non_id_search_filters_met , 0 -- a_require_any_non_id_search_filters_met , v_id_permission_apply_founding_partner_form_admin -- ids_permission , v_id_access_level_view -- ids_access_level , 0 -- a_show_errors , 0 -- a_debug ; END IF; CALL demo.p_dog_calc_user( a_guid , 0 -- get_all_user , 0 -- get_inactive_user , a_id_user -- ids_user , '' -- a_auth0_ids_user , '' -- a_names_user , '' -- a_emails_user , 1 -- a_require_all_id_search_filters_met , 1 -- a_require_any_id_search_filters_met , 0 -- a_require_all_non_id_search_filters_met , 0 -- a_require_any_non_id_search_filters_met , v_id_permission_apply_founding_partner_form_admin -- ids_permission , v_id_access_level_view -- ids_access_level , 0 -- a_show_errors , 0 -- a_debug ); SELECT IFNULL(CALC_USER_T.has_access, 0) INTO v_can_admin FROM demo.DOG_Calc_User_Temp CALC_USER_T WHERE CALC_USER_T.GUID = a_guid LIMIT 1 ; IF a_debug = 1 THEN SELECT v_can_admin; SELECT COUNT(*) AS Count_Errors FROM tmp_Msg_Error t_ERROR; SELECT * FROM tmp_Msg_Error t_ERROR; END IF; CALL demo.p_dog_clear_calc_user( a_guid , 0 -- a_debug ); IF a_debug = 1 THEN SELECT a_guid , 0 -- get_all_user , 0 -- get_inactive_user , a_id_user -- ids_user , '' -- a_auth0_ids_user , '' -- a_names_user , '' -- a_emails_user , 1 -- a_require_all_id_search_filters_met , 1 -- a_require_any_id_search_filters_met , 0 -- a_require_all_non_id_search_filters_met , 0 -- a_require_any_non_id_search_filters_met , v_id_permission_apply_founding_partner_form_new -- ids_permission , v_id_access_level_view -- ids_access_level , 0 -- a_show_errors , 0 -- a_debug ; END IF; CALL demo.p_dog_calc_user( a_guid , 0 -- get_all_user , 0 -- get_inactive_user , a_id_user -- ids_user , '' -- a_auth0_ids_user , '' -- a_names_user , '' -- a_emails_user , 1 -- a_require_all_id_search_filters_met , 1 -- a_require_any_id_search_filters_met , 0 -- a_require_all_non_id_search_filters_met , 0 -- a_require_any_non_id_search_filters_met , v_id_permission_apply_founding_partner_form_new -- ids_permission , v_id_access_level_view -- ids_access_level , 0 -- a_show_errors , 0 -- a_debug ); SELECT IFNULL(CALC_USER_T.has_access, 0) INTO v_can_create FROM demo.DOG_Calc_User_Temp CALC_USER_T WHERE CALC_USER_T.GUID = a_guid LIMIT 1 ; IF a_debug = 1 THEN SELECT v_can_create; SELECT COUNT(*) AS Count_Errors FROM tmp_Msg_Error t_ERROR; SELECT * FROM tmp_Msg_Error t_ERROR; END IF; CALL demo.p_dog_clear_calc_user( a_guid , 0 -- a_debug ); IF (v_can_admin = 0 AND EXISTS(SELECT * FROM tmp_Apply_Founding_Partner_Form WHERE is_new = 0)) THEN DELETE t_ME FROM tmp_Msg_Error t_ME WHERE t_ME.id_type <> v_id_type_error_no_permission ; INSERT INTO tmp_Msg_Error ( id_type , code , msg ) VALUES ( v_id_type_error_no_permission , v_code_type_error_no_permission , 'You do not have permission to admin Apply Founding Partner Forms.' ) ; END IF; IF EXISTS (SELECT * FROM tmp_Msg_Error LIMIT 1) THEN IF a_debug = 1 THEN SELECT * from tmp_Apply_Founding_Partner_Form; END IF; DELETE FROM tmp_Apply_Founding_Partner_Form; END IF; IF NOT EXISTS (SELECT * FROM tmp_Msg_Error LIMIT 1) THEN START TRANSACTION; INSERT INTO demo.PH_Contact_Form_Change_Set ( comment , id_user_updated_last_by , updated_last_on ) VALUES ( a_comment , a_id_user , v_time_start ) ; SET v_id_change_set := LAST_INSERT_ID(); UPDATE demo.PH_Apply_Founding_Partner_Form AFPF INNER JOIN tmp_Apply_Founding_Partner_Form t_AFPF ON AFPF.id_apply_founding_partner_form = t_AFPF.id_apply_founding_partner_form AND t_AFPF.is_new = 0 SET AFPF.name_contact = t_AFPF.name_contact , AFPF.email = t_AFPF.email , AFPF.phone_number = t_AFPF.phone_number , AFPF.name_company = t_AFPF.name_company , AFPF.website = t_AFPF.website , AFPF.dog_count = t_AFPF.dog_count , AFPF.id_years_of_experience = t_AFPF.id_years_of_experience , AFPF.ids_speciality = t_AFPF.ids_speciality , AFPF.ids_existing_system = t_AFPF.ids_existing_system , AFPF.id_existing_challenges = t_AFPF.id_existing_challenges , AFPF.id_existing_time_sink_weekly = t_AFPF.id_existing_time_sink_weekly , AFPF.id_commitment_frequency = t_AFPF.id_commitment_frequency , AFPF.most_valuable_features = t_AFPF.most_valuable_features , AFPF.notes = t_AFPF.notes , AFPF.active = t_AFPF.active , AFPF.id_change_set = v_id_change_set ; INSERT INTO demo.PH_Apply_Founding_Partner_Form ( name_contact , email , phone_number , name_company , website , dog_count , id_years_of_experience , ids_speciality , ids_existing_system , id_existing_challenges , id_existing_time_sink_weekly , id_commitment_frequency , most_valuable_features , notes , active , id_user_created_by , created_on ) SELECT t_AFPF.name_contact , t_AFPF.email , t_AFPF.phone_number , t_AFPF.name_company , t_AFPF.website , t_AFPF.dog_count , t_AFPF.id_years_of_experience , t_AFPF.ids_speciality , t_AFPF.ids_existing_system , t_AFPF.id_existing_challenges , t_AFPF.id_existing_time_sink_weekly , t_AFPF.id_commitment_frequency , t_AFPF.most_valuable_features , t_AFPF.notes , t_AFPF.active , a_id_user , v_time_start FROM tmp_Apply_Founding_Partner_Form t_AFPF WHERE t_AFPF.is_new = 1 AND t_AFPF.active = 1 ; COMMIT; END IF; START TRANSACTION; DELETE FROM demo.PH_Apply_Founding_Partner_Form_Temp WHERE GUID = a_guid ; COMMIT; -- Errors SELECT * FROM tmp_Msg_Error t_ME INNER JOIN demo.CORE_Msg_Error_Type MET ON t_ME.id_type = MET.id_type ; IF a_debug = 1 THEN SELECT * from tmp_Apply_Founding_Partner_Form; END IF; DROP TEMPORARY TABLE tmp_Apply_Founding_Partner_Form; DROP TEMPORARY TABLE tmp_Msg_Error; IF a_debug = 1 THEN CALL demo.p_core_debug_timing_reporting ( v_time_start ); END IF; END // DELIMITER ; /* select * -- COUNT(*) -- delete from demo.PH_Apply_Founding_Partner_Form_Temp ; CALL demo.p_ph_save_apply_founding_partner_form ( 'nipples' , (SELECT GUID FROM demo.PH_Apply_Founding_Partner_Form_Temp ORDER BY id_temp DESC LIMIT 1) , 1 , 1 ); select * -- COUNT(*) -- delete from demo.PH_Apply_Founding_Partner_Form_Temp ; */