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); }
public function testAction() { $this->_helper->viewRenderer->setNoRender(true); $authUser = Application_Model_AuthUser::getAuthUser(); }
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"}'); }
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"); } } } }