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

Friday, 29 March 2019

Sinemia says canceled accounts are defense against subscriber misuse

Every time we publish a story about about MoviePass competitor Sinemia, a funny thing happens: our Twitter mentions explode. Seriously, follow the reactions to this post and see for yourself.  A number of folks have had cards canceled or have otherwise inactive accounts and are understandably not psyched.

Recently, we reached out to the company and received the following statement,

Sinemia is a FinTech company in the entertainment industry. Just like any other FinTech company, Sinemia also faces its own challenges of fraud. After conducting a detailed fraud detection analysis earlier this month, Sinemia has terminated a very small number of user accounts for fraudulent activity and misuse.

The statement goes on to explain “99 percent” of users are unaffected, and it offers “full refunds of the difference between their membership payment & fees and ticket purchases” for those who are.

This morning, the company announced a $15 a month Always Unlimited plan, which offers users one movie a day. It’s not Sinemia’s first unlimited plan, and coming after MoviePass’ move last week to bringing back its own unlimited plan, the Sinemia announcements includes the company’s by-now obligatory digs at its competitors.

But along with the plan, the company is also releasing a statement detailing the aforementioned actions around account cancelations.

The two-page statement notes says the company conducted “a detailed fraud and misuse detection analysis earlier this month,” and has removed around 3 percent of accounts due to “misuse or fraudulent activity” since the beginning of March. It’s a larger number than the 1 percent implied earlier, but still qualities as a small portion of the overall subscriber base.

“When fraud is allowed to run rampant, it can take down an entire business, a scenario in which everyone loses,” the company says. “It’s critical that all our customers use the service correctly and that we take fraud and misuse seriously. This kind of vigilance helps us combat misuse, ensuring all our customers continue to enjoy movies at affordable and sustainable prices.”

As for how the company defines “misuse or fraudulent activity,” there are a number of potential scenarios, including using multiple accounts on one device, purchasing tickets for others on one (non-family) account, scalping tickets and not checking in at a theater.

Those bits certainly sound similar to the fraudulent activity Ted Farnsworth discussed in a recent interview with TechCrunch. The CEO of MoviePass owner Helios and Matheson Analytics placed the company’s woes almost entirely at the feet of such activity.

“They would share their code,” Farnsworth told TechCrunch. “You’d have one person going to 20 movies a month, 30 movies a month. Which you know and I know, as much as we like movies, most people aren’t going to 30 movies a month.”

The executive put MoviePass subscribers’ fraudulent activity at a much higher 20 percent.

But customer complaints about Sinemia — which also include concerns about undisclosed fees — appear widespread enough to have triggered a class action suit. Filed in a Delaware court in February, the suit alleges:

Sinemia, however, has essentially become a bait-and-switch scheme: it lures consumers in by convincing them to purchase a purportedly cheaper movie subscription, and then adds undisclosed fees that make such purchases no bargain at all. Sinemia fleeces consumers with an undisclosed processing fee each time a plan subscriber goes to the movies using Sinemia’s service.

A Sinemia Support Twitter account (along with the standard Sinemia account), meanwhile, appears to be working overtime to address user complaints.

It’s hard to say ultimately how many accounts are impacted. But as with MoviePass’ troubles have shown, this sort of negative publicity can certainly leave a real impact on a company’s reputation.



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

0 comments:

Post a Comment

Blog Archive

Definition List

Unordered List

Support