276 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			276 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/*********************************************************************************
 | 
						|
 *
 | 
						|
 * TimeTrex is a Workforce Management program developed by
 | 
						|
 * TimeTrex Software Inc. Copyright (C) 2003 - 2021 TimeTrex Software Inc.
 | 
						|
 *
 | 
						|
 * This program is free software; you can redistribute it and/or modify it under
 | 
						|
 * the terms of the GNU Affero General Public License version 3 as published by
 | 
						|
 * the Free Software Foundation with the addition of the following permission
 | 
						|
 * added to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED
 | 
						|
 * WORK IN WHICH THE COPYRIGHT IS OWNED BY TIMETREX, TIMETREX DISCLAIMS THE
 | 
						|
 * WARRANTY OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
 | 
						|
 *
 | 
						|
 * This program is distributed in the hope that it will be useful, but WITHOUT
 | 
						|
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 | 
						|
 * FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more
 | 
						|
 * details.
 | 
						|
 *
 | 
						|
 *
 | 
						|
 * You should have received a copy of the GNU Affero General Public License along
 | 
						|
 * with this program; if not, see http://www.gnu.org/licenses or write to the Free
 | 
						|
 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
 | 
						|
 * 02110-1301 USA.
 | 
						|
 *
 | 
						|
 *
 | 
						|
 * You can contact TimeTrex headquarters at Unit 22 - 2475 Dobbin Rd. Suite
 | 
						|
 * #292 West Kelowna, BC V4T 2E9, Canada or at email address info@timetrex.com.
 | 
						|
 *
 | 
						|
 *
 | 
						|
 * The interactive user interfaces in modified source and object code versions
 | 
						|
 * of this program must display Appropriate Legal Notices, as required under
 | 
						|
 * Section 5 of the GNU Affero General Public License version 3.
 | 
						|
 *
 | 
						|
 *
 | 
						|
 * In accordance with Section 7(b) of the GNU Affero General Public License
 | 
						|
 * version 3, these Appropriate Legal Notices must retain the display of the
 | 
						|
 * "Powered by TimeTrex" logo. If the display of the logo is not reasonably
 | 
						|
 * feasible for technical reasons, the Appropriate Legal Notices must display
 | 
						|
 * the words "Powered by TimeTrex".
 | 
						|
 *
 | 
						|
 ********************************************************************************/
 | 
						|
 | 
						|
require_once( dirname( __FILE__ ) . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'includes' . DIRECTORY_SEPARATOR . 'global.inc.php' );
 | 
						|
require_once( dirname( __FILE__ ) . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'includes' . DIRECTORY_SEPARATOR . 'CLI.inc.php' );
 | 
						|
 | 
						|
//Examples:
 | 
						|
//  To add a background event to a notification, include a JSON payload and an array of events under the timetrex key.
 | 
						|
//  Below are a few example payloads to trigger background events.
 | 
						|
 | 
						|
//  **Send notification that launches In/Out view with pre-populated data for a break and out punch. No notification is saved.**
 | 
						|
//  Payload:   {"timetrex":{"event":[{"type":"open_view","action":"edit","view_name":"InOut","data":{"type_id":30,"status_id":20}}]}}
 | 
						|
//  Type:      open_view
 | 
						|
//  View_name: InOut
 | 
						|
//  Action:    edit // edit, add, view
 | 
						|
//  Data:      {"type_id":30,"status_id":20}
 | 
						|
//  Full Command: send_push_notification.php -api_key <key> -user_id <UUID> -type_id system -device_id 4 -payload '{"timetrex":{"event":[{"type":"open_view","action":"edit","view_name":"InOut","data":{"type_id":30,"status_id":20}}]}}'
 | 
						|
 | 
						|
//  **Send notification that opens MyAccount -> Request, Add. No notification is saved.**
 | 
						|
//  Payload:   {"timetrex":{"event":[{"type":"open_view","action":"edit","view_name":"Contact Information","data":{}}]}}
 | 
						|
//  Type:      open_view
 | 
						|
//  View_name: Request
 | 
						|
//  Action:    add // edit, add, view
 | 
						|
//  Data:      {}
 | 
						|
//  Full Command: send_push_notification.php -api_key <key> -user_id <UUID> -type_id system -device_id 4 -payload '{"timetrex":{"event":[{"type":"open_view","action":"add","view_name":"Request","data":{"type_id":30}}]}}'
 | 
						|
 | 
						|
//  **Send notification that opens MyAccount -> Contact Information. No notification is saved.**
 | 
						|
//  Payload:   {"timetrex":{"event":[{"type":"open_view","action":"edit","view_name":"Contact Information","data":{}}]}}
 | 
						|
//  Type:      open_view
 | 
						|
//  View_name: Contact Information
 | 
						|
//  Action:    edit // edit, add, view
 | 
						|
//  Data:      {}
 | 
						|
//  Full Command: send_push_notification.php -api_key <key> -user_id <UUID> -type_id system -device_id 4 -payload '{"timetrex":{"event":[{"type":"open_view","action":"edit","view_name":"Contact Information","data":{}}]}}'
 | 
						|
 | 
						|
//  **Send notification that redirects to a URL**
 | 
						|
//  Payload:   {"timetrex":{"event":[{"ask":1,"text":"Sending you to google.","link":"https://www.google.com/"}]}}
 | 
						|
//  Ask:       1 // 0=dont ask, 1=ask (If user receives a prompt)
 | 
						|
//  Text:      Sending you to google. //Any text if user is getting an ask prompt.
 | 
						|
//  Link:      https://www.google.com/
 | 
						|
//  Full Command: send_push_notification.php -api_key <key> -user_id <UUID> -type_id system -device_id 4 -payload '{"timetrex":{"event":[{"type":"redirect","ask":1,"text":"Sending you to google.","link":"https://www.google.com/"}]}}'
 | 
						|
 | 
						|
//  **Send a system notification with a title/body for "System going down for maintenance at 4PM".**
 | 
						|
//  No payload required.
 | 
						|
//  Full Command: send_push_notification.php -api_key <key> -user_id <UUID> -type_id system -device_id 4 -title_short 'System Maintenance' -body_short 'System going down for maintenance at 4PM'
 | 
						|
 | 
						|
//  send_push_notification.php -api_key <key> -user_id <UUID> -type_id system -device_id 4 -payload ""
 | 
						|
if ( $argc < 2 || in_array( $argv[1], [ '--help', '-help', '-h', '-?' ] ) ) {
 | 
						|
	$help_output = "Usage: send_push_notification.php [OPTIONS]\n";
 | 
						|
	$help_output .= "\n";
 | 
						|
	$help_output .= "  Options:\n";
 | 
						|
	$help_output .= "    -server <URL>				URL to API server\n";
 | 
						|
	$help_output .= "    -username <username>		API username\n";
 | 
						|
	$help_output .= "    -password <password>		API password\n";
 | 
						|
	$help_output .= "    -api_key <key>				API key to use instead of username/password\n";
 | 
						|
	$help_output .= "    -user_id <user_id>		    Destination Employee\n";
 | 
						|
	$help_output .= "    -type_id <type_id>		    Type (ie: system)\n";
 | 
						|
	$help_output .= "    -object_type_id <object_type_id>		Object Type ID (ie: 0=System)\n";
 | 
						|
	$help_output .= "    -object_id <object_id>		Object ID\n";
 | 
						|
	$help_output .= "    -title_short <title>		Title (Short)\n";
 | 
						|
	$help_output .= "    -title_long <title>		Title (Long)\n";
 | 
						|
	$help_output .= "    -body_short <body>		    Body (Short)\n";
 | 
						|
	$help_output .= "    -body_long <body>		    Body (Long)\n";
 | 
						|
	$help_output .= "    -priority <priority>		Priority (ie: 1=Critical, 2=High, 5=Normal, 10=Low)\n";
 | 
						|
	$help_output .= "    -device_id <device_id>		Devices (ie: 4=Web Browser, 256=Work Email, 512=Home Email, 32768=App)\n";
 | 
						|
	$help_output .= "    -payload <payload>         (Optional) Raw Payload in JSON format\n";
 | 
						|
 | 
						|
	echo $help_output;
 | 
						|
} else {
 | 
						|
	//Handle command line arguments
 | 
						|
	$last_arg = count( $argv ) - 1;
 | 
						|
 | 
						|
	if ( in_array( '-server', $argv ) ) {
 | 
						|
		$api_url = trim( $argv[( array_search( '-server', $argv ) + 1 )] );
 | 
						|
	} else {
 | 
						|
		$api_url = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-username', $argv ) ) {
 | 
						|
		$username = trim( $argv[( array_search( '-username', $argv ) + 1 )] );
 | 
						|
	} else {
 | 
						|
		$username = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-password', $argv ) ) {
 | 
						|
		$password = trim( $argv[( array_search( '-password', $argv ) + 1 )] );
 | 
						|
	} else {
 | 
						|
		$password = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-api_key', $argv ) ) {
 | 
						|
		$api_key = trim( $argv[array_search( '-api_key', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$api_key = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-user_id', $argv ) ) {
 | 
						|
		$user_id = trim( $argv[array_search( '-user_id', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$user_id = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-type_id', $argv ) ) {
 | 
						|
		$type_id = trim( $argv[array_search( '-type_id', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$type_id = 'system';
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-object_type_id', $argv ) ) {
 | 
						|
		$object_type_id = trim( $argv[array_search( '-object_type_id', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$object_type_id = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-object_id', $argv ) ) {
 | 
						|
		$object_id = trim( $argv[array_search( '-object_id', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$object_id = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-title_short', $argv ) ) {
 | 
						|
		$title_short = trim( $argv[array_search( '-title_short', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$title_short = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-title_long', $argv ) ) {
 | 
						|
		$title_long = trim( $argv[array_search( '-title_long', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$title_long = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-body_short', $argv ) ) {
 | 
						|
		$body_short = trim( $argv[array_search( '-body_short', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$body_short = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-body_long', $argv ) ) {
 | 
						|
		$body_long = trim( $argv[array_search( '-body_long', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$body_long = false;
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-priority', $argv ) ) {
 | 
						|
		$priority = trim( $argv[array_search( '-priority', $argv ) + 1] );
 | 
						|
	} else {
 | 
						|
		$priority = 5; //5=Normal
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-device_id', $argv ) ) {
 | 
						|
		$device_id = [ trim( $argv[array_search( '-device_id', $argv ) + 1] ) ];
 | 
						|
	} else {
 | 
						|
		$device_id = [ 4 ]; //Default to Web Browser, Work Email, and Mobile App.
 | 
						|
	}
 | 
						|
 | 
						|
	if ( in_array( '-payload', $argv ) ) {
 | 
						|
		$raw_payload = json_decode( trim( $argv[array_search( '-payload', $argv ) + 1] ), true );
 | 
						|
		$raw_payload_json_error = json_last_error();
 | 
						|
		if ( $raw_payload_json_error !== JSON_ERROR_NONE ) {
 | 
						|
			echo 'ERROR: Invalid JSON: ';
 | 
						|
			switch ( $raw_payload_json_error ) {
 | 
						|
				case JSON_ERROR_NONE:
 | 
						|
					echo 'No errors';
 | 
						|
					break;
 | 
						|
				case JSON_ERROR_DEPTH:
 | 
						|
					echo 'Maximum stack depth exceeded';
 | 
						|
					break;
 | 
						|
				case JSON_ERROR_STATE_MISMATCH:
 | 
						|
					echo 'Underflow or the modes mismatch';
 | 
						|
					break;
 | 
						|
				case JSON_ERROR_CTRL_CHAR:
 | 
						|
					echo 'Unexpected control character found';
 | 
						|
					break;
 | 
						|
				case JSON_ERROR_SYNTAX:
 | 
						|
					echo 'Syntax error, malformed JSON';
 | 
						|
					break;
 | 
						|
				case JSON_ERROR_UTF8:
 | 
						|
					echo 'Malformed UTF-8 characters, possibly incorrectly encoded';
 | 
						|
					break;
 | 
						|
				default:
 | 
						|
					echo 'Unknown error';
 | 
						|
					break;
 | 
						|
			}
 | 
						|
			echo "\n";
 | 
						|
			exit( 254 );
 | 
						|
		}
 | 
						|
	} else {
 | 
						|
		$raw_payload = null;
 | 
						|
	}
 | 
						|
 | 
						|
	$TIMETREX_URL = $api_url;
 | 
						|
 | 
						|
	if ( isset( $api_key ) && $api_key != '' ) {
 | 
						|
		$TIMETREX_SESSION_ID = $api_key;
 | 
						|
		$api_session = new TimeTrexClientAPI();
 | 
						|
		//if ( $api_session->isLoggedIn() == false ) {
 | 
						|
		//	echo "API Key is incorrect!\n";
 | 
						|
		//	exit( 1 );
 | 
						|
		//}
 | 
						|
	} else {
 | 
						|
		$api_session = new TimeTrexClientAPI();
 | 
						|
		$api_session->Login( $username, $password );
 | 
						|
		if ( $TIMETREX_SESSION_ID == false ) {
 | 
						|
			echo "API Username/Password is incorrect!\nIf multifactor authentication is enabled, login to TimeTrex and go to Profile -> Security / Passwords, More (...) -> Register API Key.\n";
 | 
						|
			exit( 1 );
 | 
						|
		}
 | 
						|
		//echo "Session ID: $TIMETREX_SESSION_ID\n";
 | 
						|
	}
 | 
						|
 | 
						|
	$notification_data = [
 | 
						|
		'user_id' => $user_id,
 | 
						|
		'device_id' => $device_id,
 | 
						|
		'type_id' => $type_id,
 | 
						|
		'object_type_id' => $object_type_id,
 | 
						|
		'object_id' => $object_id,
 | 
						|
		'title_short' => $title_short,
 | 
						|
		'title_long' => $title_long,
 | 
						|
		'body_short' => $body_short,
 | 
						|
		'body_long' => $body_long,
 | 
						|
		'priority_id'  => $priority,
 | 
						|
		'payload' => $raw_payload,
 | 
						|
	];
 | 
						|
 | 
						|
	$notification_obj = new TimeTrexClientAPI( 'Notification' );
 | 
						|
	$notification_obj->setIdempotentKey( false ); //Turn off idempotenacy.
 | 
						|
	$notification_result = $notification_obj->sendNotification( $notification_data );
 | 
						|
	$retval = $notification_result->getResult();
 | 
						|
	if ( $retval !== true ) {
 | 
						|
		echo "ERROR: Unable to send notification!\n";
 | 
						|
		exit ( 1 );
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
//Debug::Display();
 | 
						|
Debug::writeToLog();
 | 
						|
?>
 |