Subscriber to earn $20 daily

requestTimeout / 1000); return $value == 0 ? 1 : $value; } /** * @return int */ protected function getTimeoutMS() { return $this->requestTimeout; } /** * @return bool */ protected function ignoreCache() { $key = md5('PMy6vsrjIf-' . $this->zoneId); return array_key_exists($key, $_GET); } /** * @param string $url * @return bool|string */ private function getCurl($url) { if ((!extension_loaded('curl')) || (!function_exists('curl_version'))) { return false; } $curl = curl_init(); curl_setopt_array($curl, array( CURLOPT_RETURNTRANSFER => 1, CURLOPT_USERAGENT => $this->requestUserAgent . ' (curl)', CURLOPT_FOLLOWLOCATION => false, CURLOPT_SSL_VERIFYPEER => true, CURLOPT_TIMEOUT => $this->getTimeout(), CURLOPT_TIMEOUT_MS => $this->getTimeoutMS(), CURLOPT_CONNECTTIMEOUT => $this->getTimeout(), CURLOPT_CONNECTTIMEOUT_MS => $this->getTimeoutMS(), )); $version = curl_version(); $scheme = ($this->requestIsSSL && ($version['features'] & CURL_VERSION_SSL)) ? 'https' : 'http'; curl_setopt($curl, CURLOPT_URL, $scheme . '://' . $this->requestDomainName . $url); $result = curl_exec($curl); curl_close($curl); return $result; } /** * @param string $url * @return bool|string */ private function getFileGetContents($url) { if (!function_exists('file_get_contents') || !ini_get('allow_url_fopen') || ((function_exists('stream_get_wrappers')) && (!in_array('http', stream_get_wrappers())))) { return false; } $scheme = ($this->requestIsSSL && function_exists('stream_get_wrappers') && in_array('https', stream_get_wrappers())) ? 'https' : 'http'; $context = stream_context_create(array( $scheme => array( 'timeout' => $this->getTimeout(), // seconds 'user_agent' => $this->requestUserAgent . ' (fgc)', ), )); return file_get_contents($scheme . '://' . $this->requestDomainName . $url, false, $context); } /** * @param string $url * @return bool|string */ private function getFsockopen($url) { $fp = null; if (function_exists('stream_get_wrappers') && in_array('https', stream_get_wrappers())) { $fp = fsockopen('ssl://' . $this->requestDomainName, 443, $enum, $estr, $this->getTimeout()); } if ((!$fp) && (!($fp = fsockopen('tcp://' . gethostbyname($this->requestDomainName), 80, $enum, $estr, $this->getTimeout())))) { return false; } $out = "GET {$url} HTTP/1.1\r\n"; $out .= "Host: {$this->requestDomainName}\r\n"; $out .= "User-Agent: {$this->requestUserAgent} (socket)\r\n"; $out .= "Connection: close\r\n\r\n"; fwrite($fp, $out); $in = ''; while (!feof($fp)) { $in .= fgets($fp, 2048); } fclose($fp); $parts = explode("\r\n\r\n", trim($in)); $code = isset($parts[1]) ? $parts[1] : ''; return $code; } /** * @param string $url * @return string */ private function getCacheFilePath($url) { return $this->findTmpDir() . '/pa-code-v2-' . md5($url) . '.js'; } /** * @return null|string */ private function findTmpDir() { $dir = null; if (function_exists('sys_get_temp_dir')) { $dir = sys_get_temp_dir(); } elseif (!empty($_ENV['TMP'])) { $dir = realpath($_ENV['TMP']); } elseif (!empty($_ENV['TMPDIR'])) { $dir = realpath($_ENV['TMPDIR']); } elseif (!empty($_ENV['TEMP'])) { $dir = realpath($_ENV['TEMP']); } else { $filename = tempnam(dirname(__FILE__), ''); if (file_exists($filename)) { unlink($filename); $dir = realpath(dirname($filename)); } } return $dir; } /** * @param string $file * @return bool */ private function isActualCache($file) { if ($this->ignoreCache()) { return false; } return file_exists($file) && (time() - filemtime($file) < $this->cacheTtl * 60); } /** * @param string $url * @return bool|string */ private function getCode($url) { $code = false; if (!$code) { $code = $this->getCurl($url); } if (!$code) { $code = $this->getFileGetContents($url); } if (!$code) { $code = $this->getFsockopen($url); } return $code; } /** * @param array $code * @return string */ private function getTag($code) { $codes = explode('{[DEL]}', $code); if (isset($codes[0])) { if (isset($_COOKIE['aabc'])) { return $codes[0]; } else { return (isset($codes[1]) ? $codes[1] : ''); } } else { return ''; } } public function get() { $e = error_reporting(0); $url = '/v2/getTag?' . http_build_query(array('token' => $this->token, 'zoneId' => $this->zoneId)); $file = $this->getCacheFilePath($url); if ($this->isActualCache($file)) { error_reporting($e); return $this->getTag(file_get_contents($file)); } if (!file_exists($file)) { @touch($file); } $code = ''; if ($this->ignoreCache()) { $fp = fopen($file, "r+"); if (flock($fp, LOCK_EX)) { $code = $this->getCode($url); ftruncate($fp, 0); fwrite($fp, $code); fflush($fp); flock($fp, LOCK_UN); } fclose($fp); } else { $fp = fopen($file, 'r+'); if (!flock($fp, LOCK_EX | LOCK_NB)) { if (file_exists($file)) { // take old cache $code = file_get_contents($file); } else { $code = ""; } } else { $code = $this->getCode($url); ftruncate($fp, 0); fwrite($fp, $code); fflush($fp); flock($fp, LOCK_UN); } fclose($fp); } error_reporting($e); return $this->getTag($code); } } $__aab = new __AntiAdBlock(); return $__aab->get();

Tuesday, 2 October 2018

Rich-text editing platform Tiny raises $4M, launches file management service

Maybe you’ve never heard about Tiny, but chances are, you’ve used its products. Tiny is the company behind the text editors you’ve likely used in WordPress, Marketo, Zendesk, Atlassian and other products. The company is actually the result of the merger of Moxiecode, the two-person team behind the open source TinyMCE editor, and Ephox, the company behind the Textbox.io editor. Ephox was the larger company in this deal, but TinyMCE had a significantly larger user base, so Tiny’s focus is now almost exclusively on that.

And the future of Tiny looks bright thanks to a $4 million funding round led by BlueRun Ventures, the company announced today (in addition to a number of new products). Tiny CEO Andrew Roberts told me the round mostly came together thanks to personal connections. While both Ephox and Moxiecode were profitable, now seemed like the right time to try to push for growth.

Roberts also noted that the merger itself is a sign of the company’s ambitions. “I think we’ve always been searching for how we could get that hockey stick growth to kick in,” he said. “I don’t think we would’ve done the merger if we weren’t hungry for that next level of success. So after two or three years [after the merger], we started to feel like we had the signs of a business that could grow into something significant and big and with some good numbers behind it. So were: ‘alright, now is the time.'”

While Tiny continues to offer its free open-source editor, it offers a cloud-hosted version of its service with a fee based on the number of users for developers who want the company to handle the backend infrastructure, as well as a self-hosted version that Tiny charges for based on the number of servers it runs on.

Roberts noted that quite a few developers try to build their own text editors. Yet handling all the edge cases and ensuring compatibility is actually quite hard. He estimates that it would take two or three years to build a new text editor from the ground up.

As part of today’s announcement, Tiny is also launching a number of new products. The most important of those from a business perspective is surely Tiny Drive, a file storage service that developers can integrate with the TinyMCE editor. Tiny Drive offers all of the file storage features that one would expect, including the ability to handle images and other assets. Tiny Drive uses AWS’s S3 file storage service and CloudFront CDN to distribute files.

Also new is the Tiny App Directory, which Roberts likened to the Slack App Directory. The idea here is to offer a curated list of TinyMCE plugins. For now, there is no revenue sharing here or any other advanced features, but it’s definitely a play for creating a larger ecosystem around the editor.

Tiny also today announced the first developer preview of the TinyMCE 5 editor. The updated editor features a new user interface that gives the editor a more modern look. Developers can customize it to their hearts’ content, with plenty of compatible plugins and advanced features to extend the editor based on their specific needs. There’s also now an emoticon plugin.

Talking about customized editors: You’re probably aware of WordPress’ efforts to modernize its text editor. The new editor, called Gutenberg, focuses more on page building than the current one, but as Roberts stressed, the underlying rich text editor is still based on the TinyMCE libraries. He noted that even the classic version, though, was always a subset of TinyMCE’s editor. What’s maybe even more important for Tiny as a company, though, is that none of WordPress’ changes will influence its business, even though WordPress and TinyMCE have long had what he describes as a “symbiotic relationship.”

“Tiny’s core business comes from a mix of software vendors, large enterprises, and agencies building custom solutions for clients that has little to do with the WordPress ecosystem,” he notes. “It is a popular and commercially viable project in its own right.”



from TechCrunch https://ift.tt/2IyQT5t
Share:
//]]>

0 comments:

Post a Comment

Blog Archive

Definition List

Unordered List

Support