Jump to content
  • 0

Adapt automatic backup Acis to Frozen


Question

Posted

hi guys! anyone can help me to adapt this code for jfrozen rev 1132?

 

Index: net.sf.l2j;Config.JAVA
===================================================================
--- net.sf.l2j;Config.JAVA (revision)
+++ net.sf.l2j;Config.JAVA (working copy)

+   /** Auto Save Data Base */
+   public static boolean ENABLE_BACKUP_BOOLEAN;
+   public static String NAME_DATA_BASE;


+   ENABLE_BACKUP_BOOLEAN = Boolean.parseBoolean(aCis.getProperty("AutoSaveDB", "True"));
+   NAME_DATA_BASE = aCis.getProperty("URL_DB", "aCis");




Index: Dev.AutoBackup;BackupDBSave.JAVA
===================================================================
--- Dev.AutoBackup;BackupDBSave.JAVA (revision)
+++ Dev.AutoBackup;BackupDBSave.JAVA (working copy)

+   package Dev.AutoBackup;
+
+   import java.io.BufferedReader;
+   import java.io.File;
+   import java.io.FileInputStream;
+   import java.io.FileOutputStream;
+   import java.io.IOException;
+   import java.io.InputStreamReader;
+   import java.net.URL;
+   import java.sql.Connection;
+   import java.sql.PreparedStatement;
+   import java.sql.ResultSet;
+   import java.text.DateFormat;
+   import java.text.SimpleDateFormat;
+   import java.util.Date;
+   import java.util.zip.ZipEntry;
+   import java.util.zip.ZipOutputStream;
+
+   import net.sf.l2j.commons.concurrent.ThreadPool;
+
+   import net.sf.l2j.Config;
+   import net.sf.l2j.L2DatabaseFactory;
+   import net.sf.l2j.util.Mysql;
+
+
+   /**
+    * @author COMBATE
+    *
+    * note to RESTORE
+    * Unzip the file
+    * Then go to database via navicat and run Execute SQL File
+    * Then declick the option "Run multiple queries in each execution" to avoid conflict with locks of tables
+    */
+   public class BackupDBSave
+   {
+       private String database_name = Config.NAME_DATA_BASE;
+       private boolean DEBUG_SYSTEM = false;
+       private long initializeAfterTime = 1000 * 60 * 60 * 1; // Start in 2 hour
+       private long checkEveryTime = 1000 * 60 * 60 * 1; // Every 6 hours
+    
+       protected BackupDBSave()
+       {
+           ThreadPool.scheduleAtFixedRate(() -> BackupDBToSql(), initializeAfterTime, checkEveryTime);
+        
+           System.out.println("Database Backup Manager: Loaded");
+       }
+
+       public void BackupDBToSql()
+       {
+           String pathOfMysql = "\"";
+        
+           Connection con = null;
+           PreparedStatement statement = null;
+           ResultSet rs = null;
+        
+           try
+           {
+               con = L2DatabaseFactory.getInstance().getConnection();
+               statement = con.prepareStatement("SELECT @@basedir");
+               rs = statement.executeQuery();
+            
+               while (rs.next())
+               {
+                   pathOfMysql += rs.getString(1);
+               }
+           }
+           catch (Exception e)
+           {
+               e.printStackTrace();
+           }
+           finally
+           {
+               Mysql.closeQuietly(con, statement, rs);
+           }
+        
+           if (pathOfMysql.isEmpty())
+           {
+               System.out.println("Error on backup database. Empty path of mysql.");
+               return;
+           }
+        
+           // Give the specific path (pathOfMysql out = C:\Program Files\MySQL\MySQL Server 5.7\)
+           pathOfMysql += "bin\\mysqldump" + "\"";
+        
+           if(DEBUG_SYSTEM) System.out.println("Path of mysql: " + pathOfMysql);
+        
+           // Initialize code for backup
+           try
+           {
+               // Section for path of system
+               URL applicationRootPathURL = getClass().getProtectionDomain().getCodeSource().getLocation();
+               File applicationRootPath = new File(applicationRootPathURL.getPath());
+               File myFile = new File(applicationRootPath.getParent());
+               File lastMyFile = new File(myFile.getParent());
+
+               String dbUser = Config.DATABASE_LOGIN;
+               String dbPass = Config.DATABASE_PASSWORD;
+            
+               String commandOfMysqlDump = " " + database_name + " --single-transaction -u" + dbUser + " -p" + dbPass + " --skip-create-options --skip-comments --disable-keys > ";
+            
+               /* NOTE: Creating Path Constraints for folder saving */
+               /* NOTE: Here the backup folder is created for saving inside it */
+               String folderPath = "backup";
+            
+               /* NOTE: Creating Folder if it does not exist */
+               File f1 = new File(folderPath);
+               f1.mkdir();
+            
+               /* NOTE: Creating Path Constraints for backup saving */
+               /* NOTE: Here the backup is saved in a folder called backup with the name backup.sql */
+               String pathUntilDirectory = (lastMyFile.getAbsolutePath() + "\\backup\\").replaceAll("%20", " ");
+               String savePath = ("\""+pathUntilDirectory + "backup.sql\"").replaceAll("%20", " ");
+
+               /* NOTE: Used to create a cmd command */
+               String commandToExecute = "cmd /c "+ pathOfMysql + commandOfMysqlDump + savePath;
+            
+               if (DEBUG_SYSTEM)
+               {
+                   System.out.println("Save path of sql file: " + savePath);
+                   System.out.println("Command To Execute: " + commandToExecute);
+               }
+            
+               /* NOTE: Executing the command here */
+               Process runtimeProcess = Runtime.getRuntime().exec(new String[] {"cmd", "/c", commandToExecute });
+            
+               if (DEBUG_SYSTEM)
+               {
+                   BufferedReader stdInput = new BufferedReader(new InputStreamReader(runtimeProcess.getInputStream()));
+                   BufferedReader stdError = new BufferedReader(new InputStreamReader(runtimeProcess.getErrorStream()));
+                
+                   // read the output from the command
+                   System.out.println("Here is the standard output of the command:\n");
+                   String s = null;
+                   while ((s = stdInput.readLine()) != null) {
+                       System.out.println(s);
+                   }
+                
+                   // read any errors from the attempted command
+                   System.out.println("Here is the standard error of the command (if any):\n");
+                   while ((s = stdError.readLine()) != null) {
+                       System.out.println(s);
+                   }
+               }
+            
+               int processComplete = runtimeProcess.waitFor();
+            
+               /* NOTE: processComplete=0 if correctly executed, will contain other values if not */
+               if (processComplete == 0)
+               {
+                   System.out.println("Backup to SQL Complete");
+                
+                   // Zip the sql file
+                   zipAFile(pathUntilDirectory);
+                
+                   // Delete the backup.sql file
+                   deleteAFile(savePath.replaceAll("\"", ""));
+               }
+               else
+               {
+                   System.out.println("Backup to SQL Failure");
+               }
+           }
+           catch (IOException | InterruptedException ex)
+           {
+               System.out.println("Error at Backuprestore" + ex.getMessage());
+           }
+       }
+    
+       @SuppressWarnings("resource")
+       private static void zipAFile(String pathToSave)
+       {
+           byte[] buffer = new byte[1024];
+        
+           try
+           {
+               DateFormat dateFormat = new SimpleDateFormat("dd-MM-yyyy HH-mm-ss");
+               Date date = new Date();
+            
+               FileOutputStream fos = new FileOutputStream(pathToSave + "Backup_"+dateFormat.format(date)+".zip");
+               ZipOutputStream zos = new ZipOutputStream(fos);
+               ZipEntry ze = new ZipEntry("backup.sql");
+               zos.putNextEntry(ze);
+               FileInputStream in = new FileInputStream(pathToSave + "\\backup.sql");
+            
+               int len;
+               while ((len = in.read(buffer)) > 0)
+               {
+                   zos.write(buffer, 0, len);
+               }
+            
+               in.close();
+               zos.closeEntry();
+            
+               // remember close it
+               zos.close();
+            
+               System.out.println("Done the zip of backup.");
+            
+           }
+           catch (IOException ex)
+           {
+               ex.printStackTrace();
+           }
+        
+       }
+    
+       private static void deleteAFile(String path) {
+           try{
+               File file = new File(path);
+               System.out.println(file.delete() ? (file.getName() + " is deleted!") : ("Delete operation is failed."));
+            
+           }catch(Exception e){
+
+               e.printStackTrace();
+
+           }
+       }
+
+       public static BackupDBSave getInstance()
+       {
+           return SingletonHolder._instance;
+       }
+    
+       private static class SingletonHolder
+       {
+           protected static final BackupDBSave _instance = new BackupDBSave();
+       }
+   }
+    

Index: Dev.AutoBackup;Mysql.JAVA
===================================================================
--- Dev.AutoBackup;Mysql.JAVA (revision)
+++ Dev.AutoBackup;Mysql.JAVA (working copy)

+   package Dev.AutoBackup;
+
+
+   import java.sql.Connection;
+   import java.sql.PreparedStatement;
+   import java.sql.ResultSet;
+   import java.sql.SQLException;
+   import java.sql.Statement;
+   import java.util.logging.Logger;
+
+   import net.sf.l2j.L2DatabaseFactory;
+
+   /**
+    * @author COMBATE
+    *
+    */
+   public abstract class Mysql
+   {
+       private static final Logger _log = Logger.getLogger(Mysql.class.getName());
+
+       /**
+        * Performs a simple sql queries where unnecessary control parameters <BR>
+        * NOTE: In this method, the parameters passed are not valid for SQL-injection!
+        * @param db
+        * @param query
+        * @param vars
+        * @return
+        */
+       public static boolean setEx(L2DatabaseFactory db, String query, Object... vars)
+       {
+           Connection con = null;
+           Statement statement = null;
+           PreparedStatement pstatement = null;
+           boolean successed = true;
+        
+           try
+           {
+               if(db == null)
+                   db = L2DatabaseFactory.getInstance();
+
+               con = db.getConnection();
+               if(vars.length == 0)
+               {
+                   statement = con.createStatement();
+                   statement.executeUpdate(query);
+                   statement.close();
+               }
+               else
+               {
+                   pstatement = con.prepareStatement(query);
+                   setVars(pstatement, vars);
+                   pstatement.executeUpdate();
+                   pstatement.close();
+               }
+               con.close();
+           }
+           catch(Exception e)
+           {
+               _log.warning("Could not execute update '" + query + "': " + e);
+               e.printStackTrace();
+               successed = false;
+           }
+           finally
+           {
+               closeQuietly(con, pstatement);
+               closeQuietly(statement);
+           }
+           return successed;
+       }
+
+       public static void setVars(PreparedStatement statement, Object... vars) throws SQLException
+       {
+           Number n;
+           long long_val;
+           double double_val;
+           for(int i = 0; i < vars.length; i++)
+               if(vars[i] instanceof Number)
+               {
+                   n = (Number) vars[i];
+                   long_val = n.longValue();
+                   double_val = n.doubleValue();
+                   if(long_val == double_val)
+                       statement.setLong(i + 1, long_val);
+                   else
+                       statement.setDouble(i + 1, double_val);
+               }
+               else if(vars[i] instanceof String)
+                   statement.setString(i + 1, (String) vars[i]);
+       }
+
+       public static boolean set(String query, Object... vars)
+       {
+           return setEx(null, query, vars);
+       }
+
+       public static boolean set(String query)
+       {
+           return setEx(null, query);
+       }
+    
+       public static void closeQuietly(Connection conn)
+       {
+           try {
+               close(conn);
+           } catch (SQLException e) { // NOPMD
+               // quiet
+           }
+       }
+
+       public static void closeQuietly(Connection conn, Statement stmt, ResultSet rs) {
+
+           try {
+               closeQuietly(rs);
+           } finally {
+               try {
+                   closeQuietly(stmt);
+               } finally {
+                   closeQuietly(conn);
+               }
+           }
+       }
+    
+       public static void closeQuietly(Connection conn, Statement stmt)
+       {
+           try {
+               closeQuietly(stmt);
+           } finally {
+               closeQuietly(conn);
+           }
+       }
+
+       public static void closeQuietly(ResultSet rs) {
+           try {
+               close(rs);
+           } catch (SQLException e) { // NOPMD
+               // quiet
+           }
+       }
+
+       public static void closeQuietly(Statement stmt) {
+           try {
+               close(stmt);
+           } catch (SQLException e) { // NOPMD
+               // quiet
+           }
+       }
+
+       public static void close(Connection conn) throws SQLException {
+           if (conn != null) {
+               conn.close();
+           }
+       }
+
+       public static void close(ResultSet rs) throws SQLException {
+           if (rs != null) {
+               rs.close();
+           }
+       }
+
+       public static void close(Statement stmt) throws SQLException {
+           if (stmt != null) {
+               stmt.close();
+           }
+       }
+   }
+

Index: net.sf.l2j.gameserver;GameServer.JAVA
===================================================================
--- net.sf.l2j.gameserver;GameServer.JAVA (revision)
+++ net.sf.l2j.gameserver;GameServer.JAVA (working copy)

+   import Dev.AutoBackup.BackupDBSave;

+   StringUtil.printSection("DataBase Auto Save");
+   if (Config.ENABLE_BACKUP_BOOLEAN) {
+       BackupDBSave.getInstance();
+       LOGGER.info("[DataBase Auto Save]: Enabled");
+   }else
+   {
+       LOGGER.info("[DataBase Auto Save]: Desatived");
+   }

Index: gameserver.config.aCis.aCis.properties
===================================================================
--- gameserver.config.aCis.aCis.properties (revision)
+++ gameserver.config.aCis.aCis.properties (working copy)

# Enable Auto Save DataBase
AutoSaveDB = True

#Name DataBase
#Ex: l2jdb
URL_DB = aCis

 

4 answers to this question

Recommended Posts

  • 0
Posted

Make backup database with runned server it's stupid idea. Backup will always is outdated. Better add to bat/sh scripts the dump task for saving database snapshot with relevant data.

  • 0
Posted
5 hours ago, Rootware said:

Make backup database with runned server it's stupid idea. Backup will always is outdated. Better add to bat/sh scripts the dump task for saving database snapshot with relevant data.

Hi @Rootware ! thanks for answer. can, maybe if u have some time, tell me how can i do it that?

  • 0
Posted (edited)

"mysql generate backup" on Google. And yes, it is kinda stupid to save during runtime since some data is stored only when server shutdowns, or when player shutdowns. If you save in middle of nowhere, then data integrity will be different than when server is currently closing.

 

Properly close your server, then use mysqldump.

 

It's the typical sort of code which "sounds cool", but is at best pointless, at worst dangerous (since you can save things in middle of something, and got no guarantee the actual engine properly ended).

 

An "ok" move would be to generate it only when server actually shutdowned, after all server operations ended.

Edited by Tryskell
  • 0
Posted
5 hours ago, Tryskell said:

"mysql generate backup" on Google. And yes, it is kinda stupid to save during runtime since some data is stored only when server shutdowns, or when player shutdowns. If you save in middle of nowhere, then data integrity will be different than when server is currently closing.

 

Properly close your server, then use mysqldump.

 

It's the typical sort of code which "sounds cool", but is at best pointless, at worst dangerous (since you can save things in middle of something, and got no guarantee the actual engine properly ended).

 

An "ok" move would be to generate it only when server actually shutdowned, after all server operations ended.

@Tryskell hi man! so, you say make a sincronized backup with mysql when the server restart?

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • Download Here: https://sitehunterus.blogspot.com/2025/12/custom-proxy-checker-check-proxies.html VirusTotal https://www.virustotal.com/gui/file/b74418850d82dbf0031e0549f20239b5bff5dbba7a59903fcf9ba55780002a4e Visit my Blogger list to download 100% free software https://www.freetoolss.com/ https://blackhat8.blogspot.com/ https://hack-crack9.blogspot.com/ https://hackernoons.blogspot.com/ https://sharetools99.blogspot.com/
    • Mustang Service — not “just another service” ▪ We don’t just redraw documents — we reverse-engineer the system’s logic. And we do it beautifully. ▪ Mustang Service is for when you need more than a quick Photoshop touch-up — you need to pass verification at the edge of the impossible. When you’re not looking for a template, but ordering a solution for your case. › What we deliver in practice: → deep redraws with no traces of editing → an expert approach to verification algorithms → guides from people who actually do it — not rehashes of someone else’s manual ▪ With us you get not just a service — you get context. We show how the system thinks, and how to navigate it. ▪ We work with those who value results, not excuses. If you’re not with us yet — just take a look at what we publish. Mustang Service — done right when everything else hasn’t worked. › TG: @mustang_service ( https:// t.me/ mustang_service ) › Channel: Mustang Service ( https:// t.me/ +6RAKokIn5ItmYjEx ) #redraw #verification #documents #graphics #photoshop #kyc #MustangService
    • I think you have other threads to advertise a shit server...  If you sell items we dont need to know where you go after quit. 
    • WTS GOLD WEAPONS +10-16 APELLA 75 BOSS JEWELS AQ/BAIUM/ ADENA MATS MOS/HORUTH/GARA/ ALL JEWELS L2GOLD.IN   L2GOLD.IN   LINEAGE2.GOLD   L2-GOLD.ORG   CHEAP price (we leave server and go play gold.co .cc) Message me here for more info and contacts
    • General Trackers :   IPTorrents invite IPTorrents account 1 tb TorrentLeech invite Torrentleech account 1 tb buffer  InTheShaDow ( ITS ) account Acid-lounge invite Torrentday invite Crnaberza account Abn.Lol account Limit-of-eden account Norbits account Xspeeds account Xspeeds invite Bemaniso invite Wigornot account Bithumen invite Filelist account Funfile invite AvistaZ invite Potuk.net invite ResurrectThe.Net invite GrabThe.Info invite Greek-Team invite LinkoManija invite Fano.in account tracker.czech-server.com Speed.cd invite Arab-torrents.net account Arabscene.me account Scenetime account 4thd.xyz invite Btarg.com.ar account Dedbit invite Estone.cc account Speedapp invite Finvip invite Fluxzone account GigaTorrents account Gimmepeers account Haidan.video invite Mojblink account Mycarpathians invite Newinsane.info account Oscarworld.xyz account Peers.FM invite Pt.msg.vg account Ransackedcrew account Redemption invite Scene-rush account Seedfile.io invite Teracod invite Torrent.ai account Torrentmasters invite Ttsweb invite X-files invite X-ite invite Ncore account TorrentHR account Rptorrents account BwTorrents account Superbits invite Krazyzone account Immortalseed account Tntracker invite Pt.eastgame.org account Bitturk account Rstorrent account Tracker.btnext invite Torrent-turk.de account BeiTai.PT account Pt.keepfrds account 52pt.site account Pthome account Torrentseeds account Aystorrent account Blues-brothers.biz invite Divteam account Thesceneplace invite CinemaMovies.pl account Brasiltracker account Patiodebutacas account Newheaven.nl account  Swarmazon.club invite Bc-reloaded account Crazyspirits account Silentground invite Omg.wtftrackr invite Milkie.cc invite Breathetheword invite Madsrevolution account Chilebt account Yubraca account Uniongang.tv account Frboard account Exvagos account Diablotorrent account Microbit account Carp-hunter.hu account Majomparade.eu account Theshinning.me account Youiv.info account Dragonworld-reloaded account Sharewood.tv account Partis.si account Digitalcore.club invite Fuzer.me account R3vuk.wtf invite Ztracker account 1 tb buffer 3changtrai account Best-core.info account Bitsite.us account Eliteunitedcrew invite Exitorrent.org account Tophos invite Torrent.lt account Sktorrent.eu account Oshen account Blackhattorrent account Pirata.digital account Esharenet account Ohmenarikgi.la Pirate-share account Immortuos account Kiesbits account Cliente.amigos-share.club account Broadcity invite Ilovetorzz account Torrentbytes account Polishsource account Portugas invite Shareisland account ArabaFenice account Hudbt.hust.edu.cn account Audiences account Nanyangpt account Pt.sjtu.edu.cn account Pt.zhixing.bjtu.edu.cn account Byr.pt invite Ptfiles invite Red-bits account Pt.hdpost.top account Irrenhaus.dyndns.dk (NewPropaganda) account Mnvv2.info (MaxNewVision V2) account 1ptba.com account Spidertk.top account Film-paleis account Generation-free account Aftershock-tracker account Twilightsdreams account Back-ups.me invite Sor-next.tk ( Spirit Of Revolution ) account Tfa.tf ( The Falling Angels ) account Hdmayi account S-f-p.dyndns.dk ( Share Friends Projekt ) account Unlimitz.biz account Pttime account St-tracker.eu account New-retro.eu account Zbbit account Tigers-dl.net account Jptvts.us account Lat-team account Club.hares.top account Falkonvision-team account Concen account Drugari account T.ceskeforum account Peeratiko.org account Zamunda.se account Central-torrent.eu account h-o-d.org account Torrentleech.pl account Demonoid invite Lst.gg account Fakedoor.store account LaidBackManor account Vrbsharezone.co.uk invite Torrenteros account Arenaelite account Datascene account Tracker.0day.community Tapochek.net invite Ptchina invite Lesaloon account Exyusubs account Therebels.tv account Ubits.club invite Zmpt.cc account Turktorrent.us account Dasunerwarte account Hawke.uno account Monikadesign account Fearnopeer account Alpharatio account Wukongwendao.top account Chinapyg account Azusa.wiki account Yggtorrent.top account Torrentdd account Cyanbug.net invite Hhanclub.top account Wintersakura.net account Xthor account Tctg.pm account Finelite invite Agsvpt.com account Pt.0ff.cc invite Qingwapt.com account Xingtan.one account Ptcafe.club invite Theoldschool.cc account W-o-t.pro account Coastal-crew.bounceme.net account Darkpeers.org account Pianyuan.org account Seedpool.org  account Tempelbox account Pt.itzmx.com account Capybarabr.com account Itatorrents.xyz  account Letseed.org account The-new-fun.com  account Malayabits.cc account Trellas.me account Yu-scene.net account Futuretorrent.org account   Movies Trackers :   Anthelion account Pixelhd account Cinemageddon account DVDSeed account Cinemageddon account Cinemaz account Retroflix account Classix-unlimited - invite Movie-Torrentz (m2g.link) invite Punck-tracker.net account Tmghub account Tb-asian account Cathode-ray.tube account Greatposterwall account Telly account Arabicsource.net account Upload.cx account Crabpt.vip invite Onlyencodes.cc account Exyusubs account Hellashut.net invite   HD Trackers :   Hdf.world account Torrentland.li account HdSky account Hdchina account Chdbits account Totheglory account Hdroute account Hdhome account TorrentCCF aka et8.org account 3DTorrents invite HD-Torrents account Bit-HDTV account HDME.eu invite Hdarea.co account Asiancinema.me account JoyHD invite HDSpace invite CrazyHD invite Bluebird-hd invite Htpt.cc account Hdtime invite Ourbits.club account Hd4fans account Siambit account Privatehd account Springsunday account Tjupt account Hdcity.leniter invite Ccfbits account Discfan account Pt.btschool.club account Ptsbao.club invite Hdzone.me invite Danishbytes account Zonaq.pw account Tracker.tekno3d account Arabp2p account Hd-united account Reelflix.xyz account Hdatmos.club account Anasch.cc invite Tigris-t account Nethd.org account Hd.ai invite Hitpt.com account Hdmonkey account Dragonhd.xyz account Hdclub.eu account Forum.bluraycd.com account Carpt account Hdfun.me invite Pt.hdupt invite Puntotorrent account Ultrahd account Rousi.zip account Bearbit account Hdturk.club account Asiandvdclub account Star-space.net account Nordicq.org account Hdkyl.in account Utp.to account   Music Trackers :   Dicmusic account Music-Vid account Open.cd account LzTr account ProAudioTorrents invite Jpopsuki invite TranceTraffic invite Audionews invite Kraytracker invite Libble.me invite Losslessclub invite Indietorrents.com invite Dimeadozen account Funkytorrents invite Karaokedl account zombtracker.the-zomb account Concertos account Sugoimusic account Satclubbing.club invite Metal.iplay invite Psyreactor invite Panda.cd account Adamsfile account Freehardmusic account Tracker.hqmusic.vn accouunt Twilightzoom account 3 tb buffer Hiresmusic account Metalguru account Musictorrents.org account Musebootlegs.com invite Zappateers.com account   E-Learning Trackers :   BitSpyder invite Brsociety account Learnbits invite Myanonamouse account Libranet account 420Project account Learnflakes account Pt.soulvoice.club account P2pelite account Aaaaarg.fail invite Ebooks-shares.org account Abtorrents account Pt.tu88.men invite Docspedia.world invite   TV-Trackers :   Skipthecommericals Cryptichaven account TV-Vault invite Shazbat.TV account Myspleen account Tasmanit.es invite Tvstore.me account Tvchaosuk account Jptv.club account Tvroad.info   XXX - Porn Trackers :   FemdomCult account Pornbay account Pussytorrents account Adult-cinema-network account Bootytape account 1 Tb buffer Exoticaz account Bitporn account Kufirc account Gaytorrent.ru invite Nicept account Gay-torrents.org invite Ourgtn account Pt.hdbd.us account BitSexy account Happyfappy.org account Kamept.com account Lesbians4u.org account   Gaming Trackers :   Mteam.fr account BitGamer invite Retrowithin invite Gamegamept account   Cartoon/Anime/Comic Trackers :   Animeworld account Oldtoons.world account U2.dmhy account CartoonChaos invite Animetorrents account Mononoke account Totallykids.tv account Bakabt.me invite Revanime account Ansktracker account Tracker.shakaw.com.br invite Bt.mdan.org account Skyey2.com account Animetracker.cc Adbt.it.cx invite Tracker.uniotaku.com account   Sports Trackers :   MMA-Tracker invite T3nnis.tv invite AcrossTheTasman account RacingForMe invite Sportscult invite Ultimatewrestlingtorrents account Worldboxingvideoarchive invite CyclingTorrents account Xtremewrestlingtorrents account Tc-boxing invite Mma-torrents account Aussierul invite Xwt-classics account Racing4everyone account Talk.tenyardtracker account Stalker.societyglitch invite Extremebits invite Rgfootball.net account F1carreras.xyz account   Software/Apps Trackers :   Brokenstones account Appzuniverse invite Teamos.xyz account Macbb.org account Graphics Trackers: Forum.Cgpersia account Gfxpeers account Forum.gfxdomain account   Documentary Trackers:   Forums.mvgroup account   Others   Fora.snahp.eu account Board4all.biz account Filewarez.tv account Makingoff.org/forum account Xrel.to account Undergunz.su account Corebay account Endoftheinter.net ( EOTI ) account Thismight.be invite Skull.facefromouter.space account Avxhm.se (AvaxHome) account Ssdforum account Notfake.vip account Intotheinter.net account Tildes.net invite Thetoonz account Usinavirtual account Hdclasico invite HispaShare account Valentine.wtf account Adit-hd account Forum-andr.net account Warezforums account Justanothermusic.site account Forbiddenlibrary.moe account Senturion.to account Movieparadise account Militaryzone account Dcdnet.ru account Sftdevils.net account Heavy-r.com account New-team.org account Ddl.tv account Filewarez.club account Hispamula.org account Hubwarez.tv account   NZB :   Drunkenslug account Drunkenslug invite Usenet-4all account Brothers-of-Usenet account Dognzb.cr invite Kleverig account Nzb.cat account Nzbplanet.net invite Ng4you.com account Nzbsa.co.za account Bd25.eu account NZB.to account Samuraiplace account Tabula-rasa.pw account Abhdtv.net account Abook.link account Comix.pw account House-of-usenet Secretbinaries.net account Vnext.to account Stockboxx.top account   Prices start from 3 $ to 100 $   Payment methods: Crypto, Neteller, Webmoney, Revolut   If you want to buy something send me a pm or contact me on:   Email: morrison2102@gmail.com   Discord: LFC4LIFE#4173   Telegram: https://t.me/LFC4LIFE4173   Skype: morrison2102@hotmail.com
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock