<?php namespace brain\utility; use brain\data\Settings; class HandleCors { public function __construct() { //look to see if settings file exists. kinda important if (file_exists("../config/settings.json")) { //check settings to see if external api access is allowed $config = new Settings(); $settings = $config->getSettings(); if ($settings["global"]["externalAPI"]) { //echo "API STATUS: " . $settings["global"]["externalAPI"]; if ($settings["global"]["externalAPI"] == "true") { //echo "API ACCESS ACTIVE"; // checks to see if origin is set if (isset($_SERVER["HTTP_ORIGIN"])) { // You can decide if the origin in $_SERVER['HTTP_ORIGIN'] is something you want to allow, or as we do here, just allow all header("Access-Control-Allow-Origin: {$_SERVER["HTTP_ORIGIN"]}"); } else { //No HTTP_ORIGIN set, so we allow any. You can disallow if needed here //never allow just any domain, so turn CORS off if no No HTTP_ORIGIN is set //header("Access-Control-Allow-Origin: *"); } header("Access-Control-Allow-Credentials: true"); header("Access-Control-Max-Age: 600"); // cache for 10 minutes if ($_SERVER["REQUEST_METHOD"] == "OPTIONS") { if (isset($_SERVER["HTTP_ACCESS_CONTROL_REQUEST_METHOD"])) { header( "Access-Control-Allow-Methods: POST, GET, OPTIONS, DELETE, PUT" ); } //Make sure you remove those you do not want to support if (isset($_SERVER["HTTP_ACCESS_CONTROL_REQUEST_HEADERS"])) { header( "Access-Control-Allow-Headers: {$_SERVER["HTTP_ACCESS_CONTROL_REQUEST_HEADERS"]}" ); } //Just exit with 200 OK with the above headers for OPTIONS method exit(0); } } else { //echo "API ACCESS ACTIVE"; } } else { //value doesn't exist, so whatevs //echo "API ACCESS VALUE NOT PRESENT"; } } else { //init state, so chill } } }