Compare commits

..

No commits in common. "5e850f12c628f3d5c1fe57b68196365c011b7402" and "faee5bb61364eef2717e0e3aa4612a93db565593" have entirely different histories.

15 changed files with 41 additions and 91 deletions

View File

@ -0,0 +1 @@
src/scrapers/template.js

View File

@ -212,7 +212,6 @@ export default {
.sidebar-toggle {
display: none;
align-items: center;
height: 100%;
.logo {

View File

@ -183,7 +183,7 @@ export default {
height: 100%;
color: var(--text);
background: var(--background);
box-shadow: 0 0 3px var(--darken-weak);
box-shadow: 0 0 3px var(--darken);
}
.sidebar-header {

View File

@ -24,8 +24,8 @@ function initActorActions(store, router) {
$actorId: Int!
$limit:Int = 10,
$offset:Int = 0,
$after:Datetime = "1900-01-01",
$before:Datetime = "2100-01-01",
$after:Date = "1900-01-01",
$before:Date = "2100-01-01",
$orderBy:[ReleasesActorsOrderBy!]
$selectableTags: [String],
$excludeTags: [String!]

View File

@ -20,8 +20,8 @@ function initEntitiesActions(store, _router) {
$entityType: String! = "channel"
$limit: Int = 10,
$offset: Int = 0,
$after: Datetime = "1900-01-01",
$before: Datetime = "2100-01-01",
$after: Date = "1900-01-01",
$before: Date = "2100-01-01",
$afterTime: Datetime = "1900-01-01",
$beforeTime: Datetime = "2100-01-01",
$orderBy: [ReleasesOrderBy!]

View File

@ -11,8 +11,8 @@ function initReleasesActions(store, _router) {
query Releases(
$limit:Int = 1000,
$offset:Int = 0,
$after:Datetime = "1900-01-01",
$before:Datetime = "2100-01-01",
$after:Date = "1900-01-01",
$before:Date = "2100-01-01",
$orderBy:[ReleasesOrderBy!],
$exclude: [String!]
) {

View File

@ -13,8 +13,8 @@ function initTagsActions(store, _router) {
query Tag(
$tagSlug:String!
$limit:Int = 1000,
$after:Datetime = "1900-01-01",
$before:Datetime = "2100-01-01",
$after:Date = "1900-01-01",
$before:Date = "2100-01-01",
$orderBy: [ReleasesTagsOrderBy!],
$exclude: [String!]
) {

2
package-lock.json generated
View File

@ -1,6 +1,6 @@
{
"name": "traxxx",
"version": "1.119.2",
"version": "1.119.1",
"lockfileVersion": 1,
"requires": true,
"dependencies": {

View File

@ -1,6 +1,6 @@
{
"name": "traxxx",
"version": "1.119.2",
"version": "1.119.1",
"description": "All the latest porn releases in one place",
"main": "src/app.js",
"scripts": {

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.4 KiB

View File

@ -505,8 +505,6 @@ async function scrapeProfiles(actor, sources, entitiesBySlug, existingProfilesBy
try {
const scraper = scrapers[scraperSlug];
const context = {
...entitiesBySlug[scraperSlug],
// legacy
site: entitiesBySlug[scraperSlug] || null,
network: entitiesBySlug[scraperSlug] || null,
entity: entitiesBySlug[scraperSlug] || null,

View File

@ -15,7 +15,6 @@ const cherrypimps = require('./cherrypimps');
const ddfnetwork = require('./ddfnetwork');
const digitalplayground = require('./digitalplayground');
const dogfart = require('./dogfart');
const elegantangel = require('./elegantangel');
const evilangel = require('./evilangel');
const fakehub = require('./fakehub');
const famedigital = require('./famedigital');
@ -91,7 +90,6 @@ module.exports = {
digitalplayground,
dogfart,
dogfartnetwork: dogfart,
elegantangel,
evilangel,
fakehub,
famedigital,

View File

@ -1,97 +1,51 @@
'use strict';
const qu = require('../utils/q');
const slugify = require('../utils/slugify');
const { get, geta } = require('../utils/q');
function scrapeAll(scenes, site) {
return scenes.map(({ query }) => {
function scrapeLatest(scenes, site) {
return scenes.map(({ qu }) => {
const release = {};
const pathname = query.url('.title a');
release.entryId = pathname.match(/\/scene\/(\d+)/)[1];
release.title = qu.q('.title a', true);
const pathname = qu.url('.title a');
release.entryId = pathname.split('/')[3];
release.url = `${site.url}${pathname}`;
release.title = query.cnt('.title a');
release.description = query.cnt('.description');
release.date = qu.date('.date', 'MMM DD, YYYY');
release.actors = qu.all('.models a.model', true);
release.date = query.date('.date', 'MMM DD, YYYY');
release.actors = query.cnts('.models a.model');
release.poster = qu.q('img').dataset.original;
release.poster = query.q('img.poster');
release.stars = query.number('.rating');
release.likes = query.number('.likes');
release.stars = Number(qu.q('.rating', true));
release.likes = Number(qu.q('.likes', true));
console.log(release);
return release;
});
}
function scrapeScene({ query }) {
function scrapeScene({ qu }, _site) {
const release = {};
release.title = query.cnt('h3.title');
release.description = query.cnt('p.description');
[release.poster, ...release.photos] = query.imgs('.preview-thumb');
const trailer = query.video('.trailer video');
release.trailer = { src: trailer };
console.log(release);
return release;
}
function scrapeProfile({ query, el }, actorName, entity, include) {
const profile = {};
async function fetchLatest(site, page = 1) {
const url = `${site.url}/${page}`;
const res = await geta(url, '.selector');
profile.description = query.cnt('.bio-text');
profile.birthPlace = query.cnt('.birth-place span');
profile.avatar = query.img('.actor-photo img');
if (include.releases) {
return scrapeAll(qu.initAll(el, '.scene'));
return res.ok ? scrapeLatest(res.items, site) : res.status;
}
console.log(profile);
return profile;
}
async function fetchScene(url, site) {
const res = await get(url);
async function fetchLatest(channel, page = 1) {
const url = `${channel.url}/${page}`;
const res = await qu.getAll(url, '.scene');
if (res.ok) {
return scrapeAll(res.items, channel);
}
return res.status;
}
async function fetchScene(url, channel) {
const res = await qu.get(url);
if (res.ok) {
return scrapeScene(res.item, channel);
}
return res.status;
}
async function fetchProfile(actorName, entity, include) {
const url = `${entity.url}/actors/${slugify(actorName, '_')}`;
const res = await qu.get(url);
if (res.ok) {
return scrapeProfile(res.item, actorName, entity, include);
}
return res.status;
return res.ok ? scrapeScene(res.item, site) : res.status;
}
module.exports = {
fetchLatest,
fetchScene,
fetchProfile,
};