Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php /* Copyright (c) Nicsoft LLC */ eval( '?>' . base64_decode('PD9waHANCg0KaW5jbHVkZV9v..

Decoded Output download

?>b'<?php

include_once \'inc/auth_header.php\';
include_once \'config.php\';
include_once \'classes/Database.php\';


class UpdateCore {
	
	
	public function __construct(){
		
		
		
		
		if(DB_TYPE == \'postgresql\')
			return;
		
		$this->update_638();
		
		$this->update_700();
		
		$this->update_705();
		
		$this->update_707();
		
		$this->update_754();
		
		$this->update_762();
		
		$this->update_766(); 
		
		$this->update_767();
		
		$this->update_770();
		
		$this->update_775(); 
        
        $this->update_801(); 
        
        $this->update_805(); 
        
        $this->update_842(); 
        
        $this->update_861(); 
        
        $this->update_866(); 
        
        $this->update_883(); 
        
        $this->update_891(); 
        
        $this->update_905(); 
        
        $this->update_906(); 
        
        $this->update_910(); 
        
		$this->update_918(); 
		
        $this->update_929(); 

        $this->update_944(); 
        
        
        
	}
	
	public function update_944(){
			
		$need_table = true;
		
		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
			$sql = "SHOW TABLES LIKE \'fb_workflow_jobs\'";
			$result = Database::pdo_query ( $sql, 0 );
			
			if (count ( $result ) != 0) {
				$need_table = false;
			}
		} else {
			$sql = "IF OBJECT_ID(\'[dbo].[fb_workflow_jobs]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
			
			$result = Database::pdo_query ( $sql, 0 );
			
			if ($result [0] [\'status\'] == \'true\') {
				$need_table = false;
			}
		}

		if(!$need_table){
			return;
		}

		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_jobs` (
				`id` int NOT NULL AUTO_INCREMENT,
				`formboss_job_id` int DEFAULT NULL,
				`formboss_job_name` varchar(255) DEFAULT NULL,
				`job_originator_id` int DEFAULT NULL,
				`current_owner_id` int DEFAULT NULL,
				`category_id` int DEFAULT NULL,
				`workflow_data` longtext,
				`date_created` datetime DEFAULT NULL,
				`date_completed` datetime DEFAULT NULL,
				`latest_update` datetime DEFAULT NULL,
				`active` int DEFAULT \'1\',
				`archived` int DEFAULT \'0\',
				`date_archived` datetime DEFAULT NULL,
				PRIMARY KEY (`id`),
				KEY `FK_fb_workflow_jobs_fb_jobs_id` (`formboss_job_id`),
				CONSTRAINT `FK_fb_workflow_jobs_fb_jobs_id` FOREIGN KEY (`formboss_job_id`) REFERENCES `fb_jobs` (`id`) ON DELETE CASCADE
			  ) ENGINE=InnoDB AUTO_INCREMENT=24 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=9830;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_active_job_entries` (
				`id` int NOT NULL AUTO_INCREMENT,
				`active_task_id` int DEFAULT NULL,
				`task_user_id` varchar(255) DEFAULT NULL,
				`formboss_job_id` int NOT NULL,
				`workflow_job_id` int DEFAULT NULL,
				`workflow_stage_name` varchar(255) DEFAULT NULL,
				`ts` int DEFAULT NULL,
				`name` varchar(255) DEFAULT NULL,
				`label` varchar(255) DEFAULT NULL,
				`entry_value` text,
				`file_data` longblob,
				`file_mime` varchar(50) DEFAULT NULL,
				`file_name` varchar(255) DEFAULT NULL,
				`entry_key` varchar(50) DEFAULT NULL,
				`fb_entry_id` varchar(255) DEFAULT NULL,
				`entry_type` varchar(20) DEFAULT NULL,
				`remote_ip` varchar(50) DEFAULT NULL,
				PRIMARY KEY (`id`),
				KEY `IDX_entry_key` (`entry_key`),
				KEY `IDX_ts` (`ts`),
				KEY `index1` (`formboss_job_id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=296 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=2340;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_active_task_comments` (
				`id` int NOT NULL AUTO_INCREMENT,
				`user_id` int DEFAULT NULL,
				`job_id` int DEFAULT NULL,
				`active_task_id` int DEFAULT NULL,
				`comment` longtext,
				`ts` datetime DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_active_tasks` (
				`id` int NOT NULL AUTO_INCREMENT,
				`task_master_id` int DEFAULT NULL,
				`task_user_id` int DEFAULT NULL,
				`workflow_job_id` int DEFAULT NULL,
				`workflow_stage_name` varchar(255) DEFAULT NULL,
				`workflow_stage_to_load` varchar(255) DEFAULT NULL,
				`task_active` int DEFAULT NULL,
				`task_locked` int DEFAULT NULL,
				`signature_status` varchar(255) DEFAULT NULL,
				`ts` datetime DEFAULT NULL,
				`comment` longtext,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=61 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=2048;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_category_group_access` (
				`id` int NOT NULL AUTO_INCREMENT,
				`category_id` int DEFAULT NULL,
				`group_id` int DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=45 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=1170;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_groups` (
				`id` int NOT NULL AUTO_INCREMENT,
				`group_name` varchar(255) DEFAULT NULL,
				`group_privilege` int DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=4096;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_hooks` (
				`id` int NOT NULL AUTO_INCREMENT,
				`workflow_job_id` int DEFAULT NULL,
				`formboss_job_id` int DEFAULT NULL,
				`formboss_job_name` varchar(255) DEFAULT NULL,
				`workflow_active` int DEFAULT \'1\',
				`targets` longtext,
				PRIMARY KEY (`id`),
				KEY `FK_fb_workflow_hooks_fb_jobs_id` (`formboss_job_id`),
				KEY `FK_fb_workflow_hooks_fb_workflow_jobs_id` (`workflow_job_id`),
				CONSTRAINT `FK_fb_workflow_hooks_fb_workflow_jobs_id` FOREIGN KEY (`workflow_job_id`) REFERENCES `fb_workflow_jobs` (`id`) ON DELETE CASCADE
			  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_job_categories` (
				`id` int NOT NULL AUTO_INCREMENT,
				`parent_id` int DEFAULT NULL,
				`name` varchar(255) DEFAULT NULL,
				`description` longtext,
				`group_access` longtext,
				`date_added` datetime DEFAULT NULL,
				`date_updated` datetime DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=29 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=1820;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_status_types` (
				`id` int NOT NULL AUTO_INCREMENT,
				`status_name` varchar(255) DEFAULT NULL,
				`status_value` varchar(255) DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_targets` (
				`id` int NOT NULL AUTO_INCREMENT,
				`workflow_job_id` int DEFAULT NULL,
				`formboss_job_id` int DEFAULT NULL,
				`formboss_job_name` varchar(255) DEFAULT NULL,
				`target` varchar(255) DEFAULT NULL,
				`target_type` varchar(55) DEFAULT NULL,
				`active` int DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=1086 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=682;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_task_master` (
				`id` int NOT NULL AUTO_INCREMENT,
				`task_originator_user_id` int DEFAULT NULL,
				`workflow_job_id` int DEFAULT NULL,
				`workflow_complete` tinyint(1) DEFAULT \'0\',
				`ts` datetime DEFAULT NULL,
				`ts_completed` datetime DEFAULT NULL,
				`archived` int DEFAULT \'0\',
				`was_deleted` int DEFAULT \'0\',
				`ts_was_deleted` datetime DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=25 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=8192;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_users` (
				`id` int NOT NULL AUTO_INCREMENT,
				`fb_user_id` int DEFAULT \'-1\',
				`name` varchar(255) DEFAULT NULL,
				`password` blob,
				`active` int DEFAULT NULL,
				`permissions` varchar(255) DEFAULT NULL,
				PRIMARY KEY (`id`),
				KEY `FK_fb_workflow_users_fb_admin_user_id` (`fb_user_id`),
				CONSTRAINT `FK_fb_workflow_users_fb_admin_user_id` FOREIGN KEY (`fb_user_id`) REFERENCES `fb_admin` (`user_id`) ON DELETE CASCADE
			  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			
			
			$sql = <<<EOF
			INSERT INTO fb_workflow_job_categories (parent_id, name, description) VALUES (\'-1\', \'root\', \'root category\');
EOF;

			$result = Database::pdo_query ( $sql, 0 );


			$sql = <<<EOF
			INSERT INTO fb_workflow_groups (group_name, group_privilege) VALUES (\'Workflow Group\', \'4\');
EOF;

			$result = Database::pdo_query ( $sql, 0 );

		} else { 

			$sql = <<<MSG_EOF
			
			CREATE TABLE [fb_workflow_jobs] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[formboss_job_id] int DEFAULT NULL,
				[formboss_job_name] varchar(255) DEFAULT NULL,
				[job_originator_id] int DEFAULT NULL,
				[current_owner_id] int DEFAULT NULL,
				[category_id] int DEFAULT NULL,
				[workflow_data] text,
				[date_created] datetime DEFAULT NULL,
				[date_completed] datetime DEFAULT NULL,
				[latest_update] datetime DEFAULT NULL,
				[active] int DEFAULT \'1\',
				[archived] int DEFAULT \'0\',
				[date_archived] datetime DEFAULT NULL, CONSTRAINT [PK_fb_workflow_jobs] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_active_job_entries] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[active_task_id] int DEFAULT NULL,
				[task_user_id] varchar(255) DEFAULT NULL,
				[formboss_job_id] int NOT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[workflow_stage_name] varchar(255) DEFAULT NULL,
				[ts] int DEFAULT NULL,
				[name] varchar(255) DEFAULT NULL,
				[label] varchar(255) DEFAULT NULL,
				[entry_value] text,
				[file_data] text,
				[file_mime] varchar(50) DEFAULT NULL,
				[file_name] varchar(255) DEFAULT NULL,
				[entry_key] varchar(50) DEFAULT NULL,
				[fb_entry_id] varchar(255) DEFAULT NULL,
				[entry_type] varchar(20) DEFAULT NULL,
				[remote_ip] varchar(50) DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_active_job_entries] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
			  


			  
			  CREATE TABLE [fb_workflow_active_task_comments] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[user_id] int DEFAULT NULL,
				[job_id] int DEFAULT NULL,
				[active_task_id] int DEFAULT NULL,
				[comment] text,
				[ts] datetime DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_active_task_comments] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] 
			  
			  
			  
			  CREATE TABLE [fb_workflow_active_tasks] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[task_master_id] int DEFAULT NULL,
				[task_user_id] int DEFAULT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[workflow_stage_name] varchar(255) DEFAULT NULL,
				[workflow_stage_to_load] varchar(255) DEFAULT NULL,
				[task_active] int DEFAULT NULL,
				[task_locked] int DEFAULT NULL,
				[signature_status] varchar(255) DEFAULT NULL,
				[ts] datetime DEFAULT NULL,
				[comment] text, 
				CONSTRAINT [PK_fb_workflow_active_tasks] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_category_group_access] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[category_id] int DEFAULT NULL,
				[group_id] int DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_category_group_access] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_groups] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[group_name] varchar(255) DEFAULT NULL,
				[group_privilege] int DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_groups] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_hooks] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[formboss_job_id] int DEFAULT NULL,
				[formboss_job_name] varchar(255) DEFAULT NULL,
				[workflow_active] int DEFAULT \'1\',
				[targets] text, 
				CONSTRAINT [PK_fb_workflow_hooks] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_job_categories] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[parent_id] int DEFAULT NULL,
				[name] varchar(255) DEFAULT NULL,
				[description] text,
				[group_access] text,
				[date_added] datetime DEFAULT NULL,
				[date_updated] datetime DEFAULT NULL, 
				CONSTRAINT [PK_workflow_job_categories] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] 
			  
			  
			  
			  CREATE TABLE [fb_workflow_status_types] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[status_name] varchar(255) DEFAULT NULL,
				[status_value] varchar(255) DEFAULT NULL, 
				CONSTRAINT [PK_workflow_status_types] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_targets] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[formboss_job_id] int DEFAULT NULL,
				[formboss_job_name] varchar(255) DEFAULT NULL,
				[target] varchar(255) DEFAULT NULL,
				[target_type] varchar(55) DEFAULT NULL,
				[active] int DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_targets] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_task_master] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[task_originator_user_id] int DEFAULT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[workflow_complete] int DEFAULT \'0\',
				[ts] datetime DEFAULT NULL,
				[ts_completed] datetime DEFAULT NULL,
				[archived] int DEFAULT \'0\',
				[was_deleted] int DEFAULT \'0\',
				[ts_was_deleted] datetime DEFAULT NULL, 
				CONSTRAINT [PK_workflow_task_master] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_users] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[fb_user_id] int DEFAULT \'-1\',
				[name] varchar(255) DEFAULT NULL,
				[password] binary,
				[active] int DEFAULT NULL,
				[permissions] varchar(255) DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_users] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  

			  -- Key 

			  ALTER TABLE [dbo].[fb_workflow_jobs]  WITH CHECK ADD  CONSTRAINT [FK_fb_workflow_jobs_fb_jobs] FOREIGN KEY([formboss_job_id])
			  REFERENCES [dbo].[fb_jobs] ([id])
			  ON DELETE CASCADE
			   
			  ALTER TABLE [dbo].[fb_workflow_jobs] CHECK CONSTRAINT [FK_fb_workflow_jobs_fb_jobs]

			  -- Key
			  
			  ALTER TABLE [dbo].[fb_workflow_hooks]  WITH CHECK ADD  CONSTRAINT [FK_fb_workflow_hooks_fb_workflow_jobs] FOREIGN KEY([workflow_job_id])
			  REFERENCES [dbo].[fb_workflow_jobs] ([id])
			  ON DELETE CASCADE

			  ALTER TABLE [dbo].[fb_workflow_hooks] CHECK CONSTRAINT [FK_fb_workflow_hooks_fb_workflow_jobs]
			  
			  -- Key
			  
			  ALTER TABLE [dbo].[fb_workflow_users]  WITH CHECK ADD  CONSTRAINT [FK_fb_workflow_users_fb_admin] FOREIGN KEY([fb_user_id])
			  REFERENCES [dbo].[fb_admin] ([user_id])
			  ON DELETE CASCADE

			  ALTER TABLE [dbo].[fb_workflow_users] CHECK CONSTRAINT [FK_fb_workflow_users_fb_admin]
			  
			  
			  -- Set Default Data.

			  INSERT INTO fb_workflow_job_categories (parent_id, name, description) VALUES (\'-1\', \'root\', \'root category\');
			  
			  INSERT INTO fb_workflow_groups (group_name, group_privilege) VALUES (\'Workflow Group\', \'4\');	
MSG_EOF;

			
			

			if (Database::pdo_query ( $sql, 1, true )) {
				return;
			} else {
				die;
			}
		}
	

		
		if (Database::pdo_query ( $sql, 1 )) {
				
			
			if (isset ( $sql_2 ) && Database::pdo_query ( $sql_2, 1 )) {
				echo \'Good News! Your Database Has Been Updated To Build 944 - Please refresh this page to start using RackForms again.\';
			} else {
	
				if (! isset ( $sql_2 )) {
					echo \'Good News! Your Database Has Been Updated To Build 944 - Please refresh this page to start using RackForms again.\';
					return;
				} else {
						
					echo \'Error Updating Database To Build 944. Please Contact [email protected] for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.\';
					return;
				}
			}
		} else {
			echo \'Error Updating Database To Build 944. Please Contact [email protected] for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.\';
		}
	}


	
	public function update_929(){
	
		
	
		if(!$this->checkConfigWrite()){
			die(\'In order to use this version of RackForms you must make your /rackforms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.\');
		}
	
		$old = \'?>\';
	
		
		$config_file_raw = file_get_contents(\'config.php\');
	
		
		if(substr_count($config_file_raw, "db_ssl_key") == 0) {
				
			
				
			$add = <<<EOF

// MySQL SSL Support.
\$db_ssl_key = \'\';
\$db_ssl_certificate = \'\';
\$db_ssl_ca_cert = \'\';
\$db_ssl_verify_cert = \'\';
\$db_ssl_cipher = \'\';

?>

EOF;
		
			$config_file_raw = str_replace($old, $add, $config_file_raw);
	
			
			file_put_contents(\'config.php\', $config_file_raw);
		
		}
		
		
		
		if(substr_count($config_file_raw, "AUTH_UseSimpleSAML") == 0) {
		
			
		
			$add = <<<EOF
		
// Build 889 - Simple SAML SSO.
define(\'AUTH_UseSimpleSAML\', \'0\'); // 1 To Use SAML Authentication.
define(\'SimpleSAML_AuthSource\', \'rackforms-sp\'); // Auth Source.
define(\'SimpleSAML_Path\', \'/../simplesamlphp/lib/_autoload.php\'); // Location of the SimpleSAML libraries.
define(\'SimpleSAML_LogoutReturnTo\', \'https://rackforms.baymain.com/logged_out.php\'); // Location of a logout redirect.
		
?>

EOF;
		
			$config_file_raw = str_replace($old, $add, $config_file_raw);
		
			
			file_put_contents(\'config.php\', $config_file_raw);
		
		}
		
	
	} 
	
	
	
	public function update_918(){
			
		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
			$sql = \'SHOW COLUMNS FROM fb_jobs\';
			$result = Database::pdo_query ( $sql, 0 );
			foreach ( $result as $r ) {
				if (substr_count ( $r [\'Field\'], \'read_only_user_id\' )) {
					
					return;
				}
			}
		} else { 
			$sql = "SELECT read_only_user_id FROM fb_jobs";
			if (Database::pdo_query ( $sql, 1 )) {
				return;
			}
		}
	
		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
			$sql = "ALTER TABLE `fb_jobs`
					ADD COLUMN `read_only_user_id` int(11) AFTER `user_id`;";
		} else { 
			$sql = "ALTER TABLE fb_jobs
					ADD read_only_user_id int";
		}
		
		
		if (Database::pdo_query ( $sql, 1 )) {
	
			echo \'Good News! Your Database Has Been Updated To Build 918 - Please refresh this page to start using RackForms again.\';

		} else {
			
			echo \'Error Updating Database To Build 918. Please Contact [email protected] for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.\';
		}
	}
	
	
	public function update_910(){
	
		
	
		if(!$this->checkConfigWrite()){
			die(\'In order to use this version of RackForms you must make your /rackforms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.\');
		}
	
		$old = \'?>\';
	
		
		$config_file_raw = file_get_contents(\'config.php\');
	
		
		if(substr_count($config_file_raw, "AUTH_AD") == 0) {
				
			
				
			$add = <<<EOF

// LDAP / Active Directory Login.
// See: https://www.rackforms.com/documentation/installation/active-directory-login.php
define(\'AUTH_AD\', \'0\'); // Use AD Authentication.
define(\'AUTH_AD_LDAP_HOST\', \'\'); // Host Name: e.g. LDAP://corp.sample.com:389
define(\'AUTH_AD_LDAP_PREFIX\', \'\'); // Prefix: e.g. CORP\ Note: Be sure to always escape single slashes.
define(\'AUTH_AD_LDAP_DN\', \'\'); // Distinguished Names: e.g. DC=corp,DC=sample,DC=com
define(\'AUTH_AD_CUSTOM_LEVEL_GROUP_NAME_VALUE\', 7); // The default user privilege level for new users.

?>

EOF;
		
			$config_file_raw = str_replace($old, $add, $config_file_raw);
	
			
			file_put_contents(\'config.php\', $config_file_raw);
		
		}
		
		
		
		if(substr_count($config_file_raw, "AUTH_UseSimpleSAML") == 0) {
		
			
		
			$add = <<<EOF
		
// Build 889 - Simple SAML SSO.
define(\'AUTH_UseSimpleSAML\', \'0\'); // 1 To Use SAML Authentication.
define(\'SimpleSAML_AuthSource\', \'rackforms-sp\'); // Auth Source.
define(\'SimpleSAML_Path\', \'/../simplesamlphp/lib/_autoload.php\'); // Location of the SimpleSAML libraries.
define(\'SimpleSAML_LogoutReturnTo\', \'https://rackforms.baymain.com/logged_out.php\'); // Location of a logout redirect.
		
?>

EOF;
		
			$config_file_raw = str_replace($old, $add, $config_file_raw);
		
			
			file_put_contents(\'config.php\', $config_file_raw);
		
		}
		
	
	} 
	
	
	
	public function update_906(){
			
		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
			$sql = \'SHOW COLUMNS FROM fb_stripe_transactions\';
			$result = Database::pdo_query ( $sql, 0 );
			foreach ( $result as $r ) {
				if (substr_count ( $r [\'Field\'], \'customer\' )) {
					
					return;
				}
			}
		} else { 
			$sql = "SELECT customer FROM fb_stripe_transactions";
			if (Database::pdo_query ( $sql, 1 )) {
				return;
			}
		}
	
		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
			$sql = "ALTER TABLE `fb_stripe_transactions`
					ADD COLUMN `customer` TEXT AFTER `date`;";
		} else { 
			$sql = "ALTER TABLE fb_stripe_transactions
					ADD customer text";
		}
		
		if (Database::pdo_query ( $sql, 1 )) {
				
			
			if (isset ( $sql_2 ) && Database::pdo_query ( $sql_2, 1 )) {
				echo \'Good News! Your Database Has Been Updated To Build 906 - Please refresh this page to start using RackForms again.\';
			} else {
	
				if (! isset ( $sql_2 )) {
					echo \'Good News! Your Database Has Been Updated To Build 79067 - Please refresh this page to start using RackForms again.\';
					return;
				} else {
						
					echo \'Error Updating Database To Build 906. Please Contact [email protected] for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.\';
					return;
				}
			}
		} else {
			echo \'Error Updating Database To Build 906. Please Contact [email protected] for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.\';
		}
	}
	
	public function update_905() {
	
		
		
		
		$need_table = true;
		
		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
			$sql = "SHOW TABLES LIKE \'fb_audit_user\'";
			$result = Database::pdo_query ( $sql, 0 );
			
			if (count ( $result ) != 0) {
				$need_table = false;
			}
		} else {
			$sql = "IF OBJECT_ID(\'[dbo].[fb_audit_user]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
			
			$result = Database::pdo_query ( $sql, 0 );
			
			if ($result [0] [\'status\'] == \'true\') {
				$need_table = false;
			}
		}
	
		if ($need_table) {
		
			
			
			if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
				
				$sql = "CREATE TABLE `fb_audit_user` (
						  `id` int(11) NOT NULL AUTO_INCREMENT,
						  `user_id` int(11) DEFAULT NULL,
						  `date` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
						  `class` varchar(100) DEFAULT NULL,
						  `action` text,
						  `result` text,
						  `detail` text,
						  PRIMARY KEY (`id`)
						) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;";
				
				Database::pdo_query ( $sql, 0 );
			} else { 
			
				$cat = DB_CATALOG;
				
				$sql = <<<EOT
			BEGIN
				USE [{$cat}];
				END

BEGIN
CREATE TABLE [dbo].[fb_audit_user](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[user_id] [int] NULL,
	[date] [datetime] NULL,
	[class] [varchar](100) NULL,
	[action] [text] NULL,
	[result] [text] NULL,
	[detail] [text] NULL,
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END

EOT;
			
				Database::pdo_query ( $sql, 0 );
			} 
			
		} 
		
		
		
		
		
		$need_table = true;
		
		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
			$sql = "SHOW TABLES LIKE \'fb_jobs_backup\'";
			$result = Database::pdo_query ( $sql, 0 );
						
					if (count ( $result ) != 0) {
						$need_table = false;
					}
		} else {
			
			$sql = "IF OBJECT_ID(\'[dbo].[fb_jobs_backup]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
		
			$result = Database::pdo_query ( $sql, 0 );
						
			if ($result [0] [\'status\'] == \'true\') {
				$need_table = false;

			}
					
		}
		
		if ($need_table) {

			
				
			if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {

			$sql = "CREATE TABLE `fb_jobs_backup` (
			  `id` int(11) NOT NULL AUTO_INCREMENT,
			  `job_name` varchar(50) DEFAULT NULL,
			  `created_ts` varchar(25) NULL,
			  `delete_date` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
			  `job_xml` longtext,
			  `user_id` int(11),	
			  `folder_id` int(11),	
			  PRIMARY KEY (`id`)
			) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;";

			Database::pdo_query ( $sql, 0 );
			
		} else { 
							
			$cat = DB_CATALOG;
	
			$sql = <<<EOT
						BEGIN
						USE [{$cat}];
				END
		
BEGIN
CREATE TABLE [dbo].[fb_jobs_backup](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[job_name] [varchar](50) NULL,
	[created_ts] [varchar](25) NULL,
	[delete_ts] [timestamp] NULL,
	[job_xml] [text] NULL,
	[user_id] [int] NULL,
	[folder_id] [int] NULL,
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END
		
EOT;
		
				Database::pdo_query ( $sql, 0 );
						
			} 
			
		} 
		
		
	}
	
	
	public function update_891(){
	
		
	
		if(!$this->checkConfigWrite()){
			die(\'In order to use this version of RackForms you must make your /rackforms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.\');
		}
	
	
		
		$config_file_raw = file_get_contents(\'config.php\');
	
		
		if(substr_count($config_file_raw, "\$_SESSION[\'v_string\']") == 0) {
			
			
			
			$add = <<<EOF
define(\'MAGIC_QUOTES_CHECK\', 1);
			
\$_SESSION[\'v_string\'] = \'rackforms\';
\$_SESSION[\'v_string_title\'] = \'RackForms\';
			
EOF;
			
			$old = <<<EOF
define(\'MAGIC_QUOTES_CHECK\', 1);
EOF;
			
			$config_file_raw = str_replace($old, $add, $config_file_raw);
				
			
			file_put_contents(\'config.php\', $config_file_raw);
			
		}	
	
	}
	
	
	
	public function update_883(){
			
		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
			$sql = \'SHOW COLUMNS FROM fb_job_entries_tmp\';
			$result = Database::pdo_query ( $sql, 0 );
			foreach ( $result as $r ) {
				if (substr_count ( $r [\'Field\'], \'file_data\' )) {
					
					return;
				}
			}
		} else { 
			$sql = "SELECT file_data FROM fb_job_entries_tmp";
			if (Database::pdo_query ( $sql, 1 )) {
				return;
			}
		}
		
		
		if (DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\') {
			$sql = "ALTER TABLE `fb_job_entries_tmp`
					ADD COLUMN `file_data` LONGBLOB AFTER `entry_value`,
					ADD COLUMN `file_mime` VARCHAR(120) AFTER `file_data`,
					ADD COLUMN `file_name` VARCHAR(255) AFTER `file_mime`,
					ADD COLUMN `sig_data` LONGBLOB AFTER `file_name`;";
		} else { 
			$sql = "ALTER TABLE fb_job_entries_tmp
					ADD file_data text,
					file_mime [varchar](120) NULL,
					file_name [varchar](255) NULL,
					sig_data text;";
		}
		
		if (Database::pdo_query ( $sql, 1 )) {
			
			
			if (isset ( $sql ) && Database::pdo_query ( $sql, 1 )) {
				echo \'Good News! Your Database Has Been Updated To Build 883 - Please refresh this page to start using RackForms again.\';
			} else {
				
				if (! isset ( $sql )) {
					echo \'Good News! Your Database Has Been Updated To Build 883 - Please refresh this page to start using RackForms again.\';
					return;
				} else {
					
					echo \'Error Updating Database To Build 883. Please Contact [email protected] for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.\';
					return;
				}
			}
		} else {
			echo \'Error Updating Database To Build 883. Please Contact [email protected] for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.\';
		}
	}
	
	
	public function update_866(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_aci_level_1_transactions\'";
			$result = Database::pdo_query($sql, 0);
					
			if(count($result) != 0){
				$need_table = false;
			}
			
		} else {
			$sql = "IF OBJECT_ID(\'[dbo].[fb_aci_level_1_transactions]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
	
			$result = Database::pdo_query($sql, 0);
	
			if($result[0][\'status\'] == \'true\'){
				$need_table = false;
			}
	
		}
	
		if($need_table){
	
			
			
			if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){

				$sql = "CREATE TABLE `fb_aci_level_1_transactions` (
						  `id` int(11) NOT NULL AUTO_INCREMENT,
						  `rf_entry_key` varchar(50) DEFAULT NULL,
						  `uid` varchar(50) DEFAULT NULL,
						  `confirmation` varchar(50) DEFAULT NULL,
						  `email` varchar(100) DEFAULT NULL,
						  `amount` double DEFAULT NULL,
						  `date` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
						  `data` text,
						  `shipping_data` text,
						  `line_items` text,
						  PRIMARY KEY (`id`)
						) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;";
	
				Database::pdo_query($sql, 0);
	
			} else { 
	
				$cat = DB_CATALOG;

				$sql = <<<EOT
					BEGIN
					USE [{$cat}];
					END
	
BEGIN
CREATE TABLE [dbo].[fb_aci_level_1_transactions](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[rf_entry_key] [varchar](50) NULL,
	[uid] [varchar](50) NULL,
	[confirmation] [varchar](50) NULL,
	[email] [varchar](100) NULL,
	[amount] [money] NULL,
	[date] [datetime] NULL,
	[data] [text] NULL,
	[shipping_data] [text] NULL,
	[line_items] [text] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END
	
EOT;
	
				Database::pdo_query($sql, 0);
	
			} 
	
		}
	}
	
	public function update_861(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_payflow_transactions\'";
			$result = Database::pdo_query($sql, 0);
					
				if(count($result) != 0){
				$need_table = false;
				}
				} else {
				$sql = "IF OBJECT_ID(\'[dbo].[fb_payflow_transactions]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
	
			$result = Database::pdo_query($sql, 0);
	
				if($result[0][\'status\'] == \'true\'){
				$need_table = false;
				}
	
				}
	
				if($need_table){
	
				
					if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
	
					$sql = "CREATE TABLE `fb_payflow_transactions` (
							  `id` int(11) NOT NULL AUTO_INCREMENT,
							  `rf_entry_key` varchar(50) DEFAULT NULL,
							  `PNREF` varchar(50) DEFAULT NULL,
							  `ACCT` int(11) DEFAULT NULL,
							  `result` varchar(50) DEFAULT NULL,
							  `email` varchar(100) DEFAULT NULL,
							  `amount` double DEFAULT NULL,
							  `date` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
							  `data` text,
							  `shipping_data` text,
							  `line_items` text,
							  `subscription_data` text,
							  `trial_data` text,
							  `profile_id` varchar(50) DEFAULT NULL,
							  `profile_status` varchar(50) DEFAULT NULL,
							  PRIMARY KEY (`id`)
							) ENGINE=InnoDB DEFAULT CHARSET=utf8;";
	
				Database::pdo_query($sql, 0);
						
					} else { 
						
					$cat = DB_CATALOG;
	
					$sql = <<<EOT
					BEGIN
					USE [{$cat}];
			END
	
BEGIN
CREATE TABLE [dbo].[fb_payflow_transactions](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[rf_entry_key] [varchar](50) NULL,
	[PNREF] [varchar](50) NULL,
	[ACCT] [int] NULL	
	[result] [varchar](50) NULL,
	[email] [varchar](100) NULL,
	[amount] [money] NULL,
	[date] [datetime] NULL,
	[data] [text] NULL,
	[shipping_data] [text] NULL,
	[line_items] [text] NULL,
	[subscription_data] [text] NULL,
	[trial_data] [text] NULL,
	[profile_id] [text] NULL,
	[profile_status] [text] NULL,	
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END

EOT;
	
				Database::pdo_query($sql, 0);
	
			} 
	
		}
	}
    
    
	public function update_842(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_reports\'";
			$result = Database::pdo_query($sql, 0);
			
			if(count($result) != 0){
				$need_table = false;
			}	
		} else {
			$sql = "IF OBJECT_ID(\'[dbo].[fb_reports]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
		
			$result = Database::pdo_query($sql, 0);
				
			if($result[0][\'status\'] == \'true\'){
				$need_table = false;
			}
	
		}
	
		if($need_table){
	
		
			if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
				
				$sql = "CREATE TABLE IF NOT EXISTS `fb_reports` (
						  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
						  `user_id` int(11) DEFAULT NULL,
						  `report_title` varchar(255) DEFAULT NULL,
						  `report_data` longtext,
						  PRIMARY KEY (`id`)
						) ENGINE=InnoDB DEFAULT CHARSET=utf8;";
	
				Database::pdo_query($sql, 0);
			
		} else { 
			
			$cat = DB_CATALOG;
				
			$sql = <<<EOT
			BEGIN
			USE [{$cat}];
			END
	
			BEGIN
CREATE TABLE [dbo].[fb_reports](
[id] [int] IDENTITY(1,1) NOT NULL,
[user_id] [int] NULL,
[report_title] [varchar](255) NULL,
[report_data] [text] NULL
) ON [PRIMARY]
END
EOT;
	
				Database::pdo_query($sql, 0);
	
			} 
	
		}
	}
	
    
    
	public function update_805(){
				
		$need_table = true;
	
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_analytics\'";
			$result = Database::pdo_query($sql, 0);
				if(count($result) != 0){
				    $need_table = false;
		        }
		} else { 
			$sql = "IF OBJECT_ID(\'[dbo].[fb_analytics]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
		
			$result = Database::pdo_query($sql, 0);
				
			if($result[0][\'status\'] == \'true\'){
					$need_table = false;
		    }
	
		}
	
		if($need_table){
	
            
			if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
	
			$sql = "CREATE TABLE `fb_analytics` (
                    `id` INT(11) NOT NULL AUTO_INCREMENT,
                    `job_id` INT(11) NOT NULL,
                    `ts` DATETIME DEFAULT NULL,
                    `page_title` VARCHAR(255) DEFAULT NULL,
                    `page_type` VARCHAR(25) DEFAULT NULL,
                    `entry_key` VARCHAR(50) DEFAULT NULL,
                    `remote_ip` VARCHAR(50) DEFAULT NULL,
                    PRIMARY KEY  (`id`),
                    INDEX index1 USING BTREE (`job_id`),
                    INDEX IDX_ts USING BTREE (`ts`),
                    INDEX IDX_entry_key USING BTREE (`entry_key`),
                    CONSTRAINT `fb_analytics_FK1` FOREIGN KEY (`job_id`) REFERENCES `fb_jobs` (`id`) ON DELETE CASCADE
                ) ENGINE=INNODB CHARSET=utf8 COLLATE utf8_general_ci;";
	
				Database::pdo_query($sql, 0);
			
            } else { 
			
                $cat = DB_CATALOG;

                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN
                    CREATE TABLE [dbo].[fb_analytics](
	                [id] [int] IDENTITY(1,1) NOT NULL,
	                [job_id] [int] NOT NULL,
	                [ts] [datetime] NULL,
	                [page_title] [varchar](255) NULL,
	                [page_type] [varchar](25) NULL,
	                [entry_key] [varchar](50) NULL,
	                [remote_ip] [varchar](50) NULL,
                 CONSTRAINT [PK_fb_analytics] PRIMARY KEY CLUSTERED 
                (
	                [id] ASC
                )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
                ) ON [PRIMARY]
                END
EOT;
	
				Database::pdo_query($sql, 0);
                
                

                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN
                    ALTER TABLE [dbo].[fb_analytics]  WITH CHECK ADD  CONSTRAINT [FK_fb_analytics_fb_jobs] FOREIGN KEY([job_id])
                    REFERENCES [dbo].[fb_jobs] ([id])
                    ON DELETE CASCADE
                    END
EOT;
	
				Database::pdo_query($sql, 0);
            
                
                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN

                    ALTER TABLE [dbo].[fb_analytics] CHECK CONSTRAINT [FK_fb_analytics_fb_jobs]

                    END
EOT;
	
				Database::pdo_query($sql, 0);

            } 
	
		} 

	}
    
    public function update_801(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_api_manager\'";
			$result = Database::pdo_query($sql, 0);
				if(count($result) != 0){
				    $need_table = false;
		        }
		} else { 
			$sql = "IF OBJECT_ID(\'[dbo].[fb_api_manager]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
		
			$result = Database::pdo_query($sql, 0);
				
			if($result[0][\'status\'] == \'true\'){
					$need_table = false;
		    }
	
		}
	
		if($need_table){
	
            
			if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
	
			$sql = "CREATE TABLE `fb_api_manager` (
					  `id` int(11) NOT NULL DEFAULT \'0\',
					  `user_id` int(11) DEFAULT NULL,
					  `data` longblob,
					  `created` datetime DEFAULT NULL,
					  `last_accessed` datetime DEFAULT NULL,
					  PRIMARY KEY (`id`),
					  KEY `RackForms_api_manager_KEY` (`user_id`),
					  CONSTRAINT `FK_RackForms_api_manager_FK` FOREIGN KEY (`user_id`) REFERENCES `fb_admin` (`user_id`) ON DELETE CASCADE
					) ENGINE=InnoDB DEFAULT CHARSET=utf8;";
	
				Database::pdo_query($sql, 0);
			
            } else { 
			
                $cat = DB_CATALOG;

                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN

                    CREATE TABLE [dbo].[fb_api_manager](
                    [id] [int] IDENTITY(1,1) NOT NULL,
                    [user_id] [int] NULL,
                    [data] [image] NULL,
                    [created] [datetime] NULL,
                    [last_accessed] [datetime] NULL,
                    CONSTRAINT [PK_fb_api_manager] PRIMARY KEY CLUSTERED 
                    (
                    [id] ASC
                    )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
                    ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END
EOT;
	
				Database::pdo_query($sql, 0);
                
                

                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN

                    ALTER TABLE [dbo].[fb_api_manager]  WITH CHECK ADD  CONSTRAINT [FK_fb_api_manager_fb_admin] FOREIGN KEY([user_id])
                    REFERENCES [dbo].[fb_admin] ([user_id])
                    ON DELETE CASCADE

                    END
EOT;
	
				Database::pdo_query($sql, 0);
            
                
                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN

                    ALTER TABLE [dbo].[fb_api_manager] CHECK CONSTRAINT [FK_fb_api_manager_fb_admin]

                    END
EOT;
	
				Database::pdo_query($sql, 0);

            } 
	
		} 
        
	}
	
	
	public function update_775(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_aim_transactions\'";
			$result = Database::pdo_query($sql, 0);
				if(count($result) != 0){
				$need_table = false;
		}
		} else { 
			$sql = "IF OBJECT_ID(\'[dbo].[fb_aim_transactions]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
		
			$result = Database::pdo_query($sql, 0);
				
			if($result[0][\'status\'] == \'true\'){
					$need_table = false;
		}
	
		}
	
		if($need_table){
	
		
			if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
	
			$sql = "CREATE TABLE IF NOT EXISTS fb_aim_transactions(
						  id INT(11) NOT NULL AUTO_INCREMENT,
						  rf_entry_key VARCHAR(50) DEFAULT NULL,
						  transaction_id VARCHAR(50) DEFAULT NULL,
						  amount INT(11) DEFAULT NULL,
						  `date` TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP,
						  `data` TEXT DEFAULT NULL,
						  shipping_data TEXT DEFAULT NULL,
						  line_items TEXT DEFAULT NULL,
						  subscription_data TEXT DEFAULT NULL,
						  trail_data TEXT DEFAULT NULL,
						  PRIMARY KEY (id)
						)
						ENGINE = INNODB
						AUTO_INCREMENT = 1
						AVG_ROW_LENGTH = 8192
						CHARACTER SET utf8
						COLLATE utf8_general_ci;";
	
				Database::pdo_query($sql, 0);
			
		} else { 
			
		$cat = DB_CATALOG;
			
		$sql = <<<EOT
			BEGIN
			USE [{$cat}];
			END
	
			BEGIN
	
			CREATE TABLE [dbo].[fb_aim_transactions](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[rf_entry_key] [varchar](50) NULL,
	[transaction_id] [varchar](50) NULL,
	[amount] [int] NULL,
	[date] [datetime] NULL,
	[data] [text] NULL,
	[shipping_data] [text] NULL,
	[line_items] [text] NULL,
	[subscription_data] [text] NULL,
	[trial_data] [text] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
	
END
EOT;
	
				Database::pdo_query($sql, 0);
	
		} 
	
		}
	}
	
	
	public function update_770(){
				
		
		
		
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = \'SHOW COLUMNS FROM fb_stripe_transactions\';
			$result = Database::pdo_query($sql, 0);
			foreach($result as $r){
				if(substr_count($r[\'Field\'], \'email\')){
					
					return;
				}
			}
		} else { 
			$sql = "SELECT email FROM fb_stripe_transactions";
			if(Database::pdo_query($sql, 1)){
				return;
			}
		}
		

		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "ALTER TABLE `fb_stripe_transactions` 
					ADD COLUMN `email` VARCHAR(100) AFTER `charge_id`;";
		} else { 
			$sql = "ALTER TABLE fb_stripe_transactions 
					ADD email VARCHAR(100);";
		}
		
		if(Database::pdo_query($sql, 1)){
			
			
			if(isset($sql_2) && Database::pdo_query($sql_2, 1)){
				echo \'Good News! Your Database Has Been Updated To Build 770 - Please refresh this page to start using RackForms again.\';
			
			} else {
				
				if(!isset($sql_2)){
					echo \'Good News! Your Database Has Been Updated To Build 770 - Please refresh this page to start using RackForms again.\';
					return;
				} else {

					echo \'Error Updating Database To Build 770. Please Contact [email protected] for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.\';
					return;
					
				}
					
			}

		} else {
			echo \'Error Updating Database To Build 770. Please Contact [email protected] for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.\';
		}

	}
	
	
	public function update_767(){
				
		
		
		
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = \'SHOW COLUMNS FROM fb_stripe_transactions\';
			$result = Database::pdo_query($sql, 0);
			foreach($result as $r){
				if(substr_count($r[\'Field\'], \'line_items\')){
					
					return;
				}
			}
		} else { 
			$sql = "SELECT line_items FROM fb_stripe_transactions";
			if(Database::pdo_query($sql, 1)){
				return;
			}
		}
		

		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "ALTER TABLE `fb_stripe_transactions` 
					ADD COLUMN `line_items` TEXT AFTER `shipping_data`;";
		} else { 
			$sql = "ALTER TABLE fb_stripe_transactions 
					ADD line_items text;";
		}
		
		if(Database::pdo_query($sql, 1)){
			
			
			if(isset($sql_2) && Database::pdo_query($sql_2, 1)){
				echo \'Good News! Your Database Has Been Updated To Build 767 - Please refresh this page to start using RackForms again.\';
			
			} else {
				
				if(!isset($sql_2)){
					echo \'Good News! Your Database Has Been Updated To Build 767 - Please refresh this page to start using RackForms again.\';
					return;
				} else {

					echo \'Error Updating Database To Build 767. Please Contact [email protected] for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.\';
					return;
					
				}
					
			}

		} else {
			echo \'Error Updating Database To Build 767. Please Contact [email protected] for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.\';
		}

	}
	
	public function update_766(){
		
		
		
		
		
		$need_table = true;
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_stripe_transactions\'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				$need_table = false;
			}
		} else { 
			$sql = "IF OBJECT_ID(\'[dbo].[fb_stripe_transactions]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0][\'status\'] == \'true\'){
				$need_table = false;
			}

		}
		
		if($need_table){
		
			
			if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
				
				$sql = "CREATE TABLE IF NOT EXISTS fb_stripe_transactions(
						  id INT(11) NOT NULL AUTO_INCREMENT,
						  rf_entry_key VARCHAR(50) DEFAULT NULL,
						  charge_id VARCHAR(50) DEFAULT NULL,
						  amount INT(11) DEFAULT NULL,
						  `date` TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP,
						  `data` TEXT DEFAULT NULL,
						  shipping_data TEXT DEFAULT NULL,
						  line_items TEXT DEFAULT NULL,
						  subscription_data TEXT DEFAULT NULL,
						  trail_data TEXT DEFAULT NULL,
						  PRIMARY KEY (id)
						)
						ENGINE = INNODB
						AUTO_INCREMENT = 1
						AVG_ROW_LENGTH = 8192
						CHARACTER SET utf8
						COLLATE utf8_general_ci;";
				
				Database::pdo_query($sql, 0);
			
			} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_stripe_transactions](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[rf_entry_key] [varchar](50) NULL,
	[charge_id] [varchar](50) NULL,
	[amount] [int] NULL,
	[date] [datetime] NULL,
	[data] [text] NULL,
	[shipping_data] [text] NULL,
	[line_items] [text] NULL,
	[subscription_data] [text] NULL,
	[trial_data] [text] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

END
EOT;

				Database::pdo_query($sql, 0);
	
			} 
		
		}
	}
	
	
	public function update_762(){
		
		
		
		
		
		$need_table = true;
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_job_folders\'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				$need_table = false;
			}
		} else { 
			$sql = "IF OBJECT_ID(\'[dbo].[fb_job_folders]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0][\'status\'] == \'true\'){
				$need_table = false;
			}

		}
		
		if($need_table){
		
			
			if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
				
				$sql = "CREATE TABLE rackforms.fb_job_folders(
						  f_id INT(11) NOT NULL AUTO_INCREMENT,
						  name VARCHAR(255) DEFAULT NULL,
						  PRIMARY KEY (f_id)
						)
						ENGINE = INNODB
						AUTO_INCREMENT = 1
						CHARACTER SET utf8
						COLLATE utf8_general_ci;";
				
				Database::pdo_query($sql, 0);
			
			} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_job_folders](
	[f_id] [int] IDENTITY(1,1) NOT NULL,
	[name] [varchar](100) NULL
) ON [PRIMARY]

END
EOT;

				Database::pdo_query($sql, 0);
	
			} 
		
		}
		
		
		
		
		
		
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = \'SHOW COLUMNS FROM fb_jobs\';
			$result = Database::pdo_query($sql, 0);
			foreach($result as $r){
				if(substr_count($r[\'Field\'], \'folder_id\')){
					
					return;
				}
			}
		} else { 
			$sql = "SELECT folder_id FROM fb_jobs";
			if(Database::pdo_query($sql, 1)){
				return;
			}
		}
		

		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "ALTER TABLE `fb_jobs` 
					ADD COLUMN `folder_id` INT(11) DEFAULT 0 AFTER `job_xml`;";
		} else { 
			$sql = "ALTER TABLE fb_jobs 
					ADD folder_id INT(11);";
			
			$sql_2 = "ALTER TABLE [dbo].[fb_jobs] ADD  CONSTRAINT [DF_fb_jobs_folder_id]  DEFAULT ((0)) FOR [folder_id]";
		}
		
		if(Database::pdo_query($sql, 1)){
			
			
			if(isset($sql_2) && Database::pdo_query($sql_2, 1)){
				echo \'Good News! Your Database Has Been Updated To Build 762 - Please refresh this page to start using RackForms again.\';
			
			} else {
				
				if(!isset($sql_2)){
					echo \'Good News! Your Database Has Been Updated To Build 762 - Please refresh this page to start using RackForms again.\';
					return;
				} else {

					echo \'Error Updating Database To Build 762. Please Contact [email protected] for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.\';
					return;
					
				}
					
			}

		} else {
			echo \'Error Updating Database To Build 762. Please Contact [email protected] for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.\';
		}

	}
	
	public function update_754(){
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_digital_signatures\'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				return;
			}
		} else { 
			$sql = "IF OBJECT_ID(\'[dbo].[fb_digital_signatures]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0][\'status\'] == \'true\'){
				return;
			}

		}
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			
			$sql = "CREATE TABLE fb_digital_signatures(
					  id INT(11) NOT NULL AUTO_INCREMENT,
					  entry_id VARCHAR(255) DEFAULT NULL,
					  field_id VARCHAR(255) DEFAULT NULL,
					  signator VARCHAR(255) DEFAULT NULL,
					  signature TEXT DEFAULT NULL,
					  signature_image LONGBLOB DEFAULT NULL,
					  sig_hash VARCHAR(128) DEFAULT NULL,
					  ip VARCHAR(46) DEFAULT NULL,
					  created INT(11) DEFAULT NULL,
					  PRIMARY KEY (id)
					)
					ENGINE = INNODB
					AUTO_INCREMENT = 1
					CHARACTER SET utf8
					COLLATE utf8_general_ci;";
			
			Database::pdo_query($sql, 0);
			
		} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_digital_signatures](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[entry_id] [varchar](255) NULL,
	[field_id] [varchar](255) NULL,
	[signator] [varchar](255) NULL,
	[signature] [text] NULL,
	[signature_image] [image] NULL,
	[sig_hash] [varchar](128) NULL,
	[ip] [varchar](48) NULL,
	[created] [int] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

END
EOT;

			Database::pdo_query($sql, 0);

		} 
			
			
			
			
			echo \'<div style="background-color: Yellow; height: 30px; padding-top:10px">&nbsp;&nbsp;&nbsp;&nbsp;Your Database Has Been Updated To Build 754 - Please Refresh The Page To Finish This Process.</div>\';

		
	}
	
	
	public function update_707(){
		
		
		$sql = "SELECT option_name FROM fb_options WHERE option_name = \'load_a_saved_job_sort\'";
		$result = Database::pdo_query($sql, 0);
		if(count($result) != 0){
			return;
		}	
		
		
	
		$sql = "INSERT INTO fb_options (option_name, option_value, option_version) VALUES (\'load_a_saved_job_sort\', \'id,DESC\', \'707\');";
		
		Database::pdo_query($sql, 0);

		
		
		
		echo \'RackForms First Run Message: - Your RackForms Database Has Been Updated With New Settings - Please Refresh This Page To Start Using RackForms Again.\';
		
	}
	
	
	public function update_705(){
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_options\'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				return;
			}
		} else { 
			$sql = "IF OBJECT_ID(\'[dbo].[fb_options]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0][\'status\'] == \'true\'){
				return;
			}

		}
		
		
		
		
		if(!$this->checkConfigWrite()){
			die(\'In order to use this version of RackForms you must make your /RackForms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.\');
		}
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			
			$sql = "CREATE TABLE fb_options(
					  option_name VARCHAR(255) DEFAULT NULL,
					  option_value TEXT DEFAULT NULL,
					  option_version INT(11) DEFAULT NULL
					)
					ENGINE = INNODB
					CHARACTER SET utf8
					COLLATE utf8_general_ci;";
			
			Database::pdo_query($sql, 0);
			
		} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_options](
	[option_name] [varchar](255) NULL,
	[option_value] [text] NULL,
	[option_version] [int] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

END
EOT;

			Database::pdo_query($sql, 0);

		} 
		


			
			$config_file_raw = file_get_contents(\'config.php\');			

			
			$newfile = $config_file_raw;
			
			
			$datetime = date(\'Y-m-d  H:i:s\', time());
			$replace = "// UPDATE - 705 :: {$datetime}
?>";
			$newfile = str_replace(\'?>\', $replace, $newfile);
			
			
			file_put_contents(\'config.php\', $newfile);
			
			
			
			
			echo \' - Your Database and Config File Has Been Updated To Build 705 - Please Refresh This Page To Start Using RackForms Again.\';

		
	}
	
	
	
	public function update_700(){
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "SHOW TABLES LIKE \'fb_formblocks\'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				return;
			}
		} else { 
			$sql = "IF OBJECT_ID(\'[dbo].[fb_formblocks]\') IS NOT NULL SELECT \'true\' AS status; ELSE SELECT \'false\' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0][\'status\'] == \'true\'){
				return;
			}

		}
		
		
		
		
		if(!$this->checkConfigWrite()){
			die(\'In order to use this version of RackForms you must make your /RackForms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.\');
		}
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			
			$sql = "CREATE TABLE fb_formblocks(
						id INT(11) NOT NULL AUTO_INCREMENT,
						user_id INT(11) DEFAULT NULL,
						name VARCHAR(255) DEFAULT NULL,
						category VARCHAR(255) DEFAULT NULL,
						description VARCHAR(255) DEFAULT NULL,
						layout VARCHAR(255) DEFAULT NULL,
						pagetype INT(11) DEFAULT NULL,
						content LONGTEXT DEFAULT NULL,
						PRIMARY KEY (id)
					)
					ENGINE = INNODB
					AUTO_INCREMENT = 1
					AVG_ROW_LENGTH = 6553
					CHARACTER SET utf8
					COLLATE utf8_general_ci;";
			
			Database::pdo_query($sql, 0);
			
		} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_formblocks](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[user_id] [int] NULL,
	[name] [varchar](255) NULL,
	[category] [varchar](255) NULL,
	[description] [varchar](255) NULL,
	[layout] [varchar](255) NULL,
	[pagetype] [int] NULL,
	[content] [text] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

END
EOT;

			Database::pdo_query($sql, 0);

		} 
		
		
			

			
			$config_file_raw = file_get_contents(\'config.php\');			
			
			$new_config_data = <<<EOF
define(\'ENCODE_PW\', 1);

// Build 700 - Add the values below to block that module from loading into the editor.
\$excluded_form_modules = array(\'\'); // Use: ecomm to block the ecomm module from loading in the editor.
\$excluded_confirmation_modules = array(\'\'); // Use: confirm-ecomm to block the ecomm confirmation module.
EOF;

			
			$newfile = $config_file_raw;
			
			
			$newfile = str_replace("define(\'ENCODE_PW\', 1);", $new_config_data, $newfile);
			
			
			$datetime = date(\'Y-m-d  H:i:s\', time());
			$replace = "// UPDATE - 700 :: {$datetime}
?>";
			$newfile = str_replace(\'?>\', $replace, $newfile);
			
			
			file_put_contents(\'config.php\', $newfile);
			
			
			
			
			echo \' - Your Database and Config File Has Been Updated To Build 700 - Please Refresh This Page To Start Using RackForms Again.\';

		
	}
	
	
	
	public function update_638(){
		
		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = \'SHOW COLUMNS FROM fb_jobs\';
			$result = Database::pdo_query($sql, 0);
			foreach($result as $r){
				if(substr_count($r[\'Field\'], \'created_ts\')){
					
					return;
				}
			}
		} else { 
			$sql = "SELECT created_ts FROM fb_jobs";
			if(Database::pdo_query($sql, 1)){
				return;
			}
		}
		
		
		if(!$this->checkConfigWrite()){
			die(\'In order to use this version of RackForms you must make your /RackForms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.\');
		}

		
		$config_file_raw = file_get_contents(\'config.php\');

		
		if(DB_TYPE == \'mysql\' || DB_TYPE == \'mysqli\'){
			$sql = "ALTER TABLE `fb_jobs` 
					ADD COLUMN `created_ts` DATETIME AFTER `created`,
					ADD COLUMN `last_edit_ts` DATETIME AFTER `last_edit`;";
		} else { 
			$sql = "ALTER TABLE fb_jobs 
					ADD created_ts DATETIME, last_edit_ts DATETIME;";
		}
		
		if(Database::pdo_query($sql, 1)){
			
			$newfile = $config_file_raw;
			$datetime = date(\'Y-m-d  H:i:s\', time());
			$replace = "// UPDATE - 638 :: {$datetime}
?>";
			$newfile = str_replace(\'?>\', $replace, $newfile);
			file_put_contents(\'config.php\', $newfile);
			echo \'Good News! Your Database Has Been Updated To Build 638 - Please refresh this page to start using RackForms again.\';
		} else {
			echo \'Error Updating Database To Build 638. Please Contact [email protected] for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.\';
		}

	}
	
	
	
	
	
	
	public function checkConfigWrite(){
		return is_writable(\'config.php\');
	}
	
} 
?>'

Did this file decode correctly?

Original Code

<?php /* Copyright (c) Nicsoft LLC */ eval( '?>' . base64_decode('<?php

include_once 'inc/auth_header.php';
include_once 'config.php';
include_once 'classes/Database.php';


class UpdateCore {
	
	
	public function __construct(){
		
		
		
		
		if(DB_TYPE == 'postgresql')
			return;
		
		$this->update_638();
		
		$this->update_700();
		
		$this->update_705();
		
		$this->update_707();
		
		$this->update_754();
		
		$this->update_762();
		
		$this->update_766(); 
		
		$this->update_767();
		
		$this->update_770();
		
		$this->update_775(); 
        
        $this->update_801(); 
        
        $this->update_805(); 
        
        $this->update_842(); 
        
        $this->update_861(); 
        
        $this->update_866(); 
        
        $this->update_883(); 
        
        $this->update_891(); 
        
        $this->update_905(); 
        
        $this->update_906(); 
        
        $this->update_910(); 
        
		$this->update_918(); 
		
        $this->update_929(); 

        $this->update_944(); 
        
        
        
	}
	
	public function update_944(){
			
		$need_table = true;
		
		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
			$sql = "SHOW TABLES LIKE 'fb_workflow_jobs'";
			$result = Database::pdo_query ( $sql, 0 );
			
			if (count ( $result ) != 0) {
				$need_table = false;
			}
		} else {
			$sql = "IF OBJECT_ID('[dbo].[fb_workflow_jobs]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
			
			$result = Database::pdo_query ( $sql, 0 );
			
			if ($result [0] ['status'] == 'true') {
				$need_table = false;
			}
		}

		if(!$need_table){
			return;
		}

		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_jobs` (
				`id` int NOT NULL AUTO_INCREMENT,
				`formboss_job_id` int DEFAULT NULL,
				`formboss_job_name` varchar(255) DEFAULT NULL,
				`job_originator_id` int DEFAULT NULL,
				`current_owner_id` int DEFAULT NULL,
				`category_id` int DEFAULT NULL,
				`workflow_data` longtext,
				`date_created` datetime DEFAULT NULL,
				`date_completed` datetime DEFAULT NULL,
				`latest_update` datetime DEFAULT NULL,
				`active` int DEFAULT '1',
				`archived` int DEFAULT '0',
				`date_archived` datetime DEFAULT NULL,
				PRIMARY KEY (`id`),
				KEY `FK_fb_workflow_jobs_fb_jobs_id` (`formboss_job_id`),
				CONSTRAINT `FK_fb_workflow_jobs_fb_jobs_id` FOREIGN KEY (`formboss_job_id`) REFERENCES `fb_jobs` (`id`) ON DELETE CASCADE
			  ) ENGINE=InnoDB AUTO_INCREMENT=24 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=9830;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_active_job_entries` (
				`id` int NOT NULL AUTO_INCREMENT,
				`active_task_id` int DEFAULT NULL,
				`task_user_id` varchar(255) DEFAULT NULL,
				`formboss_job_id` int NOT NULL,
				`workflow_job_id` int DEFAULT NULL,
				`workflow_stage_name` varchar(255) DEFAULT NULL,
				`ts` int DEFAULT NULL,
				`name` varchar(255) DEFAULT NULL,
				`label` varchar(255) DEFAULT NULL,
				`entry_value` text,
				`file_data` longblob,
				`file_mime` varchar(50) DEFAULT NULL,
				`file_name` varchar(255) DEFAULT NULL,
				`entry_key` varchar(50) DEFAULT NULL,
				`fb_entry_id` varchar(255) DEFAULT NULL,
				`entry_type` varchar(20) DEFAULT NULL,
				`remote_ip` varchar(50) DEFAULT NULL,
				PRIMARY KEY (`id`),
				KEY `IDX_entry_key` (`entry_key`),
				KEY `IDX_ts` (`ts`),
				KEY `index1` (`formboss_job_id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=296 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=2340;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_active_task_comments` (
				`id` int NOT NULL AUTO_INCREMENT,
				`user_id` int DEFAULT NULL,
				`job_id` int DEFAULT NULL,
				`active_task_id` int DEFAULT NULL,
				`comment` longtext,
				`ts` datetime DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_active_tasks` (
				`id` int NOT NULL AUTO_INCREMENT,
				`task_master_id` int DEFAULT NULL,
				`task_user_id` int DEFAULT NULL,
				`workflow_job_id` int DEFAULT NULL,
				`workflow_stage_name` varchar(255) DEFAULT NULL,
				`workflow_stage_to_load` varchar(255) DEFAULT NULL,
				`task_active` int DEFAULT NULL,
				`task_locked` int DEFAULT NULL,
				`signature_status` varchar(255) DEFAULT NULL,
				`ts` datetime DEFAULT NULL,
				`comment` longtext,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=61 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=2048;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_category_group_access` (
				`id` int NOT NULL AUTO_INCREMENT,
				`category_id` int DEFAULT NULL,
				`group_id` int DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=45 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=1170;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_groups` (
				`id` int NOT NULL AUTO_INCREMENT,
				`group_name` varchar(255) DEFAULT NULL,
				`group_privilege` int DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=4096;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_hooks` (
				`id` int NOT NULL AUTO_INCREMENT,
				`workflow_job_id` int DEFAULT NULL,
				`formboss_job_id` int DEFAULT NULL,
				`formboss_job_name` varchar(255) DEFAULT NULL,
				`workflow_active` int DEFAULT '1',
				`targets` longtext,
				PRIMARY KEY (`id`),
				KEY `FK_fb_workflow_hooks_fb_jobs_id` (`formboss_job_id`),
				KEY `FK_fb_workflow_hooks_fb_workflow_jobs_id` (`workflow_job_id`),
				CONSTRAINT `FK_fb_workflow_hooks_fb_workflow_jobs_id` FOREIGN KEY (`workflow_job_id`) REFERENCES `fb_workflow_jobs` (`id`) ON DELETE CASCADE
			  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_job_categories` (
				`id` int NOT NULL AUTO_INCREMENT,
				`parent_id` int DEFAULT NULL,
				`name` varchar(255) DEFAULT NULL,
				`description` longtext,
				`group_access` longtext,
				`date_added` datetime DEFAULT NULL,
				`date_updated` datetime DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=29 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=1820;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_status_types` (
				`id` int NOT NULL AUTO_INCREMENT,
				`status_name` varchar(255) DEFAULT NULL,
				`status_value` varchar(255) DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_targets` (
				`id` int NOT NULL AUTO_INCREMENT,
				`workflow_job_id` int DEFAULT NULL,
				`formboss_job_id` int DEFAULT NULL,
				`formboss_job_name` varchar(255) DEFAULT NULL,
				`target` varchar(255) DEFAULT NULL,
				`target_type` varchar(55) DEFAULT NULL,
				`active` int DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=1086 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=682;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_task_master` (
				`id` int NOT NULL AUTO_INCREMENT,
				`task_originator_user_id` int DEFAULT NULL,
				`workflow_job_id` int DEFAULT NULL,
				`workflow_complete` tinyint(1) DEFAULT '0',
				`ts` datetime DEFAULT NULL,
				`ts_completed` datetime DEFAULT NULL,
				`archived` int DEFAULT '0',
				`was_deleted` int DEFAULT '0',
				`ts_was_deleted` datetime DEFAULT NULL,
				PRIMARY KEY (`id`)
			  ) ENGINE=InnoDB AUTO_INCREMENT=25 DEFAULT CHARSET=utf8 AVG_ROW_LENGTH=8192;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			$sql = <<<EOT

			CREATE TABLE `fb_workflow_users` (
				`id` int NOT NULL AUTO_INCREMENT,
				`fb_user_id` int DEFAULT '-1',
				`name` varchar(255) DEFAULT NULL,
				`password` blob,
				`active` int DEFAULT NULL,
				`permissions` varchar(255) DEFAULT NULL,
				PRIMARY KEY (`id`),
				KEY `FK_fb_workflow_users_fb_admin_user_id` (`fb_user_id`),
				CONSTRAINT `FK_fb_workflow_users_fb_admin_user_id` FOREIGN KEY (`fb_user_id`) REFERENCES `fb_admin` (`user_id`) ON DELETE CASCADE
			  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
EOT;
			
			$result = Database::pdo_query ( $sql, 0 );

			
			
			$sql = <<<EOF
			INSERT INTO fb_workflow_job_categories (parent_id, name, description) VALUES ('-1', 'root', 'root category');
EOF;

			$result = Database::pdo_query ( $sql, 0 );


			$sql = <<<EOF
			INSERT INTO fb_workflow_groups (group_name, group_privilege) VALUES ('Workflow Group', '4');
EOF;

			$result = Database::pdo_query ( $sql, 0 );

		} else { 

			$sql = <<<MSG_EOF
			
			CREATE TABLE [fb_workflow_jobs] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[formboss_job_id] int DEFAULT NULL,
				[formboss_job_name] varchar(255) DEFAULT NULL,
				[job_originator_id] int DEFAULT NULL,
				[current_owner_id] int DEFAULT NULL,
				[category_id] int DEFAULT NULL,
				[workflow_data] text,
				[date_created] datetime DEFAULT NULL,
				[date_completed] datetime DEFAULT NULL,
				[latest_update] datetime DEFAULT NULL,
				[active] int DEFAULT '1',
				[archived] int DEFAULT '0',
				[date_archived] datetime DEFAULT NULL, CONSTRAINT [PK_fb_workflow_jobs] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_active_job_entries] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[active_task_id] int DEFAULT NULL,
				[task_user_id] varchar(255) DEFAULT NULL,
				[formboss_job_id] int NOT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[workflow_stage_name] varchar(255) DEFAULT NULL,
				[ts] int DEFAULT NULL,
				[name] varchar(255) DEFAULT NULL,
				[label] varchar(255) DEFAULT NULL,
				[entry_value] text,
				[file_data] text,
				[file_mime] varchar(50) DEFAULT NULL,
				[file_name] varchar(255) DEFAULT NULL,
				[entry_key] varchar(50) DEFAULT NULL,
				[fb_entry_id] varchar(255) DEFAULT NULL,
				[entry_type] varchar(20) DEFAULT NULL,
				[remote_ip] varchar(50) DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_active_job_entries] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
			  


			  
			  CREATE TABLE [fb_workflow_active_task_comments] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[user_id] int DEFAULT NULL,
				[job_id] int DEFAULT NULL,
				[active_task_id] int DEFAULT NULL,
				[comment] text,
				[ts] datetime DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_active_task_comments] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] 
			  
			  
			  
			  CREATE TABLE [fb_workflow_active_tasks] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[task_master_id] int DEFAULT NULL,
				[task_user_id] int DEFAULT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[workflow_stage_name] varchar(255) DEFAULT NULL,
				[workflow_stage_to_load] varchar(255) DEFAULT NULL,
				[task_active] int DEFAULT NULL,
				[task_locked] int DEFAULT NULL,
				[signature_status] varchar(255) DEFAULT NULL,
				[ts] datetime DEFAULT NULL,
				[comment] text, 
				CONSTRAINT [PK_fb_workflow_active_tasks] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_category_group_access] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[category_id] int DEFAULT NULL,
				[group_id] int DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_category_group_access] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_groups] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[group_name] varchar(255) DEFAULT NULL,
				[group_privilege] int DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_groups] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_hooks] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[formboss_job_id] int DEFAULT NULL,
				[formboss_job_name] varchar(255) DEFAULT NULL,
				[workflow_active] int DEFAULT '1',
				[targets] text, 
				CONSTRAINT [PK_fb_workflow_hooks] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_job_categories] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[parent_id] int DEFAULT NULL,
				[name] varchar(255) DEFAULT NULL,
				[description] text,
				[group_access] text,
				[date_added] datetime DEFAULT NULL,
				[date_updated] datetime DEFAULT NULL, 
				CONSTRAINT [PK_workflow_job_categories] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] 
			  
			  
			  
			  CREATE TABLE [fb_workflow_status_types] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[status_name] varchar(255) DEFAULT NULL,
				[status_value] varchar(255) DEFAULT NULL, 
				CONSTRAINT [PK_workflow_status_types] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_targets] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[formboss_job_id] int DEFAULT NULL,
				[formboss_job_name] varchar(255) DEFAULT NULL,
				[target] varchar(255) DEFAULT NULL,
				[target_type] varchar(55) DEFAULT NULL,
				[active] int DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_targets] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_task_master] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[task_originator_user_id] int DEFAULT NULL,
				[workflow_job_id] int DEFAULT NULL,
				[workflow_complete] int DEFAULT '0',
				[ts] datetime DEFAULT NULL,
				[ts_completed] datetime DEFAULT NULL,
				[archived] int DEFAULT '0',
				[was_deleted] int DEFAULT '0',
				[ts_was_deleted] datetime DEFAULT NULL, 
				CONSTRAINT [PK_workflow_task_master] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  
			  
			  
			  CREATE TABLE [fb_workflow_users] (
				[id] [int] IDENTITY(1,1) NOT NULL,
				[fb_user_id] int DEFAULT '-1',
				[name] varchar(255) DEFAULT NULL,
				[password] binary,
				[active] int DEFAULT NULL,
				[permissions] varchar(255) DEFAULT NULL, 
				CONSTRAINT [PK_fb_workflow_users] PRIMARY KEY CLUSTERED 
			  (
				  [id] ASC
			  )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
			  ) ON [PRIMARY]
			  

			  -- Key 

			  ALTER TABLE [dbo].[fb_workflow_jobs]  WITH CHECK ADD  CONSTRAINT [FK_fb_workflow_jobs_fb_jobs] FOREIGN KEY([formboss_job_id])
			  REFERENCES [dbo].[fb_jobs] ([id])
			  ON DELETE CASCADE
			   
			  ALTER TABLE [dbo].[fb_workflow_jobs] CHECK CONSTRAINT [FK_fb_workflow_jobs_fb_jobs]

			  -- Key
			  
			  ALTER TABLE [dbo].[fb_workflow_hooks]  WITH CHECK ADD  CONSTRAINT [FK_fb_workflow_hooks_fb_workflow_jobs] FOREIGN KEY([workflow_job_id])
			  REFERENCES [dbo].[fb_workflow_jobs] ([id])
			  ON DELETE CASCADE

			  ALTER TABLE [dbo].[fb_workflow_hooks] CHECK CONSTRAINT [FK_fb_workflow_hooks_fb_workflow_jobs]
			  
			  -- Key
			  
			  ALTER TABLE [dbo].[fb_workflow_users]  WITH CHECK ADD  CONSTRAINT [FK_fb_workflow_users_fb_admin] FOREIGN KEY([fb_user_id])
			  REFERENCES [dbo].[fb_admin] ([user_id])
			  ON DELETE CASCADE

			  ALTER TABLE [dbo].[fb_workflow_users] CHECK CONSTRAINT [FK_fb_workflow_users_fb_admin]
			  
			  
			  -- Set Default Data.

			  INSERT INTO fb_workflow_job_categories (parent_id, name, description) VALUES ('-1', 'root', 'root category');
			  
			  INSERT INTO fb_workflow_groups (group_name, group_privilege) VALUES ('Workflow Group', '4');	
MSG_EOF;

			
			

			if (Database::pdo_query ( $sql, 1, true )) {
				return;
			} else {
				die;
			}
		}
	

		
		if (Database::pdo_query ( $sql, 1 )) {
				
			
			if (isset ( $sql_2 ) && Database::pdo_query ( $sql_2, 1 )) {
				echo 'Good News! Your Database Has Been Updated To Build 944 - Please refresh this page to start using RackForms again.';
			} else {
	
				if (! isset ( $sql_2 )) {
					echo 'Good News! Your Database Has Been Updated To Build 944 - Please refresh this page to start using RackForms again.';
					return;
				} else {
						
					echo 'Error Updating Database To Build 944. Please Contact support@rackforms.com for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.';
					return;
				}
			}
		} else {
			echo 'Error Updating Database To Build 944. Please Contact support@rackforms.com for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.';
		}
	}


	
	public function update_929(){
	
		
	
		if(!$this->checkConfigWrite()){
			die('In order to use this version of RackForms you must make your /rackforms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.');
		}
	
		$old = '?>';
	
		
		$config_file_raw = file_get_contents('config.php');
	
		
		if(substr_count($config_file_raw, "db_ssl_key") == 0) {
				
			
				
			$add = <<<EOF

// MySQL SSL Support.
\$db_ssl_key = '';
\$db_ssl_certificate = '';
\$db_ssl_ca_cert = '';
\$db_ssl_verify_cert = '';
\$db_ssl_cipher = '';

?>

EOF;
		
			$config_file_raw = str_replace($old, $add, $config_file_raw);
	
			
			file_put_contents('config.php', $config_file_raw);
		
		}
		
		
		
		if(substr_count($config_file_raw, "AUTH_UseSimpleSAML") == 0) {
		
			
		
			$add = <<<EOF
		
// Build 889 - Simple SAML SSO.
define('AUTH_UseSimpleSAML', '0'); // 1 To Use SAML Authentication.
define('SimpleSAML_AuthSource', 'rackforms-sp'); // Auth Source.
define('SimpleSAML_Path', '/../simplesamlphp/lib/_autoload.php'); // Location of the SimpleSAML libraries.
define('SimpleSAML_LogoutReturnTo', 'https://rackforms.baymain.com/logged_out.php'); // Location of a logout redirect.
		
?>

EOF;
		
			$config_file_raw = str_replace($old, $add, $config_file_raw);
		
			
			file_put_contents('config.php', $config_file_raw);
		
		}
		
	
	} 
	
	
	
	public function update_918(){
			
		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
			$sql = 'SHOW COLUMNS FROM fb_jobs';
			$result = Database::pdo_query ( $sql, 0 );
			foreach ( $result as $r ) {
				if (substr_count ( $r ['Field'], 'read_only_user_id' )) {
					
					return;
				}
			}
		} else { 
			$sql = "SELECT read_only_user_id FROM fb_jobs";
			if (Database::pdo_query ( $sql, 1 )) {
				return;
			}
		}
	
		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
			$sql = "ALTER TABLE `fb_jobs`
					ADD COLUMN `read_only_user_id` int(11) AFTER `user_id`;";
		} else { 
			$sql = "ALTER TABLE fb_jobs
					ADD read_only_user_id int";
		}
		
		
		if (Database::pdo_query ( $sql, 1 )) {
	
			echo 'Good News! Your Database Has Been Updated To Build 918 - Please refresh this page to start using RackForms again.';

		} else {
			
			echo 'Error Updating Database To Build 918. Please Contact support@rackforms.com for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.';
		}
	}
	
	
	public function update_910(){
	
		
	
		if(!$this->checkConfigWrite()){
			die('In order to use this version of RackForms you must make your /rackforms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.');
		}
	
		$old = '?>';
	
		
		$config_file_raw = file_get_contents('config.php');
	
		
		if(substr_count($config_file_raw, "AUTH_AD") == 0) {
				
			
				
			$add = <<<EOF

// LDAP / Active Directory Login.
// See: https://www.rackforms.com/documentation/installation/active-directory-login.php
define('AUTH_AD', '0'); // Use AD Authentication.
define('AUTH_AD_LDAP_HOST', ''); // Host Name: e.g. LDAP://corp.sample.com:389
define('AUTH_AD_LDAP_PREFIX', ''); // Prefix: e.g. CORP\\ Note: Be sure to always escape single slashes.
define('AUTH_AD_LDAP_DN', ''); // Distinguished Names: e.g. DC=corp,DC=sample,DC=com
define('AUTH_AD_CUSTOM_LEVEL_GROUP_NAME_VALUE', 7); // The default user privilege level for new users.

?>

EOF;
		
			$config_file_raw = str_replace($old, $add, $config_file_raw);
	
			
			file_put_contents('config.php', $config_file_raw);
		
		}
		
		
		
		if(substr_count($config_file_raw, "AUTH_UseSimpleSAML") == 0) {
		
			
		
			$add = <<<EOF
		
// Build 889 - Simple SAML SSO.
define('AUTH_UseSimpleSAML', '0'); // 1 To Use SAML Authentication.
define('SimpleSAML_AuthSource', 'rackforms-sp'); // Auth Source.
define('SimpleSAML_Path', '/../simplesamlphp/lib/_autoload.php'); // Location of the SimpleSAML libraries.
define('SimpleSAML_LogoutReturnTo', 'https://rackforms.baymain.com/logged_out.php'); // Location of a logout redirect.
		
?>

EOF;
		
			$config_file_raw = str_replace($old, $add, $config_file_raw);
		
			
			file_put_contents('config.php', $config_file_raw);
		
		}
		
	
	} 
	
	
	
	public function update_906(){
			
		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
			$sql = 'SHOW COLUMNS FROM fb_stripe_transactions';
			$result = Database::pdo_query ( $sql, 0 );
			foreach ( $result as $r ) {
				if (substr_count ( $r ['Field'], 'customer' )) {
					
					return;
				}
			}
		} else { 
			$sql = "SELECT customer FROM fb_stripe_transactions";
			if (Database::pdo_query ( $sql, 1 )) {
				return;
			}
		}
	
		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
			$sql = "ALTER TABLE `fb_stripe_transactions`
					ADD COLUMN `customer` TEXT AFTER `date`;";
		} else { 
			$sql = "ALTER TABLE fb_stripe_transactions
					ADD customer text";
		}
		
		if (Database::pdo_query ( $sql, 1 )) {
				
			
			if (isset ( $sql_2 ) && Database::pdo_query ( $sql_2, 1 )) {
				echo 'Good News! Your Database Has Been Updated To Build 906 - Please refresh this page to start using RackForms again.';
			} else {
	
				if (! isset ( $sql_2 )) {
					echo 'Good News! Your Database Has Been Updated To Build 79067 - Please refresh this page to start using RackForms again.';
					return;
				} else {
						
					echo 'Error Updating Database To Build 906. Please Contact support@rackforms.com for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.';
					return;
				}
			}
		} else {
			echo 'Error Updating Database To Build 906. Please Contact support@rackforms.com for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.';
		}
	}
	
	public function update_905() {
	
		
		
		
		$need_table = true;
		
		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
			$sql = "SHOW TABLES LIKE 'fb_audit_user'";
			$result = Database::pdo_query ( $sql, 0 );
			
			if (count ( $result ) != 0) {
				$need_table = false;
			}
		} else {
			$sql = "IF OBJECT_ID('[dbo].[fb_audit_user]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
			
			$result = Database::pdo_query ( $sql, 0 );
			
			if ($result [0] ['status'] == 'true') {
				$need_table = false;
			}
		}
	
		if ($need_table) {
		
			
			
			if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
				
				$sql = "CREATE TABLE `fb_audit_user` (
						  `id` int(11) NOT NULL AUTO_INCREMENT,
						  `user_id` int(11) DEFAULT NULL,
						  `date` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
						  `class` varchar(100) DEFAULT NULL,
						  `action` text,
						  `result` text,
						  `detail` text,
						  PRIMARY KEY (`id`)
						) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;";
				
				Database::pdo_query ( $sql, 0 );
			} else { 
			
				$cat = DB_CATALOG;
				
				$sql = <<<EOT
			BEGIN
				USE [{$cat}];
				END

BEGIN
CREATE TABLE [dbo].[fb_audit_user](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[user_id] [int] NULL,
	[date] [datetime] NULL,
	[class] [varchar](100) NULL,
	[action] [text] NULL,
	[result] [text] NULL,
	[detail] [text] NULL,
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END

EOT;
			
				Database::pdo_query ( $sql, 0 );
			} 
			
		} 
		
		
		
		
		
		$need_table = true;
		
		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
			$sql = "SHOW TABLES LIKE 'fb_jobs_backup'";
			$result = Database::pdo_query ( $sql, 0 );
						
					if (count ( $result ) != 0) {
						$need_table = false;
					}
		} else {
			
			$sql = "IF OBJECT_ID('[dbo].[fb_jobs_backup]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
		
			$result = Database::pdo_query ( $sql, 0 );
						
			if ($result [0] ['status'] == 'true') {
				$need_table = false;

			}
					
		}
		
		if ($need_table) {

			
				
			if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {

			$sql = "CREATE TABLE `fb_jobs_backup` (
			  `id` int(11) NOT NULL AUTO_INCREMENT,
			  `job_name` varchar(50) DEFAULT NULL,
			  `created_ts` varchar(25) NULL,
			  `delete_date` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
			  `job_xml` longtext,
			  `user_id` int(11),	
			  `folder_id` int(11),	
			  PRIMARY KEY (`id`)
			) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;";

			Database::pdo_query ( $sql, 0 );
			
		} else { 
							
			$cat = DB_CATALOG;
	
			$sql = <<<EOT
						BEGIN
						USE [{$cat}];
				END
		
BEGIN
CREATE TABLE [dbo].[fb_jobs_backup](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[job_name] [varchar](50) NULL,
	[created_ts] [varchar](25) NULL,
	[delete_ts] [timestamp] NULL,
	[job_xml] [text] NULL,
	[user_id] [int] NULL,
	[folder_id] [int] NULL,
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END
		
EOT;
		
				Database::pdo_query ( $sql, 0 );
						
			} 
			
		} 
		
		
	}
	
	
	public function update_891(){
	
		
	
		if(!$this->checkConfigWrite()){
			die('In order to use this version of RackForms you must make your /rackforms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.');
		}
	
	
		
		$config_file_raw = file_get_contents('config.php');
	
		
		if(substr_count($config_file_raw, "\$_SESSION['v_string']") == 0) {
			
			
			
			$add = <<<EOF
define('MAGIC_QUOTES_CHECK', 1);
			
\$_SESSION['v_string'] = 'rackforms';
\$_SESSION['v_string_title'] = 'RackForms';
			
EOF;
			
			$old = <<<EOF
define('MAGIC_QUOTES_CHECK', 1);
EOF;
			
			$config_file_raw = str_replace($old, $add, $config_file_raw);
				
			
			file_put_contents('config.php', $config_file_raw);
			
		}	
	
	}
	
	
	
	public function update_883(){
			
		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
			$sql = 'SHOW COLUMNS FROM fb_job_entries_tmp';
			$result = Database::pdo_query ( $sql, 0 );
			foreach ( $result as $r ) {
				if (substr_count ( $r ['Field'], 'file_data' )) {
					
					return;
				}
			}
		} else { 
			$sql = "SELECT file_data FROM fb_job_entries_tmp";
			if (Database::pdo_query ( $sql, 1 )) {
				return;
			}
		}
		
		
		if (DB_TYPE == 'mysql' || DB_TYPE == 'mysqli') {
			$sql = "ALTER TABLE `fb_job_entries_tmp`
					ADD COLUMN `file_data` LONGBLOB AFTER `entry_value`,
					ADD COLUMN `file_mime` VARCHAR(120) AFTER `file_data`,
					ADD COLUMN `file_name` VARCHAR(255) AFTER `file_mime`,
					ADD COLUMN `sig_data` LONGBLOB AFTER `file_name`;";
		} else { 
			$sql = "ALTER TABLE fb_job_entries_tmp
					ADD file_data text,
					file_mime [varchar](120) NULL,
					file_name [varchar](255) NULL,
					sig_data text;";
		}
		
		if (Database::pdo_query ( $sql, 1 )) {
			
			
			if (isset ( $sql ) && Database::pdo_query ( $sql, 1 )) {
				echo 'Good News! Your Database Has Been Updated To Build 883 - Please refresh this page to start using RackForms again.';
			} else {
				
				if (! isset ( $sql )) {
					echo 'Good News! Your Database Has Been Updated To Build 883 - Please refresh this page to start using RackForms again.';
					return;
				} else {
					
					echo 'Error Updating Database To Build 883. Please Contact support@rackforms.com for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.';
					return;
				}
			}
		} else {
			echo 'Error Updating Database To Build 883. Please Contact support@rackforms.com for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.';
		}
	}
	
	
	public function update_866(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_aci_level_1_transactions'";
			$result = Database::pdo_query($sql, 0);
					
			if(count($result) != 0){
				$need_table = false;
			}
			
		} else {
			$sql = "IF OBJECT_ID('[dbo].[fb_aci_level_1_transactions]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
	
			$result = Database::pdo_query($sql, 0);
	
			if($result[0]['status'] == 'true'){
				$need_table = false;
			}
	
		}
	
		if($need_table){
	
			
			
			if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){

				$sql = "CREATE TABLE `fb_aci_level_1_transactions` (
						  `id` int(11) NOT NULL AUTO_INCREMENT,
						  `rf_entry_key` varchar(50) DEFAULT NULL,
						  `uid` varchar(50) DEFAULT NULL,
						  `confirmation` varchar(50) DEFAULT NULL,
						  `email` varchar(100) DEFAULT NULL,
						  `amount` double DEFAULT NULL,
						  `date` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
						  `data` text,
						  `shipping_data` text,
						  `line_items` text,
						  PRIMARY KEY (`id`)
						) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;";
	
				Database::pdo_query($sql, 0);
	
			} else { 
	
				$cat = DB_CATALOG;

				$sql = <<<EOT
					BEGIN
					USE [{$cat}];
					END
	
BEGIN
CREATE TABLE [dbo].[fb_aci_level_1_transactions](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[rf_entry_key] [varchar](50) NULL,
	[uid] [varchar](50) NULL,
	[confirmation] [varchar](50) NULL,
	[email] [varchar](100) NULL,
	[amount] [money] NULL,
	[date] [datetime] NULL,
	[data] [text] NULL,
	[shipping_data] [text] NULL,
	[line_items] [text] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END
	
EOT;
	
				Database::pdo_query($sql, 0);
	
			} 
	
		}
	}
	
	public function update_861(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_payflow_transactions'";
			$result = Database::pdo_query($sql, 0);
					
				if(count($result) != 0){
				$need_table = false;
				}
				} else {
				$sql = "IF OBJECT_ID('[dbo].[fb_payflow_transactions]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
	
			$result = Database::pdo_query($sql, 0);
	
				if($result[0]['status'] == 'true'){
				$need_table = false;
				}
	
				}
	
				if($need_table){
	
				
					if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
	
					$sql = "CREATE TABLE `fb_payflow_transactions` (
							  `id` int(11) NOT NULL AUTO_INCREMENT,
							  `rf_entry_key` varchar(50) DEFAULT NULL,
							  `PNREF` varchar(50) DEFAULT NULL,
							  `ACCT` int(11) DEFAULT NULL,
							  `result` varchar(50) DEFAULT NULL,
							  `email` varchar(100) DEFAULT NULL,
							  `amount` double DEFAULT NULL,
							  `date` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
							  `data` text,
							  `shipping_data` text,
							  `line_items` text,
							  `subscription_data` text,
							  `trial_data` text,
							  `profile_id` varchar(50) DEFAULT NULL,
							  `profile_status` varchar(50) DEFAULT NULL,
							  PRIMARY KEY (`id`)
							) ENGINE=InnoDB DEFAULT CHARSET=utf8;";
	
				Database::pdo_query($sql, 0);
						
					} else { 
						
					$cat = DB_CATALOG;
	
					$sql = <<<EOT
					BEGIN
					USE [{$cat}];
			END
	
BEGIN
CREATE TABLE [dbo].[fb_payflow_transactions](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[rf_entry_key] [varchar](50) NULL,
	[PNREF] [varchar](50) NULL,
	[ACCT] [int] NULL	
	[result] [varchar](50) NULL,
	[email] [varchar](100) NULL,
	[amount] [money] NULL,
	[date] [datetime] NULL,
	[data] [text] NULL,
	[shipping_data] [text] NULL,
	[line_items] [text] NULL,
	[subscription_data] [text] NULL,
	[trial_data] [text] NULL,
	[profile_id] [text] NULL,
	[profile_status] [text] NULL,	
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END

EOT;
	
				Database::pdo_query($sql, 0);
	
			} 
	
		}
	}
    
    
	public function update_842(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_reports'";
			$result = Database::pdo_query($sql, 0);
			
			if(count($result) != 0){
				$need_table = false;
			}	
		} else {
			$sql = "IF OBJECT_ID('[dbo].[fb_reports]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
		
			$result = Database::pdo_query($sql, 0);
				
			if($result[0]['status'] == 'true'){
				$need_table = false;
			}
	
		}
	
		if($need_table){
	
		
			if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
				
				$sql = "CREATE TABLE IF NOT EXISTS `fb_reports` (
						  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
						  `user_id` int(11) DEFAULT NULL,
						  `report_title` varchar(255) DEFAULT NULL,
						  `report_data` longtext,
						  PRIMARY KEY (`id`)
						) ENGINE=InnoDB DEFAULT CHARSET=utf8;";
	
				Database::pdo_query($sql, 0);
			
		} else { 
			
			$cat = DB_CATALOG;
				
			$sql = <<<EOT
			BEGIN
			USE [{$cat}];
			END
	
			BEGIN
CREATE TABLE [dbo].[fb_reports](
[id] [int] IDENTITY(1,1) NOT NULL,
[user_id] [int] NULL,
[report_title] [varchar](255) NULL,
[report_data] [text] NULL
) ON [PRIMARY]
END
EOT;
	
				Database::pdo_query($sql, 0);
	
			} 
	
		}
	}
	
    
    
	public function update_805(){
				
		$need_table = true;
	
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_analytics'";
			$result = Database::pdo_query($sql, 0);
				if(count($result) != 0){
				    $need_table = false;
		        }
		} else { 
			$sql = "IF OBJECT_ID('[dbo].[fb_analytics]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
		
			$result = Database::pdo_query($sql, 0);
				
			if($result[0]['status'] == 'true'){
					$need_table = false;
		    }
	
		}
	
		if($need_table){
	
            
			if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
	
			$sql = "CREATE TABLE `fb_analytics` (
                    `id` INT(11) NOT NULL AUTO_INCREMENT,
                    `job_id` INT(11) NOT NULL,
                    `ts` DATETIME DEFAULT NULL,
                    `page_title` VARCHAR(255) DEFAULT NULL,
                    `page_type` VARCHAR(25) DEFAULT NULL,
                    `entry_key` VARCHAR(50) DEFAULT NULL,
                    `remote_ip` VARCHAR(50) DEFAULT NULL,
                    PRIMARY KEY  (`id`),
                    INDEX index1 USING BTREE (`job_id`),
                    INDEX IDX_ts USING BTREE (`ts`),
                    INDEX IDX_entry_key USING BTREE (`entry_key`),
                    CONSTRAINT `fb_analytics_FK1` FOREIGN KEY (`job_id`) REFERENCES `fb_jobs` (`id`) ON DELETE CASCADE
                ) ENGINE=INNODB CHARSET=utf8 COLLATE utf8_general_ci;";
	
				Database::pdo_query($sql, 0);
			
            } else { 
			
                $cat = DB_CATALOG;

                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN
                    CREATE TABLE [dbo].[fb_analytics](
	                [id] [int] IDENTITY(1,1) NOT NULL,
	                [job_id] [int] NOT NULL,
	                [ts] [datetime] NULL,
	                [page_title] [varchar](255) NULL,
	                [page_type] [varchar](25) NULL,
	                [entry_key] [varchar](50) NULL,
	                [remote_ip] [varchar](50) NULL,
                 CONSTRAINT [PK_fb_analytics] PRIMARY KEY CLUSTERED 
                (
	                [id] ASC
                )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
                ) ON [PRIMARY]
                END
EOT;
	
				Database::pdo_query($sql, 0);
                
                

                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN
                    ALTER TABLE [dbo].[fb_analytics]  WITH CHECK ADD  CONSTRAINT [FK_fb_analytics_fb_jobs] FOREIGN KEY([job_id])
                    REFERENCES [dbo].[fb_jobs] ([id])
                    ON DELETE CASCADE
                    END
EOT;
	
				Database::pdo_query($sql, 0);
            
                
                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN

                    ALTER TABLE [dbo].[fb_analytics] CHECK CONSTRAINT [FK_fb_analytics_fb_jobs]

                    END
EOT;
	
				Database::pdo_query($sql, 0);

            } 
	
		} 

	}
    
    public function update_801(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_api_manager'";
			$result = Database::pdo_query($sql, 0);
				if(count($result) != 0){
				    $need_table = false;
		        }
		} else { 
			$sql = "IF OBJECT_ID('[dbo].[fb_api_manager]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
		
			$result = Database::pdo_query($sql, 0);
				
			if($result[0]['status'] == 'true'){
					$need_table = false;
		    }
	
		}
	
		if($need_table){
	
            
			if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
	
			$sql = "CREATE TABLE `fb_api_manager` (
					  `id` int(11) NOT NULL DEFAULT '0',
					  `user_id` int(11) DEFAULT NULL,
					  `data` longblob,
					  `created` datetime DEFAULT NULL,
					  `last_accessed` datetime DEFAULT NULL,
					  PRIMARY KEY (`id`),
					  KEY `RackForms_api_manager_KEY` (`user_id`),
					  CONSTRAINT `FK_RackForms_api_manager_FK` FOREIGN KEY (`user_id`) REFERENCES `fb_admin` (`user_id`) ON DELETE CASCADE
					) ENGINE=InnoDB DEFAULT CHARSET=utf8;";
	
				Database::pdo_query($sql, 0);
			
            } else { 
			
                $cat = DB_CATALOG;

                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN

                    CREATE TABLE [dbo].[fb_api_manager](
                    [id] [int] IDENTITY(1,1) NOT NULL,
                    [user_id] [int] NULL,
                    [data] [image] NULL,
                    [created] [datetime] NULL,
                    [last_accessed] [datetime] NULL,
                    CONSTRAINT [PK_fb_api_manager] PRIMARY KEY CLUSTERED 
                    (
                    [id] ASC
                    )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
                    ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
END
EOT;
	
				Database::pdo_query($sql, 0);
                
                

                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN

                    ALTER TABLE [dbo].[fb_api_manager]  WITH CHECK ADD  CONSTRAINT [FK_fb_api_manager_fb_admin] FOREIGN KEY([user_id])
                    REFERENCES [dbo].[fb_admin] ([user_id])
                    ON DELETE CASCADE

                    END
EOT;
	
				Database::pdo_query($sql, 0);
            
                
                $sql = <<<EOT
                    BEGIN
                    USE [{$cat}];
                    END

                    BEGIN

                    ALTER TABLE [dbo].[fb_api_manager] CHECK CONSTRAINT [FK_fb_api_manager_fb_admin]

                    END
EOT;
	
				Database::pdo_query($sql, 0);

            } 
	
		} 
        
	}
	
	
	public function update_775(){
	
		
		
		
	
		$need_table = true;
	
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_aim_transactions'";
			$result = Database::pdo_query($sql, 0);
				if(count($result) != 0){
				$need_table = false;
		}
		} else { 
			$sql = "IF OBJECT_ID('[dbo].[fb_aim_transactions]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
		
			$result = Database::pdo_query($sql, 0);
				
			if($result[0]['status'] == 'true'){
					$need_table = false;
		}
	
		}
	
		if($need_table){
	
		
			if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
	
			$sql = "CREATE TABLE IF NOT EXISTS fb_aim_transactions(
						  id INT(11) NOT NULL AUTO_INCREMENT,
						  rf_entry_key VARCHAR(50) DEFAULT NULL,
						  transaction_id VARCHAR(50) DEFAULT NULL,
						  amount INT(11) DEFAULT NULL,
						  `date` TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP,
						  `data` TEXT DEFAULT NULL,
						  shipping_data TEXT DEFAULT NULL,
						  line_items TEXT DEFAULT NULL,
						  subscription_data TEXT DEFAULT NULL,
						  trail_data TEXT DEFAULT NULL,
						  PRIMARY KEY (id)
						)
						ENGINE = INNODB
						AUTO_INCREMENT = 1
						AVG_ROW_LENGTH = 8192
						CHARACTER SET utf8
						COLLATE utf8_general_ci;";
	
				Database::pdo_query($sql, 0);
			
		} else { 
			
		$cat = DB_CATALOG;
			
		$sql = <<<EOT
			BEGIN
			USE [{$cat}];
			END
	
			BEGIN
	
			CREATE TABLE [dbo].[fb_aim_transactions](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[rf_entry_key] [varchar](50) NULL,
	[transaction_id] [varchar](50) NULL,
	[amount] [int] NULL,
	[date] [datetime] NULL,
	[data] [text] NULL,
	[shipping_data] [text] NULL,
	[line_items] [text] NULL,
	[subscription_data] [text] NULL,
	[trial_data] [text] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
	
END
EOT;
	
				Database::pdo_query($sql, 0);
	
		} 
	
		}
	}
	
	
	public function update_770(){
				
		
		
		
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = 'SHOW COLUMNS FROM fb_stripe_transactions';
			$result = Database::pdo_query($sql, 0);
			foreach($result as $r){
				if(substr_count($r['Field'], 'email')){
					
					return;
				}
			}
		} else { 
			$sql = "SELECT email FROM fb_stripe_transactions";
			if(Database::pdo_query($sql, 1)){
				return;
			}
		}
		

		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "ALTER TABLE `fb_stripe_transactions` 
					ADD COLUMN `email` VARCHAR(100) AFTER `charge_id`;";
		} else { 
			$sql = "ALTER TABLE fb_stripe_transactions 
					ADD email VARCHAR(100);";
		}
		
		if(Database::pdo_query($sql, 1)){
			
			
			if(isset($sql_2) && Database::pdo_query($sql_2, 1)){
				echo 'Good News! Your Database Has Been Updated To Build 770 - Please refresh this page to start using RackForms again.';
			
			} else {
				
				if(!isset($sql_2)){
					echo 'Good News! Your Database Has Been Updated To Build 770 - Please refresh this page to start using RackForms again.';
					return;
				} else {

					echo 'Error Updating Database To Build 770. Please Contact support@rackforms.com for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.';
					return;
					
				}
					
			}

		} else {
			echo 'Error Updating Database To Build 770. Please Contact support@rackforms.com for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.';
		}

	}
	
	
	public function update_767(){
				
		
		
		
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = 'SHOW COLUMNS FROM fb_stripe_transactions';
			$result = Database::pdo_query($sql, 0);
			foreach($result as $r){
				if(substr_count($r['Field'], 'line_items')){
					
					return;
				}
			}
		} else { 
			$sql = "SELECT line_items FROM fb_stripe_transactions";
			if(Database::pdo_query($sql, 1)){
				return;
			}
		}
		

		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "ALTER TABLE `fb_stripe_transactions` 
					ADD COLUMN `line_items` TEXT AFTER `shipping_data`;";
		} else { 
			$sql = "ALTER TABLE fb_stripe_transactions 
					ADD line_items text;";
		}
		
		if(Database::pdo_query($sql, 1)){
			
			
			if(isset($sql_2) && Database::pdo_query($sql_2, 1)){
				echo 'Good News! Your Database Has Been Updated To Build 767 - Please refresh this page to start using RackForms again.';
			
			} else {
				
				if(!isset($sql_2)){
					echo 'Good News! Your Database Has Been Updated To Build 767 - Please refresh this page to start using RackForms again.';
					return;
				} else {

					echo 'Error Updating Database To Build 767. Please Contact support@rackforms.com for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.';
					return;
					
				}
					
			}

		} else {
			echo 'Error Updating Database To Build 767. Please Contact support@rackforms.com for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.';
		}

	}
	
	public function update_766(){
		
		
		
		
		
		$need_table = true;
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_stripe_transactions'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				$need_table = false;
			}
		} else { 
			$sql = "IF OBJECT_ID('[dbo].[fb_stripe_transactions]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0]['status'] == 'true'){
				$need_table = false;
			}

		}
		
		if($need_table){
		
			
			if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
				
				$sql = "CREATE TABLE IF NOT EXISTS fb_stripe_transactions(
						  id INT(11) NOT NULL AUTO_INCREMENT,
						  rf_entry_key VARCHAR(50) DEFAULT NULL,
						  charge_id VARCHAR(50) DEFAULT NULL,
						  amount INT(11) DEFAULT NULL,
						  `date` TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP,
						  `data` TEXT DEFAULT NULL,
						  shipping_data TEXT DEFAULT NULL,
						  line_items TEXT DEFAULT NULL,
						  subscription_data TEXT DEFAULT NULL,
						  trail_data TEXT DEFAULT NULL,
						  PRIMARY KEY (id)
						)
						ENGINE = INNODB
						AUTO_INCREMENT = 1
						AVG_ROW_LENGTH = 8192
						CHARACTER SET utf8
						COLLATE utf8_general_ci;";
				
				Database::pdo_query($sql, 0);
			
			} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_stripe_transactions](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[rf_entry_key] [varchar](50) NULL,
	[charge_id] [varchar](50) NULL,
	[amount] [int] NULL,
	[date] [datetime] NULL,
	[data] [text] NULL,
	[shipping_data] [text] NULL,
	[line_items] [text] NULL,
	[subscription_data] [text] NULL,
	[trial_data] [text] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

END
EOT;

				Database::pdo_query($sql, 0);
	
			} 
		
		}
	}
	
	
	public function update_762(){
		
		
		
		
		
		$need_table = true;
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_job_folders'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				$need_table = false;
			}
		} else { 
			$sql = "IF OBJECT_ID('[dbo].[fb_job_folders]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0]['status'] == 'true'){
				$need_table = false;
			}

		}
		
		if($need_table){
		
			
			if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
				
				$sql = "CREATE TABLE rackforms.fb_job_folders(
						  f_id INT(11) NOT NULL AUTO_INCREMENT,
						  name VARCHAR(255) DEFAULT NULL,
						  PRIMARY KEY (f_id)
						)
						ENGINE = INNODB
						AUTO_INCREMENT = 1
						CHARACTER SET utf8
						COLLATE utf8_general_ci;";
				
				Database::pdo_query($sql, 0);
			
			} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_job_folders](
	[f_id] [int] IDENTITY(1,1) NOT NULL,
	[name] [varchar](100) NULL
) ON [PRIMARY]

END
EOT;

				Database::pdo_query($sql, 0);
	
			} 
		
		}
		
		
		
		
		
		
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = 'SHOW COLUMNS FROM fb_jobs';
			$result = Database::pdo_query($sql, 0);
			foreach($result as $r){
				if(substr_count($r['Field'], 'folder_id')){
					
					return;
				}
			}
		} else { 
			$sql = "SELECT folder_id FROM fb_jobs";
			if(Database::pdo_query($sql, 1)){
				return;
			}
		}
		

		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "ALTER TABLE `fb_jobs` 
					ADD COLUMN `folder_id` INT(11) DEFAULT 0 AFTER `job_xml`;";
		} else { 
			$sql = "ALTER TABLE fb_jobs 
					ADD folder_id INT(11);";
			
			$sql_2 = "ALTER TABLE [dbo].[fb_jobs] ADD  CONSTRAINT [DF_fb_jobs_folder_id]  DEFAULT ((0)) FOR [folder_id]";
		}
		
		if(Database::pdo_query($sql, 1)){
			
			
			if(isset($sql_2) && Database::pdo_query($sql_2, 1)){
				echo 'Good News! Your Database Has Been Updated To Build 762 - Please refresh this page to start using RackForms again.';
			
			} else {
				
				if(!isset($sql_2)){
					echo 'Good News! Your Database Has Been Updated To Build 762 - Please refresh this page to start using RackForms again.';
					return;
				} else {

					echo 'Error Updating Database To Build 762. Please Contact support@rackforms.com for more help.<br/>
						Before you do though, please open your app/config.php file and temporarily change the line:<br/>
						define(\'DEBUG\', \'0\');<br/>
						to be:<br/>
						define(\'DEBUG\', \'1\');<br/>
						and run this page again. Then copy any messages you get into the email you send.';
					return;
					
				}
					
			}

		} else {
			echo 'Error Updating Database To Build 762. Please Contact support@rackforms.com for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.';
		}

	}
	
	public function update_754(){
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_digital_signatures'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				return;
			}
		} else { 
			$sql = "IF OBJECT_ID('[dbo].[fb_digital_signatures]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0]['status'] == 'true'){
				return;
			}

		}
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			
			$sql = "CREATE TABLE fb_digital_signatures(
					  id INT(11) NOT NULL AUTO_INCREMENT,
					  entry_id VARCHAR(255) DEFAULT NULL,
					  field_id VARCHAR(255) DEFAULT NULL,
					  signator VARCHAR(255) DEFAULT NULL,
					  signature TEXT DEFAULT NULL,
					  signature_image LONGBLOB DEFAULT NULL,
					  sig_hash VARCHAR(128) DEFAULT NULL,
					  ip VARCHAR(46) DEFAULT NULL,
					  created INT(11) DEFAULT NULL,
					  PRIMARY KEY (id)
					)
					ENGINE = INNODB
					AUTO_INCREMENT = 1
					CHARACTER SET utf8
					COLLATE utf8_general_ci;";
			
			Database::pdo_query($sql, 0);
			
		} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_digital_signatures](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[entry_id] [varchar](255) NULL,
	[field_id] [varchar](255) NULL,
	[signator] [varchar](255) NULL,
	[signature] [text] NULL,
	[signature_image] [image] NULL,
	[sig_hash] [varchar](128) NULL,
	[ip] [varchar](48) NULL,
	[created] [int] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

END
EOT;

			Database::pdo_query($sql, 0);

		} 
			
			
			
			
			echo '<div style="background-color: Yellow; height: 30px; padding-top:10px">&nbsp;&nbsp;&nbsp;&nbsp;Your Database Has Been Updated To Build 754 - Please Refresh The Page To Finish This Process.</div>';

		
	}
	
	
	public function update_707(){
		
		
		$sql = "SELECT option_name FROM fb_options WHERE option_name = 'load_a_saved_job_sort'";
		$result = Database::pdo_query($sql, 0);
		if(count($result) != 0){
			return;
		}	
		
		
	
		$sql = "INSERT INTO fb_options (option_name, option_value, option_version) VALUES ('load_a_saved_job_sort', 'id,DESC', '707');";
		
		Database::pdo_query($sql, 0);

		
		
		
		echo 'RackForms First Run Message: - Your RackForms Database Has Been Updated With New Settings - Please Refresh This Page To Start Using RackForms Again.';
		
	}
	
	
	public function update_705(){
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_options'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				return;
			}
		} else { 
			$sql = "IF OBJECT_ID('[dbo].[fb_options]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0]['status'] == 'true'){
				return;
			}

		}
		
		
		
		
		if(!$this->checkConfigWrite()){
			die('In order to use this version of RackForms you must make your /RackForms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.');
		}
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			
			$sql = "CREATE TABLE fb_options(
					  option_name VARCHAR(255) DEFAULT NULL,
					  option_value TEXT DEFAULT NULL,
					  option_version INT(11) DEFAULT NULL
					)
					ENGINE = INNODB
					CHARACTER SET utf8
					COLLATE utf8_general_ci;";
			
			Database::pdo_query($sql, 0);
			
		} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_options](
	[option_name] [varchar](255) NULL,
	[option_value] [text] NULL,
	[option_version] [int] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

END
EOT;

			Database::pdo_query($sql, 0);

		} 
		


			
			$config_file_raw = file_get_contents('config.php');			

			
			$newfile = $config_file_raw;
			
			
			$datetime = date('Y-m-d  H:i:s', time());
			$replace = "// UPDATE - 705 :: {$datetime}\n?>";
			$newfile = str_replace('?>', $replace, $newfile);
			
			
			file_put_contents('config.php', $newfile);
			
			
			
			
			echo ' - Your Database and Config File Has Been Updated To Build 705 - Please Refresh This Page To Start Using RackForms Again.';

		
	}
	
	
	
	public function update_700(){
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "SHOW TABLES LIKE 'fb_formblocks'";
			$result = Database::pdo_query($sql, 0);
			if(count($result) != 0){
				return;
			}
		} else { 
			$sql = "IF OBJECT_ID('[dbo].[fb_formblocks]') IS NOT NULL SELECT 'true' AS status; ELSE SELECT 'false' AS status ";
			
			$result = Database::pdo_query($sql, 0);
			
			if($result[0]['status'] == 'true'){
				return;
			}

		}
		
		
		
		
		if(!$this->checkConfigWrite()){
			die('In order to use this version of RackForms you must make your /RackForms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.');
		}
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			
			$sql = "CREATE TABLE fb_formblocks(
						id INT(11) NOT NULL AUTO_INCREMENT,
						user_id INT(11) DEFAULT NULL,
						name VARCHAR(255) DEFAULT NULL,
						category VARCHAR(255) DEFAULT NULL,
						description VARCHAR(255) DEFAULT NULL,
						layout VARCHAR(255) DEFAULT NULL,
						pagetype INT(11) DEFAULT NULL,
						content LONGTEXT DEFAULT NULL,
						PRIMARY KEY (id)
					)
					ENGINE = INNODB
					AUTO_INCREMENT = 1
					AVG_ROW_LENGTH = 6553
					CHARACTER SET utf8
					COLLATE utf8_general_ci;";
			
			Database::pdo_query($sql, 0);
			
		} else { 
			
			$cat = DB_CATALOG;
			
			$sql = <<<EOT
BEGIN
USE [{$cat}];
END

BEGIN

CREATE TABLE [dbo].[fb_formblocks](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[user_id] [int] NULL,
	[name] [varchar](255) NULL,
	[category] [varchar](255) NULL,
	[description] [varchar](255) NULL,
	[layout] [varchar](255) NULL,
	[pagetype] [int] NULL,
	[content] [text] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

END
EOT;

			Database::pdo_query($sql, 0);

		} 
		
		
			

			
			$config_file_raw = file_get_contents('config.php');			
			
			$new_config_data = <<<EOF
define('ENCODE_PW', 1);

// Build 700 - Add the values below to block that module from loading into the editor.
\$excluded_form_modules = array(''); // Use: ecomm to block the ecomm module from loading in the editor.
\$excluded_confirmation_modules = array(''); // Use: confirm-ecomm to block the ecomm confirmation module.
EOF;

			
			$newfile = $config_file_raw;
			
			
			$newfile = str_replace("define('ENCODE_PW', 1);", $new_config_data, $newfile);
			
			
			$datetime = date('Y-m-d  H:i:s', time());
			$replace = "// UPDATE - 700 :: {$datetime}\n?>";
			$newfile = str_replace('?>', $replace, $newfile);
			
			
			file_put_contents('config.php', $newfile);
			
			
			
			
			echo ' - Your Database and Config File Has Been Updated To Build 700 - Please Refresh This Page To Start Using RackForms Again.';

		
	}
	
	
	
	public function update_638(){
		
		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = 'SHOW COLUMNS FROM fb_jobs';
			$result = Database::pdo_query($sql, 0);
			foreach($result as $r){
				if(substr_count($r['Field'], 'created_ts')){
					
					return;
				}
			}
		} else { 
			$sql = "SELECT created_ts FROM fb_jobs";
			if(Database::pdo_query($sql, 1)){
				return;
			}
		}
		
		
		if(!$this->checkConfigWrite()){
			die('In order to use this version of RackForms you must make your /RackForms/app/config.php file writeable.<br/>
				Once you do this an automatic update will be performed and you can then use RackForms again.');
		}

		
		$config_file_raw = file_get_contents('config.php');

		
		if(DB_TYPE == 'mysql' || DB_TYPE == 'mysqli'){
			$sql = "ALTER TABLE `fb_jobs` 
					ADD COLUMN `created_ts` DATETIME AFTER `created`,
					ADD COLUMN `last_edit_ts` DATETIME AFTER `last_edit`;";
		} else { 
			$sql = "ALTER TABLE fb_jobs 
					ADD created_ts DATETIME, last_edit_ts DATETIME;";
		}
		
		if(Database::pdo_query($sql, 1)){
			
			$newfile = $config_file_raw;
			$datetime = date('Y-m-d  H:i:s', time());
			$replace = "// UPDATE - 638 :: {$datetime}\n?>";
			$newfile = str_replace('?>', $replace, $newfile);
			file_put_contents('config.php', $newfile);
			echo 'Good News! Your Database Has Been Updated To Build 638 - Please refresh this page to start using RackForms again.';
		} else {
			echo 'Error Updating Database To Build 638. Please Contact support@rackforms.com for more help.<br/>
					Before you do though, please open your app/config.php file and temporarily change the line:<br/>
					define(\'DEBUG\', \'0\');<br/>
					to be:<br/>
					define(\'DEBUG\', \'1\');<br/>
					and run this page again. Then copy any messages you get into the email you send.';
		}

	}
	
	
	
	
	
	
	public function checkConfigWrite(){
		return is_writable('config.php');
	}
	
} 
?>')); ?>

Function Calls

base64_decode 1

Variables

None

Stats

MD5 c3fcb71d5dbb8be70cfaf17c49936cc5
Eval Count 1
Decode Time 225 ms