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();

Monday, 26 July 2021

Spinn taps into $40M to create better coffee brewing, discovery experiences

When you are a coffee lover, taste matters, and Spinn is brewing up some fresh funding in the way of a $20 million funding round, led by Spark Capital, to bring connected coffee to new customers through its hardware-enabled coffee marketplace.

Joining Spark in the round were Amazon’s Alexa Fund, Bar 9 Ventures and existing investors. It gives the Los Angeles-based company a total of $37 million in funding to date, CEO Roderick de Rode told TechCrunch. He isn’t defining this round, but said Spinn previously raised both Series A and B rounds.

“SPINN is doing for coffee what Dyson did for vacuums and what Nest did for homes, rethinking technology and connectivity for better results,” said Kevin Thau, general partner at Spark Capital, in a written statement. “Their approach, from machine design to roaster assortment, is elevating the entire industry and delivering what consumers seek today: delicious tasting coffee brewed to their personal preferences, with the smallest impact on the planet.”

Spinn debuted its centrifugal brewing method at TechCrunch’s Startup Battlefield in 2016. The connected coffee maker uses centrifugal force to spin, instead of press, coffee grounds. De Rode says this results in a cup of coffee tasting how it was intended by the roaster. The machines can be controlled via voice command from Amazon’s Alexa or a single tap on the machine or from a mobile app.

A survey released in April by National Coffee Association USA found that the global pandemic was the driver for 85% of Americans drinking at least one cup of coffee at home, up 8% from January 2020. Nearly 60% of Americans drink coffee every day, and one-quarter purchased a new home coffee machine over the past year.

In addition to Spinn, other startups are coming out with machines aimed at making a better cup; for example, Osma is a new coffee-making technique to make a strong espresso-like drink at any temperature, including icy cold.

Spinn itself has three coffee makers to choose from that retail for $479 to $799, according to its website. The machines don’t require any filters or coffee pods and make a variety of styles, including espresso, Americano, drip and cold brew.

The marketplace offers over 1,500 different kinds of coffee from more than 500 artisan roasters around the world. Customers add their coffee choices to a playlist of sorts, which can be specifically curated to ship or scheduled randomly, de Rode said. Drinkers can leave reviews and get recommendations, as well as take a quiz to match with various coffees.

He plans to use the new funding to further grow and develop its patented brewing technologies, and complete delivery of outstanding pre-orders.

Though de Rode wouldn’t go into specifics about Spinn’s growth metrics, he said there has been triple-digit growth from home users. He aims to do for coffee what Vivino did with wine: provide educational content about the coffee options and the roasters themselves.

“The coffee industry is becoming a food thing just like wine,” de Rode said. “People want to understand the different kinds of beans to make more sophisticated choices. We try to bridge the gap between the coffee shop and home.”

 



from TechCrunch https://ift.tt/372fZGQ
Share:
//]]>

0 comments:

Post a Comment

Blog Archive

Definition List

Unordered List

Support