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, 27 April 2020

Tinvio, a communication platform for supply chain merchants, gets $5.5 million seed round

Being a supply chain merchant often means cobbling together different ways of keeping in touch with buyers, including emails, text messages and paper invoices. Tinvio wants to simplify the process with a communication and commerce platform designed especially for managing orders.

The Singapore-based startup announced today that it has raised $5.5 million in seed funding, led by Sequoia Capital India’s Surge early-stage accelerator program, with participation from Global Founders Capital and Partech Partners.

Along with a pre-seed round from Rocket Internet, this brings Tinvio’s total raised so far to $6.5 million. The startup was founded in July 2019 by Ajay Gopal, who previously worked at Rocket Internet in Berlin. Before that, he was a fintech investment banker at Credit Suisse.

Since launching, Tinvio’s customer base has grown to over 1,000 businesses in more than 10 cities. Over the next 12 months, it plans to add more cities and languages, as well as digital financial services.

Tinvio is targeted at small-to mid-sized merchants, and many of its customers are in the food and beverage (F&B), retail and healthcare supply industries.

“At its core, Tinvio is a real-time messaging app. For every 10 orders placed on Tinvio, there’s an average of two messages sent, reinforcing that communication is critical in fragmented supply chains,” Gopal told TechCrunch.

One of Tinvio’s selling points is that merchants can continue to receive orders through their existing channels, including email, SMS or WhatsApp. By consolidating those orders in one app, Tinvio is also able to create a real-time digital ledger, making it easier for merchants to track invoices, fulfillment and finances.

During the COVID-19 pandemic, order volumes between merchants and suppliers on Tinvio have fallen about 30% to 50% in most cities, Gopal said, “though retention rates remain high, suggesting that many businesses are trying their best to stay open. We talk to them often, and we’re quite awed by their resilience to keep trying, keep finding a way to make it work.”

He added, “Our tech is designed to be fully customizable, so we’ve started organically supporting many of their new use cases.”

For example, some food and beverage merchants have started using Tinvio to manage group orders with consumers instead. Since many businesses have let go of staff, this means merchants have become more reliant on the app to keep track of orders and inbound/outbound deliveries. Tinvio has started expanding this into a new feature and also begun customizing soft-integrations for suppliers so they don’t have to manually add data to their ERP software.

Two weeks ago, Tinvio also launched a project called Save Our Nomnoms to help direct more orders to food and beverage merchants in Singapore, which is currently under partial lockdown. The project started with 40 brands, and has since grown to include more than 300 brands.



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

0 comments:

Post a Comment

Blog Archive

Definition List

Unordered List

Support