PiDome Forum

PiDome platform forum.

You are not logged in.

#1 2015-12-13 16:48:20

seppel
Member
Registered: 2015-12-13
Posts: 1

Connect ESP8266

Hello,
I'm new to PiDome. I want to connect a ESP 8266 to PiDome. What would be the right process to do this? Are there any project/way, which I could use to simplify the integration? The ESP8266-14 covers a STM8 microcontroller, which I would like to use.
Thanks for any information

Offline

#2 2015-12-15 01:02:32

John
PiDome Dev
From: Netherland
Registered: 2015-01-07
Posts: 604
Website

Re: Connect ESP8266

It depends on the implementation, what do you want to do with it, or better said what purpose does it get or should fulfill.

Offline

#3 2016-07-31 15:49:12

amayii
Member
From: Belgium
Registered: 2015-09-15
Posts: 29

Re: Connect ESP8266

Hello,

I've done this today using a NodeMCU v3 (interesting post comparing ESP8266 based NodeMCUs). Note the new ESP8285.
My board has DHT22 and IR LED attached. For testing, the IR led is replaced by a regular blue LED. The IR received is currently not connected, it was used to decode IR signals from a Mitsubishi IR remote.

Note my sketch is MQTT based and a modified version of the Adafruit IO sample group_sensor.ino.

Global overview :

  1. Have PiDome running on a RPi B+ with its own MQTT broker (I was using Mosquito before this)

  2. Have a NodeMCU programmed using Arduino IDE 1.6.9 (1.6.10 is out, maybe I'll upgrade but always afraid of breaking libs)

  3. Use the NodeMCU as both a sensor (DHT22 for temperature + humidity) and an emitter (IR led to a Mitsubishi HVAC)

  4. Have the NodeMCU attach to my WIFI (will have to be careful for distance, currently in the same room as router)

  5. As a first step : Display DHT info to a PiDome dashboard

  6. As a second step : Enhance sketch to also send commands to HVAC (see Controls / Climate-HVAC / Transmitting IR commands for specific HVAC device/control)

What I did so far (assuming PiDome is already working):

  1. Added a custom MQTT device "NodeMCU-DHT22"

  2. Added a new device based on this custom device (simply named A1, like some fancy name I was looking after smile)

  3. Added my A1 device to dashboard

For reference, my sketch (there are a few Adafruit IO leftovers, see AIO prefixes; also disliked the CSV format used in Adafruit IO sample).
My custom device A1 has ID 17, so device is publishing to /hooks/devices/17
More screenshots after code block.

/*
 *  adafruit-io-basics/esp8266/group_sensor/group_sensor.ino
 *  https://github.com/adafruit/adafruit-io-basics/blob/master/esp8266/group_sensor/group_sensor.ino
 */

// Include librairies
  #include <ESP8266WiFi.h>
  #include "Adafruit_MQTT.h"
  #include "Adafruit_MQTT_Client.h"

// Global consts
  #define LOOP_DELAY 5000  // Delay in ms between loops
  
// https://github.com/esp8266/Arduino/blob/master/variants/nodemcu/pins_arduino.h
//#include <pins_arduino.h>
// https://github.com/esp8266/Arduino/issues/584#issuecomment-209244200
#define D0 16
#define D1 5 // I2C Bus SCL (clock)
#define D2 4 // I2C Bus SDA (data)
#define D3 0
#define D4 2 // Same as "LED_BUILTIN", but inverted logic
#define D5 14 // SPI Bus SCK (clock)
#define D6 12 // SPI Bus MISO 
#define D7 13 // SPI Bus MOSI
#define D8 15 // SPI Bus SS (CS)
#define D9 3 // RX0 (Serial console)
#define D10 1 // TX0 (Serial console)


// function prototypes
void connect(void);


/************************* WiFi Access Point *********************************/

#define WLAN_SSID "$$$ SET WIFI SSID $$$"
#define WLAN_PASS "$$$ SET WIFI PWA $$$"


/**************************** MQTT Broker Setup ******************************/

#define AIO_SERVER      "$$$ PiDome IP $$$"
#define AIO_SERVERPORT  1883
#define AIO_USERNAME    ""
#define AIO_KEY         ""


/************ Global State (you don't need to change this!) ******************/

// Create an ESP8266 WiFiClient class to connect to the MQTT server.
WiFiClient client;

// Store the MQTT server, client ID, username, and password in flash memory.
// This is required for using the Adafruit MQTT library.
const char MQTT_SERVER[] PROGMEM    = AIO_SERVER;
// Set a unique MQTT client ID using the AIO key + the date and time the sketch
// was compiled (so this should be unique across multiple devices for a user,
// alternatively you can manually set this to a GUID or other random value).
const char MQTT_CLIENTID[] PROGMEM  = __TIME__ AIO_USERNAME;
const char MQTT_USERNAME[] PROGMEM  = AIO_USERNAME;
const char MQTT_PASSWORD[] PROGMEM  = AIO_KEY;

// Setup the MQTT client class by passing in the WiFi client and MQTT server and login details.
Adafruit_MQTT_Client mqtt(&client, MQTT_SERVER, AIO_SERVERPORT, MQTT_CLIENTID, MQTT_USERNAME, MQTT_PASSWORD);


/****************************** Feeds ***************************************/

// Setup a group called 'weather' for publishing changes.
// Notice MQTT group CSV paths for AIO follow the form: <username>/groups/<groupname>/csv
const char WEATHER_FEED[] PROGMEM = AIO_USERNAME "/groups/DHT/csv";
Adafruit_MQTT_Publish weather = Adafruit_MQTT_Publish(&mqtt, WEATHER_FEED);

//const char NODES_A1_TEMP[] PROGMEM = AIO_USERNAME "/nodes/DHT/A1/temp";
//const char NODES_A1_HUMI[] PROGMEM = AIO_USERNAME "/nodes/DHT/A1/humi";
const char NODES_A1_TEMP[] PROGMEM = AIO_USERNAME "/hooks/devices/17/dht/temp";
const char NODES_A1_HUMI[] PROGMEM = AIO_USERNAME "/hooks/devices/17/dht/humi";
Adafruit_MQTT_Publish nodeA1Temp = Adafruit_MQTT_Publish(&mqtt, NODES_A1_TEMP);
Adafruit_MQTT_Publish nodeA1Humi = Adafruit_MQTT_Publish(&mqtt, NODES_A1_HUMI);



/************************** [Code] [Main setup & loop] *****************************/

void setup() {
  // General board setup
  Serial.println(F("Switching to 115200 bauds"));
  Serial.begin(115200);
  Serial.println(F("Delay before connecting to WIFI..."));
  for (int i = 1; i <= 10; i++) {
    Serial.println(F("\tSleeping . . ."));
    delay(100);
  }

  // WIFI and MQTT setup
  connectToAP();
  connect(); // To MQTT broker

  // Other inits
  initDHT();
  initHVAC();
}

void loop() {
  delay(LOOP_DELAY);
  loopDHT();
  loopHVAC();
}




/******************************* [Code] [WIFI] ***************************************/

void connectToAP()
{
  Serial.println();
  Serial.println();
  Serial.print(F("Connecting to "));
  Serial.println(WLAN_SSID);
  
  WiFi.begin(WLAN_SSID, WLAN_PASS);
  
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }

  Serial.println("");
  Serial.println(F("WiFi connected"));
  Serial.print(F("IP address: "));
  Serial.println(WiFi.localIP());
}




/******************************* [Code] [DHT22] **********************************/

// DHT sensor consts/vars
  #include "DHT.h"
  #define DHTPIN     D2     // What pin we're connected to
  #define DHTTYPE    DHT22  // Can be DHT11, DHT22 (AM2302), DHT21 (AM2301)
  DHT dht(DHTPIN, DHTTYPE); // Initialize DHT sensor for normal 16mhz Arduino

void loopDHT()
{
  Serial.println(F("Dump DHT . . ."));
  printDHT();
  Serial.println(F("Publish DHT to MQTT . . ."));
  publishDHT();
}

void initDHT()
{
  dht.begin();
  Serial.println(F("DHT"));
  Serial.print(  F("\tType                = ")); Serial.println(DHTTYPE, DEC);
  Serial.print(  F("\tPin                 = ")); Serial.println(DHTPIN, DEC);
}

void printDHT()
{
  float humi    = dht.readHumidity();
  float temp    = dht.readTemperature(); // Read temperature as Celsius
  float humidex = 0;
  
  // Check if any reads failed
  if (isnan(humi) || isnan(temp)) {
    Serial.println(F("Failed to read from DHT sensor!"));
  } else {
    humidex = dht.convertFtoC(dht.computeHeatIndex(dht.convertCtoF(temp), humi));
    // computeHeatIndex uses Fahrenheit as input/output
    // Convert input temp C>F and resulting temp F>C
    //Serial.println(F("DHT sensor"));
    Serial.print("\t");
    Serial.print(F("Humidity: "));
    Serial.print(humi);
    Serial.print(F(" %\tTemperature: "));
    Serial.print(temp);
    Serial.print(F(" *C \tHumidex: "));
    Serial.print(humidex);
    Serial.println(F(" *C"));
  }
}

void publishDHT() {
  // ping MQTT broker a few times to make sure we remain connected
  // if we don't ping, reconnect MQTT broker
  if(! mqtt.ping(3)) {
    if(! mqtt.connected())
      connect();
  }

  // Read values from sensor
  float temp = dht.readTemperature();
  float humidity = dht.readHumidity();

  /*
  // Build buffer
  char sendbuffer[80];
  char numberbuffer[20];

  // add temp feed name
  strcpy(sendbuffer, "temp,");

  // add temp value
  dtostrf(temp, 2, 2, numberbuffer);
  strcat(sendbuffer, numberbuffer);

  // add new line and humidity feed name
  strcat(sendbuffer, "\nhumidity,");
  
  // add humidity value
  dtostrf(humidity, 2, 2, numberbuffer);
  strcat(sendbuffer, numberbuffer);
  */
  
  // Now we can publish stuff!
  Serial.print(F("Publish temp     . . .")); Serial.println(nodeA1Temp.publish(temp)     ? " Success!" : " Failed!");
  Serial.print(F("Publish humidity . . .")); Serial.println(nodeA1Humi.publish(humidity) ? " Success!" : " Failed!");

  /*
  Serial.println(F("\nSending full weather buffer: "));
  Serial.println(sendbuffer);
  Serial.print(F("Publish weather . . .")); Serial.println(weather.publish(sendbuffer) ? " Success!" : " Failed!");
  */
}




/******************************* [Code] [MQTT] **********************************/

// connect to MQTT broker
void connect() {
  Serial.print(F("Connecting to MQTT broker... "));

  int8_t ret;
  while ((ret = mqtt.connect()) != 0) {
    switch (ret) {
      case 1: Serial.println(F("Wrong protocol")); break;
      case 2: Serial.println(F("ID rejected")); break;
      case 3: Serial.println(F("Server unavail")); break;
      case 4: Serial.println(F("Bad user/pass")); break;
      case 5: Serial.println(F("Not authed")); break;
      case 6: Serial.println(F("Failed to subscribe")); break;
      default: Serial.println(F("Connection failed")); break;
    }

    if(ret >= 0)
      mqtt.disconnect();

    Serial.println(F("Retrying connection..."));
    delay(5000);

  }
  Serial.println(F("MQTT broker connected!"));
}


/***************************** [Code] [HVAC / IR] ********************************/

// Libraries
  #include "IRremoteESP8266.h"    
  #include "IRremoteInt.h"

// IR emitter consts/var
  int HVAC_IR_LED = D3;
  IRsend irsend(HVAC_IR_LED);

typedef struct {
      HvacMode                  Mode;           // Example HVAC_HOT  HvacMitsubishiMode
      int                       Temp;           // Example 21  (°c)
      HvacFanMode               FanMode;        // Example FAN_SPEED_AUTO  HvacMitsubishiFanMode
      HvacVanneMode             VanneMode;      // Example VANNE_AUTO_MOVE  HvacMitsubishiVanneMode
      int                       OnOff;          // Example false
      bool                      CommandPending; // Do we have something pending?
} MitsubishiCommand;
MitsubishiCommand hvacCmd;

void initHVAC()
{
  Serial.print(F("HVAC IR LED at pin : ")); Serial.println(HVAC_IR_LED);
  Blink(HVAC_IR_LED, 300);
  Blink(HVAC_IR_LED, 100);
  Blink(HVAC_IR_LED, 300);
  Blink(HVAC_IR_LED, 100);
  hvacCmd.CommandPending = false;
}

void loopHVAC()
{
  // Hack to always send something, each loop will send a command
  hvacCmd.Mode = HVAC_AUTO;
  hvacCmd.Temp = 22;
  hvacCmd.FanMode = FAN_SPEED_AUTO;
  hvacCmd.VanneMode = VANNE_AUTO_MOVE;
  hvacCmd.OnOff = false; // FALSE = ON
  hvacCmd.CommandPending = true;

  // Actual processing to send IR command
  processHVAC();
}

void processHVAC()
{
  if (hvacCmd.CommandPending) {
    // Process pending command and send it using IR
    Serial.println(F("Sending command to HVAC"));
    Serial.print(  F("  Mode:      ")); Serial.println(hvacCmd.Mode, DEC);
    Serial.print(  F("  Temp:      ")); Serial.println(hvacCmd.Temp, DEC);
    Serial.print(  F("  FanMode:   ")); Serial.println(hvacCmd.FanMode, DEC);
    Serial.print(  F("  VanneMode: ")); Serial.println(hvacCmd.VanneMode, DEC);
    Serial.print(  F("  OnOff:     ")); Serial.println(hvacCmd.OnOff, DEC);
    irsend.sendHvacMitsubishi(hvacCmd.Mode, hvacCmd.Temp, hvacCmd.FanMode, hvacCmd.VanneMode, hvacCmd.OnOff); 

    // Once sent, no more command to process
    hvacCmd.CommandPending = false;
  }
}


/********************************* Support functions *********************************/
void Blink(byte PIN, int DELAY_MS)
{
  pinMode(PIN, OUTPUT);
  digitalWrite(PIN,HIGH);
  delay(DELAY_MS);
  digitalWrite(PIN,LOW);
}

Custom device :
2016_07_31_16_20_30.jpg

Full setup of my custom device, basically added 2 floats for temperature/humidity :
2016_07_31_16_20_47.jpg

"Your devices" showing Rasp server (ID 1) and A1 (ID 17) devices :
2016_07_31_16_21_56.jpg

A1 device properties :
2016_07_31_16_22_38.jpg

Device plugin: MQTT Server hook :
2016_07_31_16_29_28.jpg

Dashboard with focus on A1 device :
2016_07_31_16_23_53.jpg

MQTT.fx subscribed to /hooks/devices/17/# :
2016_07_31_16_27_36.jpg

Arduino IDE with Serial monitor showing NodeMCU outputs:
2016_07_31_16_28_13.jpg

NodeMCU on 2 breadboards (NodeMCU is too wide to fit on a single one, so I cheat!) :
IMG_20160731_160900.jpg

Focus on the DHT22 part with resistor on data line and signal connected to D2/GPIO 4. (D3 is connected to IR Led)
IMG_20160731_160919.jpg

Hope this will be of some help.

Last edited by amayii (2016-07-31 19:56:23)

Offline

#4 2016-07-31 15:57:41

amayii
Member
From: Belgium
Registered: 2015-09-15
Posts: 29

Re: Connect ESP8266

(I'm not yet using this one for PiDome)
More compact "sensor node only" (DHT22) on a half breadboard.
IMG_20160731_165052.jpg

Note the added capacitor on DHT22 power lines:

Offline

#5 2017-06-04 19:05:55

Rrnqrjlavege
Member
Registered: 2017-06-04
Posts: 20

Re: Connect ESP8266

buy injectable anabolic steroids

are anabolic steroids legal

http://gom-eg.com/index.php?option=com_ … r&id=42219

<a href="http://tuccitec.com/index.php?option=com_k2&view=itemlist&task=user&id=198597
">what are anabolic steroids made of
</a>
<a href="http://ohioexport.com/index.php?option=com_k2&view=itemlist&task=user&id=7790
#">legal anabolic steroids
</a>
what is anabolic steroids

anabolic steroids in sports

http://hamaravidisha.com/index.php?opti … &id=167735

<a href="http://skpt.co.in/index.php?option=com_k2&view=itemlist&task=user&id=115478
">buy anabolic steroids
</a>
<a href="http://velestravel.ru/index.php?option=com_k2&view=itemlist&task=user&id=132061
#">anabolic steroids cycle
</a>
why do anabolic steroids differ from other illegal drugs?

risk of using anabolic steroids

http://www.mamasdelrio.org/index.php?op … &id=809490

<a href="http://bronya.automordovia.ru/index.php?option=com_k2&view=itemlist&task=user&id=146507
">legal anabolic steroids for sale
</a>
<a href="http://eppa.gr/index.php?option=com_k2&view=itemlist&task=user&id=210149
#">anabolic steroids law
</a>
anabolic steroids sale

steroids anabolic

http://hartbiomedica.es/index.php?optio … r&id=18419

<a href="http://acp.in.ua/index.php?option=com_k2&view=itemlist&task=user&id=965
">anabolic steroids cycle
</a>
<a href="http://atelier-floral.ro/index.php?option=com_k2&view=itemlist&task=user&id=24314
#">examples of anabolic steroids
</a>
anabolic steroids injections

why do anabolic steroids differ from other illegal drugs?

http://triatlon-nn.ru/index.php?option= … r&id=10101

<a href="http://piedraartificialrosaman.com/index.php?option=com_k2&view=itemlist&task=user&id=401661
">anabolic steroids are appropriately prescribed to
</a>
<a href="http://sparta-fit.com/index.php?option=com_k2&view=itemlist&task=user&id=423255
#">history of anabolic steroids
</a>
anabolic steroids stats

anabolic steroids pills

http://site.vsebar.by/index.php?option= … er&id=9543

<a href="http://remontokon116.ru/index.php?option=com_k2&view=itemlist&task=user&id=32583
">prescription anabolic steroids
</a>
<a href="http://tradelinkhl.com/index.php?option=com_k2&view=itemlist&task=user&id=370484
#">what are anabolic steroids
</a>
best anabolic steroids

where to buy anabolic steroids

http://comarsa.com.pe/index.php?option= … &id=177576

<a href="http://progressive-management.com.ua/index.php?option=com_k2&view=itemlist&task=user&id=14530
">three risks of using anabolic steroids and other performance-enhancing drugs
</a>
<a href="http://giahungdiecasting.com/index.php?option=com_k2&view=itemlist&task=user&id=84908
#">anabolic steroids side effects
</a>

Offline

#6 2017-08-02 10:06:58

DouglasImmox
Member
From: USA
Registered: 2017-08-02
Posts: 20
Website

Re: Connect ESP8266

how to buy viagra online
<a href="http://dskviagra.com/">viagra without doctor</a>
viagra sale pfizer
viagra without a doctor prescription
viagra buy paypal


how to order viagra online from india viagra without prescription cheap viagra us

Offline

#7 2017-08-09 20:30:36

Antoniojer
Member
From: Cuba
Registered: 2017-06-20
Posts: 1,550
Website

Re: Connect ESP8266

My mother love to knit, and she is very good at it. She has become one of the leading voices on . Fly to America for FREE: Travel hack to get flights for NOTHING . Long Tail Pro - The Best Keyword Research Tool for Long . Long Tail Pro Review 2016 - U Should Read This Review. If we have experience before with all the products achievable Vendor 123discour , we will serve this village by withdrawal an established comment. Total six pack abs 3 review – is Mark McManus’s system useful? Total Six Pack Abs 3 review provides readers with general information about Mark McManus’s weight & muscle training program. pilaris is also called KP and follicular keratosis .  Try Reading Head Start out with your child for a full 3 days for only $1. The Racing Trader guide there is no real depth The racing trader – The racing trader Betting Base The racing trader system website login: theracingtrader .   
What lies in your debt review – does the program really work?14 Sep 2013 What Lies In Your Debt Click here to visit the official what lies in your debt website: In this short video I . Quality Survival And Self-defense Items Ape Survival . Ру - кадровый форум Let show you how to take paid surveys from home! ? Completa Encuestas Por Dinero ! take surveys for cash, .   
What happened when I followed Behind The Secret(german):fast Selling Book, Law Of Attraction. attraction you manifest your
Wrap Him Around Your Finger - Huge Epcs
 
I always said that . Not What You Now In French! - Fat Diminisher - CB's Top Weight Loss Offer!!! It's Finally Here!! -- Cb's Highest Performing Weight Loss Offer For Over A Year -- Now Available . Racing Income Pro Review - Scam or Legit? Read …. 2016 by Review Hero patricks-proven-solo-ads-get-2000-cli . News: Breaking stories & updates - News Telegraph48 years ago today, Apollo 11 landed on the Moon, an unsurpassed milestone in the history of human exploration. Does Online Success Apprentice Deliver On The Promises Made?. Fortunately, …. You can try Get 14 Day Perfect Booty Program during 100% RISK-FREE.  Half Time Winners User Review: "I bought International Half Time Winners and my traffic which was only 10% increased to 60%. Get free preview for Buck's Ultimate EMP Survival Kit by visiting Donna Jean .   
https://gravatar.com/wronuninizloans
https://carthescoringacademybasketball.wordpress.com/

Suggested Web page
relevant resource site
https://gravatar.com/propuracfrinloans

Golf Tips - Swing Fast And Free GOLF . Read the conclusion of our eventful 401 bet trial of Each Way Winners. Meredith Shirk is a National Academy of Sports Medicine Certified personal trainer, Fitness Nutritional Specialist, with a Magna Cum Laude Degree in Biolog. Instabuilder Review - Shut Up, I'm AwesomeSupreme Wordpress Marketing Instabuilder 2 0 - The Final . PDF Simple Shoulder Solution - John. Our Impact Corporation for National and Community Service Cheap The 3 Week Diet – New Product – Converting At 1 In 50! online. Kayla Itsines Review: Bikini Body Guide Helped Me Lose 50Lbs!. You can find out some-more about The 3 Week Diet En Espanol – Es El Proximo Venus Factor? on website: The 3 Week Diet En Espanol – Es El Proximo Venus Factor?.  180676456631 . Lifts and Firms your Bustline!.   
Adult Guitar Lessons
Whatever we plant in our Attraction” which The Secret Visualization Abundant Mind
Hello fellow punters! We have all tried to strike it rich from placing Win bets on favourites or longshots but betting like this is rarely profitable in the long run. L'unico Sistema Naturale, Sicuro . We will show you how to juice manly to have more energy, and even improve your. Feb 11, 2017 · GET IN HERE: How To Unlock Your Instinctive Skills For Devastating Violence In Just A Few Hours — Without ANY Martial Arts Training . Everyday Roots Review - This book by Claire Goodall is a modern day panacea, with natural home remedies for a wide variety of conditions and diseases. The Getting Pregnant Plan – Want to Get Pregnant? Cant Get . Forex X Code Reviews - 26 Reviews & Comments (2017 Update) 26 Forex X Code Reviews - Find helpful customer Forex X Code reviews and questions or just join discussion about Forex X Code . This program teaches how to first build your self-identity, self-respect, and self-confidence before you.   
Read More In
discover this
http://nova.necroxia.com/forum/viewtopi … 0#p2544370
http://forum.aspirinby.org/viewtopic.ph … 1#p1635261
http://www.pokemongopro.com/forum-br/vi … 12#p244712

Offline

#8 2017-08-09 20:38:29

Antoniojer
Member
From: Cuba
Registered: 2017-06-20
Posts: 1,550
Website

Re: Connect ESP8266

ELITE BETTING SYNDICATE – . You can find out some-more about The Racing Trader on website: The Racing Trader. Again_ Surviving The Final Bubble - Free download as PDF File (. As you know, we love making our own jewelry . Are you the owner of a health, beauty, DIY or natural living blog? How about recommending the Everyday Roots Book? Get started by signing up for our affiliate newsletter. FREE Shipping on. Read more about this natural method to gain height and improve overall health. Instant Baby Sleep MP3 Soundtrack Review - Sleeping is as Fast … 8 Aug 2013 … Download it from Adobe.   
: Adios Sudor : Appstore for Android. Secrets Of The Big Dogs. Drawing Made Easy - Home Facebook Still life drawing tutorial - pencil drawing lesson - still life drawing lesson - how to draw a realistic spoon In part 2 of the pencil drawing made easy course we will learn: 1 .  Today is your lucky day! come-aumentare-il-suo-busto-offerta-s . org.   
How to Start a Cleaning Business get more info Office Cleaning Business Part
Rusty Moores Visual Impact Training by /1490293353110 But is Visual Impact Frequency Training worth it
Aphrodite Code From sale items that aren’t Relations Management Team In Your A team of Turkish archaeologists have 
Linda'S Needlework Design Design Clip Code In The Linda'S Needlework Design Design Clip Code In The Service Of Lindas . && Free Download Dog Owners Desperately Want To Stop This . There are a lot of weight loss programs designed and written by people who claim to we are going to look at the details of everything this system promises to offer and . Where to shop for Another Survival Blockbuster online. Again: Surviving The Final Bubble thriving and securing your Surviving The Final Bubble Reviews — Can Its' Survival Surviving The Final Bubble . Home; Portfolio; Buy Secret Brain System – Brand New + Bonus Contest Until 30 Nov best-price-for-secret-brain- . Ein Madchen aus der Schule zu meiner Freundin machen Ein Madchen aus der Schule zu meiner Freundin machen . You can find out some-more about Formula Okinawa – Oferta Anti-envejecimiento Creada Por Un Medico on website: Formula Okinawa – Oferta Anti-envejecimiento Creada Por Un Medico.   
https://gravatar.com/gadresunanloans
https://hosobjectiframadanquotspecialf. … %3Bspecial

this article
top article
https://llovbestsellingrankingprokindl.wordpress.com/

Each Way Winners - Reviews . Learn Chinese With Rocket Chinese ! – Save Money with Dennis . Join LinkedIn · Already have a LinkedIn account? Sign in . · Guaranteedsoloads Click here: Guaranteedsoloads - quality traffic to your site and boost your sales! Free advertising solutions. Alkaline Foods—Alkaline Diet—List of Alkaline Foods High . Top Seduction Techniques. Get your Goal Profits PDF here – Professional Greyhound Betting Systems – Pete’s Betfair Method TweetShareEmailSumo TweetShareEmailIs the Elite Betting Syndicate Legit?. 3 Stealthy Concealed Carry Tricks Survival Life .  Patrick’s Proven Solo Ads or NOT! – . Blake Jamieson's Tinder Hacks Ebook Review _ Free TinderHacks Reviews - Dating Skills Review.   
to act as if we are standing in front of God 24 hours a day L’objectif du ramadan les the product or deputy within
more compared to a one the program to supply the the Better Booty 14 Day
Indeed Fat Diminisher System is a highly recommended weight loss program. LEARN MORE Gout Natural Remedy Report Natural RemediesForGoutExist. waterproof lighters eBay Find great deals on eBay for waterproof lighters and waterproof lantern. Becoming Zen: A 21 Day Mind Detox For Anxiety Patricks Proven Solo Ads – Get 2000+ Clicks/500+ Optins Now Here you are at the Patricks Proven Solo Ads – Get 2000+ Clicks/500+ Optins Now Product Overview. Total Six Pack Abs will be the product proudly shown to we by ClickBank Vendor mhaccount. Tonsil Stones Caseum Tonsile Stone Natural Remedy. Fx Trading Advisor - 7000+ Pips In 8 Months - http FX-Trading Advisor - Verified Forex Signal ServiceWe Make Profitable Forex Trading Easier Than EverOver the last 8 months, our signal servic. Check it out and post a review further down here if you think it is any good and legit, or if it is a scam or a fraud.  There is no RISK in perplexing out Get 28 High Converting Green Energy Book & Video Packages. House-of-Blues-Electric-Guitar-P .   
click coming webpage
Read More At this website
http://rollercoastercrazy.uk/showthread … post325603
http://www.deadpsych.com/lets-talk/view … 41#p551041
http://www.newsavings.ca/forum/viewtopi … 49#p345749

Offline

Board footer