const fs = require('fs').promises;
const path = require('path');
const bulkInsert = require('../src/utils/bulk-insert');

const affiliates = [
	{
		id: 'archangel_share',
		channel: 'archangel',
		url: 'https://join.archangelvideo.com/track/MzQ3LjEuMS4xLjAuMC4wLjAuMA',
		comment: 'revshare',
	},
	{
		id: 'kink_params',
		network: 'kink',
		parameters: 't=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		comment: '50%',
	},
	{
		id: 'bang_signup',
		network: 'bang',
		parameters: 't=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		comment: '$25 per signup',
	},
];

const bannerTags = {
	// 21sextury
	'21sextury_300_250_anal': ['anal', 'blonde'],
	'21sextury_770_76_gina_gerson_dp': ['dp', 'anal', 'mfm', 'blonde'],
	'21sextury_770_76_veronica_leal_dp': ['dp', 'anal', 'mfm', 'blowjob', 'blonde'],
	'21sextreme_300_250_cum': ['facial', 'cum-in-mouth'],
	'21naturals_315_300': ['brunette', 'natural-boobs'],
	'21naturals_315_300_1': ['blonde', 'natural-boobs'],
	'21naturals_315_300_gina_gerson': ['sex', 'blonde', 'natural-boobs'],
	'21naturals_315_300_ginebra_bellucci': ['sex', 'brunette', 'natural-boobs'],
	'21naturals_315_300_lana_roy_anal': ['anal', 'brunette', 'natural-boobs'],
	'21naturals_770_76_alexis_crystal': ['blowjob', 'blonde'],
	'21naturals_970_90': ['sex', 'brunette'],
	// archangel
	archangel_970_90_kendra_lust: ['dp', 'anal', 'sex', 'interracial', 'black'],
	// dogfart
	wefuckblackgirls_728_90_loss: ['mfm', 'threesome', 'anal', 'black', 'interracial'],
	dfxtra_900_250_mfm: ['mfm', 'threesome', 'black', 'interracial'],
	dfxtra_900_250_gay_anal: ['gay', 'anal', 'black', 'interracial'],
	dfxtra_300_250_mfm: ['mfm', 'threesome', 'black', 'interracial'],
	dfxtra_300_250_gay_bj: ['gay', 'blowjob', 'black', 'interracial'],
	blacksonblondes_900_250_mfm: ['mfm', 'threesome', 'black', 'interracial'],
	blacksonblondes_900_250_mfm_hj: ['mfm', 'threesome', 'handjob', 'black', 'interracial'],
	blacksonblondes_300_250_mfm: ['mfm', 'threesome', 'black', 'interracial'],
	blacksonblondes_300_250_mff_april: ['mff', 'threesome', 'black', 'interracial'],
	blacksonblondes_300_250_mff_april2: ['mff', 'threesome', 'black', 'interracial'],
	// evilangel
	evilangel_728_90_adriana_chechik_gangbang: ['gangbang', 'airtight', 'dp', 'dvp', 'facial', 'brunette'],
	evilangel_728_90_kenzie_reeves_lexi_lore: ['anal', 'mff', 'blowjob', 'blonde'],
	evilangel_970_90_one_dollar: ['sex', 'mff'],
	// julesjordan
	julesjordan_728_90_jill_kassidy: ['sex', 'blowjob', 'black-cock', 'brunette'],
	julesjordan_728_90_angela_white: ['sex', 'black-cock', 'brunette'],
	julesjordan_728_90_adriana_chechik: ['anal', 'black-cock', 'brunette'],
	julesjordan_728_90_autumn_falls: ['sex', 'big-boobs', 'brunette'],
	julesjordan_728_90_gabbie_carter: ['sex', 'blowjob', 'facefucking', 'big-boobs', 'brunette'],
	manuelferrara_728_90_asses: ['big-butt'],
	// kink
	boundgangbangs_305_99_moretta_11975_animated: ['gangbang', 'mfm', 'bdsm', 'blonde'],
	boundgangbangs_305_99_moretta_11975: ['blowbang', 'blowjob', 'bdsm', 'blonde'],
	boundgangbangs_315_300_lou_charmelle_12402_animated: ['gangbang', 'airtight', 'dp', 'bdsm', 'bondage'],
	boundgangbangs_315_300_lou_charmelle_12402: ['gangbang', 'mfm', 'bdsm', 'bondage'],
	boundgangbangs_770_76_amy_brooke_11965_animated: ['gangbang', 'airtight', 'mfm', 'bdsm', 'bondage'],
	boundgangbangs_770_76_anissa_kate_19662: ['gangbang', 'airtight', 'bdsm', 'bondage'],
	boundgangbangs_970_90_sasha_swift_18815: ['gangbang', 'blowbang', 'dp', 'blowjob', 'facefucking', 'facial', 'bdsm'],
	boundgangbangs_970_90_skylar_price_12403_animated: ['gangbang', 'mfm', 'blowbang', 'blowjob', 'blonde', 'bdsm'],
	hardcoregangbang_300_250_kira_noir_44157: ['blowbang', 'black', 'bdsm'],
	hardcoregangbang_305_99_kira_noir: ['blowbang', 'black', 'bdsm'],
	hardcoregangbang_900_250_gloves_blonde: ['blowbang', 'blonde', 'bdsm'],
	hardcoregangbang_1000_100: ['gangbang', 'mfm', 'bdsm'],
	// aylo
	aylo_728_90_gay: ['gay'],
	// teenmegaworld
	analangels_468_80_animated: ['anal'],
	analangels_300_250_animated: ['anal'],
	analbeauty_468_80_animated: ['anal'],
	analbeauty_300_250_animated: ['anal'],
	analbeauty_300_250_tail_animated: ['anal', 'bondage', 'bdsm'],
	beautyangels_468_80_animated: ['solo'],
	beautyangels_300_250_69_animated: ['lesbian', '69'],
	beautyangels_300_250_lesbian_animated: ['lesbian'],
	teenmegaworld_300_250_animated: ['solo'],
	tmwvrnet_468_80_animated: ['vr'],
	// legalporno/analvids/pornworld
	pornworld_600_120_1: ['anal', 'brunette'],
	pornworld_600_120_2: ['mfm', 'sex', 'brunette'],
	// xempire
	hardx_770_76_anal: ['anal', 'blonde'],
	hardx_770_76_esperanza_anal: ['anal', 'brunette'],
	hardx_770_76_zoey_monroe_mff: ['sex', 'mff', 'blonde'],
	xempire_315_300: ['blowbang', 'sex', 'black-cock', 'brunette'],
	xempire_970_90_mff: ['mff', '69', 'brunette'],
	// vixen
	blacked_300_250_cherry_kiss_dp: ['dp', 'anal', 'black-cock'],
	blacked_300_250_cherry_kiss_anal_mfm: ['anal', 'black-cock'],
	tushy_970_70_alexa_flexy_dp: ['dp', 'anal'],
	tushy_776_70_gianna_dior_anal: ['anal'],
};

/*
const bannerActors = {
	// 21sextury
	'21sextury_770_76_gina_gerson_dp': ['gina-gerson'],
	'21sextury_770_76_veronica_leal_dp': ['veronica-leal'],
	'21naturals_315_300_gina_gerson': ['gina-gerson'],
	'21naturals_315_300_ginebra_bellucci': ['ginebra-bellucci'],
	'21naturals_315_300_lana_roy_anal': ['lana-roy'],
	'21naturals_770_76_alexis_crystal': ['alexis-crystal'],
	// archangel
	archangel_970_90_kendra_lust: ['kendra-lust'],
	// evilangel
	evilangel_728_90_adriana_chechik_gangbang: ['adriana-chechik'],
	evilangel_728_90_kenzie_reeves_lexi_lore: ['kenzie-reeves', 'lexi-lore'],
	// julesjordan
	julesjordan_728_90_jill_kassidy: ['jill-kassidy'],
	julesjordan_728_90_angela_white: ['angela-white'],
	julesjordan_728_90_adriana_chechik: ['adriana-chechik'],
	julesjordan_728_90_autumn_falls: ['autumn-falls'],
	julesjordan_728_90_gabbie_carter: ['gabbie-carter'],
	// kink
	boundgangbangs_305_99_moretta_11975_animated: ['moretta'],
	boundgangbangs_305_99_moretta_11975: ['moretta'],
	boundgangbangs_315_300_lou_charmelle_12402_animated: ['lou-charmelle'],
	boundgangbangs_315_300_lou_charmelle_12402: ['lou-charmelle'],
	boundgangbangs_770_76_amy_brooke_11965_animated: ['amy-brooke'],
	boundgangbangs_770_76_anissa_kate_19662: ['anissa-kate'],
	boundgangbangs_970_90_sasha_swift_18815: ['sasha-swift'],
	boundgangbangs_970_90_skylar_price_12403_animated: ['skylar-price'],
	hardcoregangbang_300_250_kira_noir_44157: ['kira-noir'],
	hardcoregangbang_305_99_kira_noir: ['kira-noir'],
	// xempire
	hardx_770_76_esperanza_anal: ['esperanza-del-horno'],
	hardx_770_76_zoey_monroe_mff: ['zoey-monroe'],
	// vixen
	blacked_300_250_cherry_kiss_dp: ['cherry-kiss'],
	blacked_300_250_cherry_kiss_anal_mfm: ['cherry-kiss'],
	tushy_970_70_alexa_flexy_dp: ['alexa-flexy'],
	tushy_776_70_gianna_dior_anal: ['gianna-dior'],
};
*/

const campaigns = [
	// 21sextury
	{
		network: '21sextury',
		url: 'https://www.iyalc.com/21sextury/go.php?pr=8&su=1&si=207&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21sextury_300_250_anal',
		network: '21sextury',
		url: 'https://www.iyalc.com/21sextury/go.php?pr=8&su=1&si=207&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21sextury_770_76_gina_gerson_dp',
		network: '21sextury',
		url: 'https://www.iyalc.com/21sextury/go.php?pr=8&su=1&si=207&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21sextury_770_76_veronica_leal_dp',
		network: '21sextury',
		url: 'https://www.iyalc.com/21sextury/go.php?pr=8&su=1&si=207&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21sextreme_300_250_cum',
		network: '21sextreme',
		url: 'https://www.iyalc.com/21sextreme/go.php?pr=8&su=1&si=208&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21naturals_315_300',
		network: '21naturals',
		url: 'https://www.iyalc.com/21naturals/go.php?pr=8&su=1&si=209&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21naturals_315_300_1',
		network: '21naturals',
		url: 'https://www.iyalc.com/21naturals/go.php?pr=8&su=1&si=209&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21naturals_315_300_gina_gerson',
		network: '21naturals',
		url: 'https://www.iyalc.com/21naturals/go.php?pr=8&su=1&si=209&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21naturals_315_300_ginebra_bellucci',
		network: '21naturals',
		url: 'https://www.iyalc.com/21naturals/go.php?pr=8&su=1&si=209&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21naturals_315_300_lana_roy_anal',
		network: '21naturals',
		url: 'https://www.iyalc.com/21naturals/go.php?pr=8&su=1&si=209&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21naturals_770_76_alexis_crystal',
		network: '21naturals',
		url: 'https://www.iyalc.com/21naturals/go.php?pr=8&su=1&si=209&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: '21naturals_970_90',
		network: '21naturals',
		url: 'https://www.iyalc.com/21naturals/go.php?pr=8&su=1&si=209&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	// archangel
	/* NATS license expired
	{
		channel: 'archangel',
		affiliate: 'archangel_share',
	},
	{
		channel: 'archangel',
		affiliate: 'archangel_share',
		banner: 'archangel_970_90_kendra_lust',
	},
	*/
	// bang
	{
		network: 'bang',
		affiliate: 'bang_signup',
		comment: 'per signup',
	},
	// brazzers
	{
		network: 'brazzers',
		url: 'https://landing.brazzersnetwork.com/?ats=eyJhIjozMTYwOTcsImMiOjU5MzI1Mzk5LCJuIjoxNCwicyI6OTAsImUiOjg4MDMsInAiOjExfQ==',
		comment: '$30 per signup',
	},
	// dfxtra / dogfart
	{
		network: 'dfxtra',
		url: 'https://www.g2fame.com/dfxtra/go.php?pr=8&su=2&si=681&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		network: 'dfxtra',
		banner: 'dfxtra_900_250_mfm',
		url: 'https://www.g2fame.com/dfxtra/go.php?pr=8&su=2&si=681&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		network: 'dfxtra',
		banner: 'dfxtra_900_250_gay_anal',
		url: 'https://www.g2fame.com/dfxtra/go.php?pr=8&su=2&si=681&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		network: 'dfxtra',
		banner: 'dfxtra_300_250_mfm',
		url: 'https://www.g2fame.com/dfxtra/go.php?pr=8&su=2&si=681&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		network: 'dfxtra',
		banner: 'dfxtra_300_250_gay_bj',
		url: 'https://www.g2fame.com/dfxtra/go.php?pr=8&su=2&si=681&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		channel: 'blacksonblondes',
		url: 'https://www.g2fame.com/blacksonblondes/go.php?pr=8&su=2&si=682&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		channel: 'blacksonblondes',
		banner: 'blacksonblondes_900_250_mfm_hj',
		url: 'https://www.g2fame.com/blacksonblondes/go.php?pr=8&su=2&si=682&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		channel: 'blacksonblondes',
		banner: 'blacksonblondes_900_250_mfm',
		url: 'https://www.g2fame.com/blacksonblondes/go.php?pr=8&su=2&si=682&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		channel: 'blacksonblondes',
		banner: 'blacksonblondes_300_250_mfm',
		url: 'https://www.g2fame.com/blacksonblondes/go.php?pr=8&su=2&si=682&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		channel: 'blacksonblondes',
		banner: 'blacksonblondes_300_250_mff_april',
		url: 'https://www.g2fame.com/blacksonblondes/go.php?pr=8&su=2&si=682&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	{
		channel: 'blacksonblondes',
		banner: 'blacksonblondes_300_250_mff_april2',
		url: 'https://www.g2fame.com/blacksonblondes/go.php?pr=8&su=2&si=682&ad=277470&pa=index&ar=&campaign=460352&buffer=',
		comment: 'per signup',
	},
	// evil angel
	{
		network: 'evilangel',
		url: 'https://www.iyalc.com/evilangel/go.php?pr=8&su=2&si=128&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: 'evilangel_728_90_adriana_chechik_gangbang',
		network: 'evilangel',
		url: 'https://www.iyalc.com/evilangel/go.php?pr=8&su=2&si=128&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: 'evilangel_728_90_kenzie_reeves_lexi_lore',
		network: 'evilangel',
		url: 'https://www.iyalc.com/evilangel/go.php?pr=8&su=2&si=128&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	{
		banner: 'evilangel_970_90_one_dollar',
		network: 'evilangel',
		url: 'https://www.iyalc.com/evilangel/go.php?pr=8&su=2&si=128&ad=277470&pa=index&ar=&buffer=',
		comment: 'per signup',
	},
	// julesjordan
	{
		network: 'julesjordan',
		url: 'https://enter.julesjordan.com/track/Mzk3MS4yLjMuNi4wLjAuMC4wLjA',
		comment: '$30 per signup',
	},
	{
		banner: 'julesjordan_728_90_jill_kassidy',
		network: 'julesjordan',
		url: 'https://enter.julesjordan.com/track/Mzk3MS4yLjMuNi4wLjAuMC4wLjA',
		comment: '$30 per signup',
	},
	{
		banner: 'julesjordan_728_90_angela_white',
		network: 'julesjordan',
		url: 'https://enter.julesjordan.com/track/Mzk3MS4yLjMuNi4wLjAuMC4wLjA',
		comment: '$30 per signup',
	},
	{
		banner: 'julesjordan_728_90_adriana_chechik',
		network: 'julesjordan',
		url: 'https://enter.julesjordan.com/track/Mzk3MS4yLjMuNi4wLjAuMC4wLjA',
		comment: '$30 per signup',
	},
	{
		banner: 'julesjordan_728_90_autumn_falls',
		network: 'julesjordan',
		url: 'https://enter.julesjordan.com/track/Mzk3MS4yLjMuNi4wLjAuMC4wLjA',
		comment: '$30 per signup',
	},
	{
		banner: 'julesjordan_728_90_gabbie_carter',
		network: 'julesjordan',
		url: 'https://enter.julesjordan.com/track/Mzk3MS4yLjMuNi4wLjAuMC4wLjA',
		comment: '$30 per signup',
	},
	{
		channel: 'manuelferrara',
		url: 'https://enter.manuelferrara.com/track/Mzk3MS4yLjcuMTYuMC4wLjAuMC4w',
		comment: '$30 per signup',
	},
	{
		banner: 'manuelferrara_728_90_asses',
		channel: 'manuelferrara',
		url: 'https://enter.manuelferrara.com/track/Mzk3MS4yLjcuMTYuMC4wLjAuMC4w',
		comment: '$30 per signup',
	},
	{
		channel: 'theassfactory',
		url: 'https://enter.theassfactory.com/track/Mzk3MS4yLjEuMS4wLjAuMC4wLjA',
		comment: '$30 per signup',
	},
	{
		channel: 'spermswallowers',
		url: 'https://enter.spermswallowers.com/track/Mzk3MS4yLjUuMTMuMC4wLjAuMC4w',
		comment: '$30 per signup',
	},
	// kink
	{
		network: 'kink',
		affiliate: 'kink_params',
		comment: '50%',
	},
	{
		channel: 'boundgangbangs',
		url: 'https://www.kink.com/channel/bound-gang-bangs?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		comment: '50%',
	},
	{
		channel: 'hardcoregangbang',
		url: 'https://www.kink.com/channel/hardcore-gangbang?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		comment: '50%',
	},
	{
		banner: 'boundgangbangs_305_99_moretta_11975',
		url: 'https://www.kink.com/channel/bound-gang-bangs?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'boundgangbangs',
		comment: '50%',
	},
	{
		banner: 'boundgangbangs_305_99_moretta_11975_animated',
		url: 'https://www.kink.com/channel/bound-gang-bangs?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'boundgangbangs',
		comment: '50%',
	},
	{
		banner: 'boundgangbangs_315_300_lou_charmelle_12402',
		url: 'https://www.kink.com/channel/bound-gang-bangs?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'boundgangbangs',
		comment: '50%',
	},
	{
		banner: 'boundgangbangs_315_300_lou_charmelle_12402_animated',
		url: 'https://www.kink.com/channel/bound-gang-bangs?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'boundgangbangs',
		comment: '50%',
	},
	{
		banner: 'boundgangbangs_770_76_amy_brooke_11965_animated',
		url: 'https://www.kink.com/channel/bound-gang-bangs?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'boundgangbangs',
		comment: '50%',
	},
	{
		banner: 'boundgangbangs_770_76_anissa_kate_19662',
		url: 'https://www.kink.com/channel/bound-gang-bangs?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'boundgangbangs',
		comment: '50%',
	},
	{
		banner: 'boundgangbangs_970_90_sasha_swift_18815',
		url: 'https://www.kink.com/channel/bound-gang-bangs?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'boundgangbangs',
		comment: '50%',
	},
	{
		banner: 'boundgangbangs_970_90_skylar_price_12403_animated',
		url: 'https://www.kink.com/channel/bound-gang-bangs?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'boundgangbangs',
		comment: '50%',
	},
	{
		banner: 'hardcoregangbang_300_250_kira_noir_44157',
		url: 'https://www.kink.com/channel/hardcore-gangbang?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'hardcoregangbang',
		comment: '50%',
	},
	{
		banner: 'hardcoregangbang_305_99_kira_noir',
		url: 'https://www.kink.com/channel/hardcore-gangbang?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'hardcoregangbang',
		comment: '50%',
	},
	{
		banner: 'hardcoregangbang_900_250_gloves_blonde',
		url: 'https://www.kink.com/channel/hardcore-gangbang?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'hardcoregangbang',
		comment: '50%',
	},
	{
		banner: 'hardcoregangbang_1000_100',
		url: 'https://www.kink.com/channel/hardcore-gangbang?t=eyJhZmZpbGlhdGUiOiJEZWJhdWNoZXJ5TGliIiwiY2FtcGFpZ24iOiJkZWZhdWx0IiwiYWdldmVyaWZpZWQiOiJ5In0',
		channel: 'hardcoregangbang',
		comment: '50%',
	},
	// kellymadison/teenfidelity
	{
		network: 'kellymadison',
		url: 'https://www2.kellymadison.com/track/MTAxOTE0LjYuMS4xLjAuMC4wLjAuMA',
		comment: '$25 per signup',
	},
	{
		channel: 'kellymadison',
		url: 'https://www2.kellymadison.com/track/MTAxOTE0LjYuMS4xLjAuMC4wLjAuMA',
		comment: '$25 per signup',
	},
	{
		channel: 'pornfidelity',
		url: 'https://www2.pornfidelity.com/track/MTAxOTE0LjYuMy4zLjAuMC4wLjAuMA',
		comment: '$25 per signup',
	},
	{
		channel: 'teenfidelity',
		url: 'https://www2.teenfidelity.com/track/MTAxOTE0LjYuNS42LjAuMC4wLjAuMA',
		comment: '$25 per signup',
	},
	// aylo
	{
		network: 'aylo',
		banner: 'aylo_728_90',
	},
	{
		network: 'aylo',
		banner: 'aylo_300_100',
	},
	{
		network: 'aylo',
		banner: 'aylo_300_250',
	},
	{
		network: 'aylo',
		banner: 'aylo_315_300',
	},
	{
		network: 'aylo',
		banner: 'aylo_728_90_gay',
	},
	// teenmegaworld
	{
		network: 'teenmegaworld',
		url: 'https://secure.teenmegaworld.net/track/MzAxNjcxLjUuMS4xLjAuMC4wLjAuMA',
		comment: 'recurring',
	},
	{
		banner: 'teenmegaworld_300_250_animated',
		network: 'teenmegaworld',
		url: 'https://secure.teenmegaworld.net/track/MzAxNjcxLjUuMS4xLjAuMC4wLjAuMA',
		comment: 'recurring',
	},
	{
		banner: 'analangels_468_80_animated',
		channel: 'analangels',
		url: 'https://secure.anal-angels.com/track/MzAxNjcxLjUuMzMuMzMuMC4wLjAuMC4w',
		comment: 'recurring',
	},
	{
		banner: 'analangels_300_250_animated',
		channel: 'analangels',
		url: 'https://secure.anal-angels.com/track/MzAxNjcxLjUuMzMuMzMuMC4wLjAuMC4w',
		comment: 'recurring',
	},
	{
		banner: 'analbeauty_468_80_animated',
		channel: 'analbeauty',
		url: 'https://secure.anal-beauty.com/track/MzAxNjcxLjUuNDAuNDAuMC4wLjAuMC4w',
		comment: 'recurring',
	},
	{
		banner: 'analbeauty_300_250_animated',
		channel: 'analbeauty',
		url: 'https://secure.anal-beauty.com/track/MzAxNjcxLjUuNDAuNDAuMC4wLjAuMC4w',
		comment: 'recurring',
	},
	{
		banner: 'analbeauty_300_250_tail_animated',
		channel: 'analbeauty',
		url: 'https://secure.anal-beauty.com/track/MzAxNjcxLjUuNDAuNDAuMC4wLjAuMC4w',
		comment: 'recurring',
	},
	{
		banner: 'beautyangels_468_80_animated',
		channel: 'beautyangels',
		url: 'https://secure.beauty-angels.com/track/MzAxNjcxLjUuMjcuMjcuMC4wLjAuMC4w',
		comment: 'recurring',
	},
	{
		banner: 'beautyangels_300_250_69_animated',
		channel: 'beautyangels',
		url: 'https://secure.beauty-angels.com/track/MzAxNjcxLjUuMjcuMjcuMC4wLjAuMC4w',
		comment: 'recurring',
	},
	{
		banner: 'beautyangels_300_250_lesbian_animated',
		channel: 'beautyangels',
		url: 'https://secure.beauty-angels.com/track/MzAxNjcxLjUuMjcuMjcuMC4wLjAuMC4w',
		comment: 'recurring',
	},
	{
		banner: 'tmwvrnet_468_80_animated',
		channel: 'tmwvrnet',
		url: 'https://secure.tmwvrnet.com/track/MzAxNjcxLjUuNDQuNDQuMC4wLjAuMC4w',
		comment: 'recurring',
	},
	// legalporno/analvids/pornworld
	{
		network: 'analvids',
		url: 'https://www.analvids.com/new-videos?aff=BW90MHT1DP____',
		comment: 'default offer',
	},
	{
		channel: 'analvids',
		banner: 'pornworld_600_120_1',
		url: 'https://www.analvids.com/new-videos?aff=BW90MHT1DP____',
		comment: 'default offer',
	},
	{
		channel: 'analvids',
		banner: 'pornworld_600_120_2',
		url: 'https://www.analvids.com/new-videos?aff=BW90MHT1DP____',
		comment: 'default offer',
	},
	{
		network: 'pornworld',
		url: 'https://pornworld.com/new-videos?aff=BW90MHT1DP____',
		comment: 'default offer',
	},
	{
		network: 'pornworld',
		banner: 'pornworld_600_120_1',
		url: 'https://pornworld.com/new-videos?aff=BW90MHT1DP____',
		comment: 'default offer',
	},
	{
		network: 'pornworld',
		banner: 'pornworld_600_120_2',
		url: 'https://pornworld.com/new-videos?aff=BW90MHT1DP____',
		comment: 'default offer',
	},
	// xempire
	{
		network: 'xempire',
		url: 'https://www.blazinglink.com/xempire/go.php?pr=12&su=2&si=81&pa=index&ar=&ad=277470',
		comment: '$30 per signup',
	},
	{
		network: 'xempire',
		banner: 'xempire_970_90_mff',
		url: 'https://www.blazinglink.com/xempire/go.php?pr=12&su=2&si=81&pa=index&ar=&ad=277470',
		comment: '$30 per signup',
	},
	{
		network: 'xempire',
		banner: 'xempire_315_300',
		url: 'https://www.blazinglink.com/xempire/go.php?pr=12&su=2&si=81&pa=index&ar=&ad=277470',
		comment: '$30 per signup',
	},
	{
		channel: 'hardx',
		url: 'https://www.blazinglink.com/hardx/go.php?pr=12&su=2&si=68&pa=index&ar=&ad=277470',
		comment: '$30 per signup',
	},
	{
		channel: 'hardx',
		banner: 'hardx_770_76_anal',
		url: 'https://www.blazinglink.com/hardx/go.php?pr=12&su=2&si=68&pa=index&ar=&ad=277470',
		comment: '$30 per signup',
	},
	{
		channel: 'hardx',
		banner: 'hardx_770_76_esperanza_anal',
		url: 'https://www.blazinglink.com/hardx/go.php?pr=12&su=2&si=68&pa=index&ar=&ad=277470',
		comment: '$30 per signup',
	},
	{
		channel: 'hardx',
		banner: 'hardx_770_76_zoey_monroe_mff',
		url: 'https://www.blazinglink.com/hardx/go.php?pr=12&su=2&si=68&pa=index&ar=&ad=277470',
		comment: '$30 per signup',
	},
	// vixen
	{
		channel: 'blacked',
		url: 'https://join.blacked.com/track/MTA0MS43OC4zLjMuMC4wLjAuMC4w',
		comment: '$30 per signup',
	},
	{
		channel: 'blacked',
		banner: 'blacked_300_250_cherry_kiss_dp',
		url: 'https://join.blacked.com/track/MTA0MS43OC4zLjMuMC4wLjAuMC4w',
		comment: '$30 per signup',
	},
	{
		channel: 'blacked',
		banner: 'blacked_300_250_cherry_kiss_anal_mfm',
		url: 'https://join.blacked.com/track/MTA0MS43OC4zLjMuMC4wLjAuMC4w',
		comment: '$30 per signup',
	},
	{
		channel: 'tushy',
		url: 'https://join.tushy.com/track/MTA0MS43OC43LjIwLjAuMC4wLjAuMA',
		comment: '$30 per signup',
	},
	{
		channel: 'tushy',
		banner: 'tushy_970_70_alexa_flexy_dp',
		url: 'https://join.tushy.com/track/MTA0MS43OC43LjIwLjAuMC4wLjAuMA',
		comment: '$30 per signup',
	},
	{
		channel: 'tushy',
		banner: 'tushy_776_70_gianna_dior_anal',
		url: 'https://join.tushy.com/track/MTA0MS43OC43LjIwLjAuMC4wLjAuMA',
		comment: '$30 per signup',
	},
];

exports.seed = async (knex) => Promise.resolve()
	.then(async () => {
		const bannerNetworks = await fs.readdir('./public/banners');

		// derive entity, width and height from filepath to minimize redundant work
		const rawBanners = await Promise.all(bannerNetworks.map(async (network) => {
			const networkPaths = await fs.readdir(`./public/banners/${network}`);

			return Promise.all(networkPaths.map(async (file) => {
				if (file.charAt(0) === '_') {
					return null;
				}

				if (await fs.stat(`./public/banners/${network}/${file}`).then(async (stats) => stats.isDirectory())) {
					const channelPaths = await fs.readdir(`./public/banners/${network}/${file}`);

					return channelPaths.map((filepath) => {
						const { name, ext } = path.parse(filepath);

						return {
							id: name,
							type: ext.slice(1),
							channel: file,
						};
					});
				}

				const { name, ext } = path.parse(file);

				return {
					id: name,
					type: ext.slice(1),
					network,
				};
			}));
		}));

		const banners = rawBanners
			.flat(2)
			.filter(Boolean)
			.map((banner) => {
				const [, width, height] = banner.id.match(/[a-z0-9]+_(\d+)_(\d+)/);

				return {
					...banner,
					width: Number(width),
					height: Number(height),
					tags: bannerTags[banner.id] || [],
				};
			});

		await Promise.all([
			knex('campaigns').delete(),
			knex('banners_tags').delete(),
		]);

		await Promise.all([
			knex('affiliates').delete(),
			knex('banners').delete(),
		]);

		const [networks, channels, tags] = await Promise.all([
			knex('entities')
				.where('type', 'network')
				.whereIn('slug', campaigns.concat(banners).map((link) => link.network).filter(Boolean)),
			knex('entities')
				.where('type', 'channel')
				.whereIn('slug', campaigns.concat(banners).map((link) => link.channel).filter(Boolean)),
			knex('tags')
				.whereIn('slug', banners.flatMap((banner) => banner.tags || [])),
			/*
			knex('actors')
				.whereIn('slug', banners.flatMap((banner) => banner.tags || [])),
			*/
		]);

		const networksBySlug = networks.reduce((acc, network) => ({ ...acc, [network.slug]: network }), {});
		const channelsBySlug = channels.reduce((acc, channel) => ({ ...acc, [channel.slug]: channel }), {});
		const tagsBySlug = tags.reduce((acc, tag) => ({ ...acc, [tag.slug]: tag }), {});

		const affiliatesWithEntityId = affiliates.map((affiliate) => ({
			id: affiliate.id,
			entity_id: networksBySlug[affiliate.network]?.id || channelsBySlug[affiliate.channel]?.id || null,
			url: affiliate.url,
			parameters: affiliate.parameters,
			comment: affiliate.comment,
		}));

		const bannersWithEntityId = banners.map((banner) => ({
			id: banner.id,
			width: banner.width,
			height: banner.height,
			type: banner.type || (banner.id.includes('animated') ? 'gif' : 'jpg'),
			entity_id: networksBySlug[banner.network]?.id || channelsBySlug[banner.channel]?.id || channelsBySlug[banner.network]?.id || null,
		}));

		const bannerTagEntries = banners.flatMap((banner) => banner.tags?.map((tag) => ({
			banner_id: banner.id,
			tag_id: tagsBySlug[tag].id,
		})) || []);

		const campaignsWithEntityIdAndAffiliateId = campaigns.map((campaign) => ({
			entity_id: networksBySlug[campaign.network]?.id || channelsBySlug[campaign.channel]?.id,
			url: campaign.url,
			affiliate_id: campaign.affiliate,
			banner_id: campaign.banner,
		})).filter((link) => link.entity_id && (link.url || link.affiliate_id || link.banner_id));

		await knex('affiliates').insert(affiliatesWithEntityId);
		await bulkInsert('banners', bannersWithEntityId, false);
		await bulkInsert('banners_tags', bannerTagEntries, false);
		await bulkInsert('campaigns', campaignsWithEntityIdAndAffiliateId, false);
	});