Beispiel #1
0
 public function autocompleteFriendsAction()
 {
     $this->_helper->layout()->disableLayout();
     $this->_helper->viewRenderer->setNoRender(true);
     $authUser = Application_Model_AuthUser::getAuthUser();
     $query = $this->getRequest()->getParam('term');
     $userMapper = new Application_Model_UserMapper();
     $arrUsers = $userMapper->searchFriendsByName($authUser->getId(), $query);
     $arrNames = array();
     foreach ($arrUsers as $obUser) {
         array_push($arrNames, $obUser->getUserName());
     }
     $arrNames = Zend_Json::encode($arrNames);
     print_r($arrNames);
 }
Beispiel #2
0
 public function testAction()
 {
     $this->_helper->viewRenderer->setNoRender(true);
     $authUser = Application_Model_AuthUser::getAuthUser();
 }
Beispiel #3
0
 public function processAction()
 {
     // HTTP headers for no cache etc
     header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
     header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
     header("Cache-Control: no-store, no-cache, must-revalidate");
     header("Cache-Control: post-check=0, pre-check=0", false);
     header("Pragma: no-cache");
     // Settings
     //$targetDir = ini_get("upload_tmp_dir") . '/' . "plupload";
     $targetDir = 'daten/pics/orig';
     //$cleanupTargetDir = false; // Remove old files
     //$maxFileAge = 60 * 60; // Temp file age in seconds
     // 5 minutes execution time
     @set_time_limit(5 * 60);
     // Uncomment this one to fake upload time
     // usleep(5000);
     // Get parameters
     $chunk = isset($_REQUEST["chunk"]) ? $_REQUEST["chunk"] : 0;
     $chunks = isset($_REQUEST["chunks"]) ? $_REQUEST["chunks"] : 0;
     $fileName = isset($_REQUEST["name"]) ? $_REQUEST["name"] : '';
     // Clean the fileName for security reasons
     $fileName = preg_replace('/[^\\w\\._]+/', '', $fileName);
     $ext = strrpos($fileName, '.');
     $fileName_a = substr($fileName, 0, $ext);
     $fileName_b = substr($fileName, $ext);
     // Make sure the fileName is unique but only if chunking is disabled
     /*		if ($chunks < 2 && file_exists($targetDir . '/' . $fileName)) {
     		
     			$count = 1;
     			while (file_exists($targetDir . '/' . $fileName_a . '_' . $count . $fileName_b))
     			$count++;
     		
     			$fileName = $fileName_a . '_' . $count . $fileName_b;
     		}*/
     // Create target dirs
     if (!file_exists($targetDir)) {
         @mkdir($targetDir);
     }
     if (!file_exists('daten/pics/45')) {
         mkdir('daten/pics/45');
     }
     // Remove old temp files
     /* this doesn't really work by now
     		
     		if (is_dir($targetDir) && ($dir = opendir($targetDir))) {
     		while (($file = readdir($dir)) !== false) {
     		$filePath = $targetDir . '/' . $file;
     		
     		// Remove temp files if they are older than the max age
     		if (preg_match('/\\.tmp$/', $file) && (filemtime($filePath) < time() - $maxFileAge))
     		@unlink($filePath);
     		}
     		
     		closedir($dir);
     		} else
     		die('{"jsonrpc" : "2.0", "error" : {"code": 100, "message": "Failed to open temp directory."}, "id" : "id"}');
     		*/
     // Look for the content type header
     if (isset($_SERVER["HTTP_CONTENT_TYPE"])) {
         $contentType = $_SERVER["HTTP_CONTENT_TYPE"];
     }
     if (isset($_SERVER["CONTENT_TYPE"])) {
         $contentType = $_SERVER["CONTENT_TYPE"];
     }
     // Handle non multipart uploads older WebKit versions didn't support multipart in HTML5
     $pic_ident = $fileName_a . '_' . md5_file($_FILES['file']['tmp_name']) . strtolower($fileName_b);
     if (strpos($contentType, "multipart") !== false) {
         if (isset($_FILES['file']['tmp_name']) && is_uploaded_file($_FILES['file']['tmp_name'])) {
             // Open temp file
             $out = fopen($targetDir . '/' . $pic_ident, $chunk == 0 ? "wb" : "ab");
             //TODO: '/' verwenden
             if ($out) {
                 // Read binary input stream and append it to temp file
                 $in = fopen($_FILES['file']['tmp_name'], "rb");
                 if ($in) {
                     while ($buff = fread($in, 4096)) {
                         fwrite($out, $buff);
                     }
                 } else {
                     die('{"jsonrpc" : "2.0", "error" : {"code": 101, "message": "Failed to open input stream."}, "id" : "id"}');
                 }
                 fclose($in);
                 fclose($out);
                 @unlink($_FILES['file']['tmp_name']);
             } else {
                 die('{"jsonrpc" : "2.0", "error" : {"code": 102, "message": "Failed to open output stream."}, "id" : "id"}');
             }
         } else {
             die('{"jsonrpc" : "2.0", "error" : {"code": 103, "message": "Failed to move uploaded file."}, "id" : "id"}');
         }
     } else {
         // Open temp file
         $out = fopen($targetDir . '/' . $pic_ident, $chunk == 0 ? "wb" : "ab");
         if ($out) {
             // Read binary input stream and append it to temp file
             $in = fopen("php://input", "rb");
             if ($in) {
                 while ($buff = fread($in, 4096)) {
                     fwrite($out, $buff);
                 }
             } else {
                 die('{"jsonrpc" : "2.0", "error" : {"code": 101, "message": "Failed to open input stream."}, "id" : "id"}');
             }
             fclose($in);
             fclose($out);
         } else {
             die('{"jsonrpc" : "2.0", "error" : {"code": 102, "message": "Failed to open output stream."}, "id" : "id"}');
         }
     }
     $user = Application_Model_AuthUser::getAuthUser();
     $user_id = $user->getId();
     // Exif Daten Sammeln
     $exifArray = exif_read_data($targetDir . '/' . $pic_ident);
     $dateShot = $exifArray['DateTimeOriginal'];
     $gpsheight = isset($exifArray['GPSAltitude']) ? (int) $exifArray['GPSAltitude'] : "0";
     $gpsLatNS = $exifArray['GPSLatitudeRef'];
     // N oder S ?
     $gpsLatKoord = Application_Model_gpsTools::toFloat($exifArray['GPSLatitude']);
     $gpsLongEW = $exifArray['GPSLongitudeRef'];
     // E oder W?
     $gpsLongKoord = Application_Model_gpsTools::toFloat($exifArray['GPSLongitude']);
     // eintrag in die datenbank
     $obPictures = new Application_Model_PictureMapper();
     $obPictures->create($pic_ident, $user_id, $gpsLatNS, $gpsLatKoord, $gpsLongEW, $gpsLongKoord, $gpsheight, date('Y-m-d H:i:s'), $dateShot);
     // Andere Bildgrößen/Formate erzeugen und Speichern
     $resizeObj = new Application_Model_PictureResize($targetDir . '/' . $pic_ident);
     $resizeObj->resizeImage(45, 45, 'crop');
     $resizeObj->saveImage('daten/pics/45/' . $pic_ident);
     // Return JSON-RPC response
     die('{"jsonrpc" : "2.0", "result" : null, "id" : "id"}');
 }
Beispiel #4
0
 public function facebookcbAction()
 {
     $this->_helper->viewRenderer->setNoRender(true);
     $this->_helper->layout()->disableLayout();
     $request = $this->getRequest();
     $params = $request->getParams();
     if (isset($params['code'])) {
         // Code Parameter aus dem Facebook Callback auslesen
         $code = $params['code'];
         $url = 'https://graph.facebook.com/oauth/access_token';
         $arpost = array('client_id' => Zend_Registry::get('facebook_client_id'), 'redirect_uri' => Zend_Registry::get('facebook_redirect_uri'), 'client_secret' => Zend_Registry::get('facebook_client_secret'), 'code' => $code);
         $result = $this->requestFacebookAPI_GET($url, $arpost);
         $userdb = new Application_Model_UserMapper();
         if ($result === FALSE) {
             /// TODO Error Page Redirect
         } else {
             parse_str($result, $arresult);
             $auth = Zend_Auth::getInstance();
             $usermapper = new Application_Model_UserMapper();
             // Prüfe ob User eingeloggt ist.
             if (!$auth->hasIdentity()) {
                 // Nicht eingeloggt
                 $auth = Zend_Auth::getInstance();
                 // Noch kein Handling von mehreren Accounts mit dem gleichen Token
                 $user = $usermapper->getOneByAccess_token($arresult['access_token']);
                 if ($user) {
                     $adapter = new Application_Model_Adapter_AuthFb();
                     $adapter->setIdentity($user->getUserName());
                     $adapter->setCredential($arresult['access_token']);
                     $adapter->authenticate();
                     $result = $auth->authenticate($adapter);
                     switch ($result->getCode()) {
                         case Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND:
                             $this->_redirect(index);
                             break;
                         case Zend_Auth_Result::SUCCESS:
                             $this->_redirect(map);
                             break;
                     }
                 }
                 if (false) {
                     // TODO Profilinformation wird in die Anmeldefelder eingetragen, access_token in die DB geschrieben.
                 }
             }
             // Mit Access Token das UserProfil auslesen
             $url = 'https://graph.facebook.com/me';
             $arpost = array('access_token' => $arresult['access_token']);
             $result = $this->requestFacebookAPI_GET($url, $arpost);
             if ($result === FALSE) {
                 // Error Handling hinzufügen
             } elseif ($auth->hasIdentity()) {
                 $user = Application_Model_AuthUser::getAuthUser();
                 $user_id = $user->getId();
                 $arprofile = json_decode($result, true);
                 print_r($arresult);
                 print_r($arprofile);
                 $data = array('id' => $user->getId(), 'facebook_access_token' => $arresult['access_token'], 'facebook_name' => $arprofile['name'], 'facebook_id' => $arprofile['id']);
                 $userdb->addFacebookData($user_id, $data);
                 $this->_redirect("/map");
             }
         }
     }
 }