Compare commits
	
		
			No commits in common. "456b240df886e8cd7d46afa42e8e6264e5a01100" and "4594dbc7636bd716de6a00a3e3ef34513a952a46" have entirely different histories.
		
	
	
		
			456b240df8
			...
			4594dbc763
		
	
		|  | @ -402,9 +402,9 @@ function showAlbum() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| async function watchRoute(to, from) { | async function watchRoute(to, from) { | ||||||
| 	console.log(to, from); | 	if (to.params.pageNumber !== from.params.pageNumber) { | ||||||
| 
 | 		await this.fetchActor(); | ||||||
| 	await this.fetchActor(); | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| async function mounted() { | async function mounted() { | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| { | { | ||||||
|     "name": "traxxx", |     "name": "traxxx", | ||||||
|     "version": "1.167.1", |     "version": "1.167.0", | ||||||
|     "lockfileVersion": 1, |     "lockfileVersion": 1, | ||||||
|     "requires": true, |     "requires": true, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| { | { | ||||||
|     "name": "traxxx", |     "name": "traxxx", | ||||||
|     "version": "1.167.1", |     "version": "1.167.0", | ||||||
|     "description": "All the latest porn releases in one place", |     "description": "All the latest porn releases in one place", | ||||||
|     "main": "src/app.js", |     "main": "src/app.js", | ||||||
|     "scripts": { |     "scripts": { | ||||||
|  |  | ||||||
| Before Width: | Height: | Size: 2.1 MiB | 
| Before Width: | Height: | Size: 1.6 MiB | 
| Before Width: | Height: | Size: 7.8 KiB | 
| Before Width: | Height: | Size: 8.0 KiB | 
| Before Width: | Height: | Size: 2.2 MiB | 
| Before Width: | Height: | Size: 1.3 MiB | 
| Before Width: | Height: | Size: 34 KiB | 
| Before Width: | Height: | Size: 35 KiB | 
|  | @ -597,7 +597,7 @@ const tagPosters = [ | ||||||
| 	['atm', 2, 'Jureka Del Mar in "Stretched Out" for Her Limit'], | 	['atm', 2, 'Jureka Del Mar in "Stretched Out" for Her Limit'], | ||||||
| 	['atogm', 0, 'Alysa Gap and Logan in "Anal Buffet 4" for Evil Angel'], | 	['atogm', 0, 'Alysa Gap and Logan in "Anal Buffet 4" for Evil Angel'], | ||||||
| 	['bdsm', 0, 'Dani Daniels in "The Traning of Dani Daniels, Day 2" for The Training of O at Kink'], | 	['bdsm', 0, 'Dani Daniels in "The Traning of Dani Daniels, Day 2" for The Training of O at Kink'], | ||||||
| 	['bts', '3b', 'Brenna Sparks for Bang! Confessions'], | 	['bts', 2, 'Christy Mack for Digital Playground'], | ||||||
| 	['blindfold', 0, 'Kylie Page in "Natural Blindfolded Beauties" for Hustler'], | 	['blindfold', 0, 'Kylie Page in "Natural Blindfolded Beauties" for Hustler'], | ||||||
| 	['blonde', 1, 'Marsha May in "Once You Go Black 7" for Jules Jordan'], | 	['blonde', 1, 'Marsha May in "Once You Go Black 7" for Jules Jordan'], | ||||||
| 	['blowbang', 0, 'Lacy Lennon in "Lacy Lennon\'s First Blowbang" for HardX'], | 	['blowbang', 0, 'Lacy Lennon in "Lacy Lennon\'s First Blowbang" for HardX'], | ||||||
|  | @ -717,7 +717,6 @@ const tagPhotos = [ | ||||||
| 	['anal-fingering', 2, 'Aidra Fox and Cassidy Klein in "Lesbian Anal Yoga" for LesbianX'], | 	['anal-fingering', 2, 'Aidra Fox and Cassidy Klein in "Lesbian Anal Yoga" for LesbianX'], | ||||||
| 	['bts', 0, 'Janice Griffith in "Day With A Pornstar: Janice" for Brazzers'], | 	['bts', 0, 'Janice Griffith in "Day With A Pornstar: Janice" for Brazzers'], | ||||||
| 	['bts', 1, 'Madison Ivy in "Day With A Pornstar" for Brazzers'], | 	['bts', 1, 'Madison Ivy in "Day With A Pornstar" for Brazzers'], | ||||||
| 	['bts', 2, 'Christy Mack for Digital Playground'], |  | ||||||
| 	['blonde', 4, 'Marry Queen for Babespotting.tv'], | 	['blonde', 4, 'Marry Queen for Babespotting.tv'], | ||||||
| 	['blonde', 3, 'Kylie Page in "A Juicy Afternoon Delight" for New Sensations'], | 	['blonde', 3, 'Kylie Page in "A Juicy Afternoon Delight" for New Sensations'], | ||||||
| 	['blonde', 2, 'Isabelle Deltore for Her Limit'], | 	['blonde', 2, 'Isabelle Deltore for Her Limit'], | ||||||
|  |  | ||||||
|  | @ -146,7 +146,7 @@ const { argv } = yargs | ||||||
| 		describe: 'Limit amount of scenes when dates are missing.', | 		describe: 'Limit amount of scenes when dates are missing.', | ||||||
| 		type: 'number', | 		type: 'number', | ||||||
| 		default: config.missingDateLimit, | 		default: config.missingDateLimit, | ||||||
| 		alias: ['null-date-limit'], | 		alias: ['null-date-limit', 'limit'], | ||||||
| 	}) | 	}) | ||||||
| 	.option('page', { | 	.option('page', { | ||||||
| 		describe: 'Page to start scraping at', | 		describe: 'Page to start scraping at', | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| 'use strict'; | 'use strict'; | ||||||
| 
 | 
 | ||||||
| const http = require('../utils/http'); | const http = require('../utils/http'); | ||||||
| const qu = require('../utils/qu'); |  | ||||||
| const { extractDate } = require('../utils/qu'); | const { extractDate } = require('../utils/qu'); | ||||||
| const { inchesToCm } = require('../utils/convert'); | const { inchesToCm } = require('../utils/convert'); | ||||||
| const slugify = require('../utils/slugify'); | const slugify = require('../utils/slugify'); | ||||||
|  | @ -38,23 +37,7 @@ function decodeId(id) { | ||||||
| 		.toString('hex'); | 		.toString('hex'); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| async function fetchPhotos(scene) { | function scrapeScene(scene) { | ||||||
| 	const photoPaths = Array.from({ length: scene.photos }, (value, index) => `/${scene.dvd.id}/${scene.identifier}/final/${String(index + 1).padStart(6, '0')}.jpg`); |  | ||||||
| 
 |  | ||||||
| 	const res = await http.post('https://www.bang.com/sign-images', { |  | ||||||
| 		images: photoPaths, |  | ||||||
| 	}, { |  | ||||||
| 		encodeJSON: false, |  | ||||||
| 	}); |  | ||||||
| 
 |  | ||||||
| 	if (res.ok) { |  | ||||||
| 		return res.body.images.map(image => qu.prefixUrl(image, 'https://photos.bang.com')); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return null; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| async function scrapeScene(scene, entity, options) { |  | ||||||
| 	const release = { | 	const release = { | ||||||
| 		entryId: scene.id, | 		entryId: scene.id, | ||||||
| 		title: scene.name, | 		title: scene.name, | ||||||
|  | @ -75,23 +58,17 @@ async function scrapeScene(scene, entity, options) { | ||||||
| 	if (scene.gay) release.tags.push('gay'); | 	if (scene.gay) release.tags.push('gay'); | ||||||
| 
 | 
 | ||||||
| 	const defaultPoster = scene.screenshots.find(photo => photo.default === true); | 	const defaultPoster = scene.screenshots.find(photo => photo.default === true); | ||||||
| 	const screens = scene.screenshots.filter(photo => photo.default === false); | 	const photoset = scene.screenshots.filter(photo => photo.default === false); | ||||||
| 
 | 
 | ||||||
| 	const remainingScreens = defaultPoster ? screens : screens.slice(1); | 	const photos = defaultPoster ? photoset : photoset.slice(1); | ||||||
| 	const poster = defaultPoster || screens[0]; | 	const poster = defaultPoster || photoset[0]; | ||||||
| 
 | 
 | ||||||
| 	release.poster = getScreenUrl(poster, scene); | 	release.poster = getScreenUrl(poster, scene); | ||||||
| 	release.photos = remainingScreens.map(photo => getScreenUrl(photo, scene)); | 	release.photos = photos.map(photo => getScreenUrl(photo, scene)); | ||||||
| 
 | 
 | ||||||
| 	if (options.includePhotos) { | 	release.trailer = { | ||||||
| 		const photos = await fetchPhotos(scene); | 		src: `https://i.bang.com/v/${scene.dvd.id}/${scene.identifier}/preview.mp4`, | ||||||
| 
 | 	}; | ||||||
| 		if (photos?.length > 0) { |  | ||||||
| 			release.photos = photos; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	release.trailer = `https://i.bang.com/v/${scene.dvd.id}/${scene.identifier}/preview.mp4`; |  | ||||||
| 
 | 
 | ||||||
| 	release.channel = scene.series.name | 	release.channel = scene.series.name | ||||||
| 		.replace(/[! .]/g, '') | 		.replace(/[! .]/g, '') | ||||||
|  | @ -351,7 +328,7 @@ async function fetchUpcoming(site, page = 1) { | ||||||
| 	return scrapeAll(res.body.hits.hits, site); | 	return scrapeAll(res.body.hits.hits, site); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| async function fetchScene(url, entity, baseRelease, options) { | async function fetchScene(url) { | ||||||
| 	const encodedId = new URL(url).pathname.split('/')[2]; | 	const encodedId = new URL(url).pathname.split('/')[2]; | ||||||
| 	const entryId = decodeId(encodedId); | 	const entryId = decodeId(encodedId); | ||||||
| 
 | 
 | ||||||
|  | @ -361,7 +338,7 @@ async function fetchScene(url, entity, baseRelease, options) { | ||||||
| 		}, | 		}, | ||||||
| 	}); | 	}); | ||||||
| 
 | 
 | ||||||
| 	return scrapeScene(res.body._source, entity, options); // eslint-disable-line no-underscore-dangle
 | 	return scrapeScene(res.body._source); // eslint-disable-line no-underscore-dangle
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| async function fetchProfile({ name: actorName }, context, include) { | async function fetchProfile({ name: actorName }, context, include) { | ||||||
|  |  | ||||||