forked from DebaucheryLibrarian/traxxx
Merge branch 'experimental' into master
This commit is contained in:
commit
5767bfb5a2
|
@ -88,6 +88,8 @@ export default {
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
overflow-x: hidden;
|
overflow-x: hidden;
|
||||||
|
box-shadow: 0 0 3px var(--shadow-weak);
|
||||||
|
z-index: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
.slide-enter-active,
|
.slide-enter-active,
|
||||||
|
|
|
@ -228,6 +228,15 @@ export default {
|
||||||
height: 1rem;
|
height: 1rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.content-inner {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
|
||||||
|
.releases {
|
||||||
|
flex-grow: 1;
|
||||||
|
}
|
||||||
|
|
||||||
.name {
|
.name {
|
||||||
color: var(--text-light);
|
color: var(--text-light);
|
||||||
display: flex;
|
display: flex;
|
||||||
|
|
|
@ -11,10 +11,8 @@
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.footer {
|
.footer {
|
||||||
margin: 2rem 0 0 0;
|
background: var(--background-dim);
|
||||||
background: var(--background);
|
|
||||||
color: var(--shadow);
|
color: var(--shadow);
|
||||||
box-shadow: inset 0 1px 3px var(--darken-hint);
|
|
||||||
font-size: .8rem;
|
font-size: .8rem;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
@ -30,5 +28,9 @@
|
||||||
|
|
||||||
.footer-link {
|
.footer-link {
|
||||||
text-decoration: underline;
|
text-decoration: underline;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
color: var(--primary);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<template>
|
<template>
|
||||||
<div class="content">
|
<div class="home">
|
||||||
<div
|
<div
|
||||||
ref="content"
|
ref="content"
|
||||||
class="content-inner"
|
class="content-inner"
|
||||||
|
@ -20,10 +20,10 @@
|
||||||
:items-per-page="limit"
|
:items-per-page="limit"
|
||||||
class="pagination-bottom"
|
class="pagination-bottom"
|
||||||
/>
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
<Footer />
|
<Footer />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
@ -79,3 +79,11 @@ export default {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.home {
|
||||||
|
flex-grow: 1;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
|
@ -2,23 +2,23 @@ import dayjs from 'dayjs';
|
||||||
|
|
||||||
const dateRanges = {
|
const dateRanges = {
|
||||||
latest: () => ({
|
latest: () => ({
|
||||||
after: '1900-01-01',
|
after: '1900-01-01 00:00:00',
|
||||||
before: dayjs(new Date()).add(1, 'day').format('YYYY-MM-DD'),
|
before: dayjs().format('YYYY-MM-DD HH:mm:ss'),
|
||||||
orderBy: 'DATE_DESC',
|
orderBy: 'DATE_DESC',
|
||||||
}),
|
}),
|
||||||
upcoming: () => ({
|
upcoming: () => ({
|
||||||
after: dayjs(new Date()).format('YYYY-MM-DD'),
|
after: dayjs().format('YYYY-MM-DD HH:mm:ss'),
|
||||||
before: '2100-01-01',
|
before: '2100-01-01 00:00:00',
|
||||||
orderBy: 'DATE_ASC',
|
orderBy: 'DATE_ASC',
|
||||||
}),
|
}),
|
||||||
new: () => ({
|
new: () => ({
|
||||||
after: '1900-01-01',
|
after: '1900-01-01 00:00:00',
|
||||||
before: '2100-01-01',
|
before: '2100-01-01 00:00:00',
|
||||||
orderBy: 'CREATED_AT_DESC',
|
orderBy: ['CREATED_AT_DESC', 'DATE_ASC'],
|
||||||
}),
|
}),
|
||||||
all: () => ({
|
all: () => ({
|
||||||
after: '1900-01-01',
|
after: '1900-01-01 00:00:00',
|
||||||
before: '2100-01-01',
|
before: '2100-01-01 00:00:00',
|
||||||
orderBy: 'DATE_DESC',
|
orderBy: 'DATE_DESC',
|
||||||
}),
|
}),
|
||||||
};
|
};
|
||||||
|
|
|
@ -7,13 +7,15 @@ function initReleasesActions(store, _router) {
|
||||||
async function fetchReleases({ _commit }, { limit = 10, pageNumber = 1, range = 'latest' }) {
|
async function fetchReleases({ _commit }, { limit = 10, pageNumber = 1, range = 'latest' }) {
|
||||||
const { before, after, orderBy } = getDateRange(range);
|
const { before, after, orderBy } = getDateRange(range);
|
||||||
|
|
||||||
|
console.log(after, before, orderBy);
|
||||||
|
|
||||||
const { connection: { releases, totalCount } } = await graphql(`
|
const { connection: { releases, totalCount } } = await graphql(`
|
||||||
query Releases(
|
query Releases(
|
||||||
$limit:Int = 1000,
|
$limit:Int = 1000,
|
||||||
$offset:Int = 0,
|
$offset:Int = 0,
|
||||||
$after:Datetime = "1900-01-01",
|
$after:Datetime = "1900-01-01 00:00:00",
|
||||||
$before:Datetime = "2100-01-01",
|
$before:Datetime = "2100-01-01 00:00:00",
|
||||||
$orderBy:[ReleasesOrderBy!],
|
$orderBy: [ReleasesOrderBy!],
|
||||||
$exclude: [String!]
|
$exclude: [String!]
|
||||||
) {
|
) {
|
||||||
${releasesFragment}
|
${releasesFragment}
|
||||||
|
|
|
@ -197,6 +197,7 @@ module.exports = {
|
||||||
lazyQuality: 90,
|
lazyQuality: 90,
|
||||||
videoQuality: [480, 360, 320, 540, 720, 1080, 2160, 270, 240, 180],
|
videoQuality: [480, 360, 320, 540, 720, 1080, 2160, 270, 240, 180],
|
||||||
limit: 25, // max number of photos per release
|
limit: 25, // max number of photos per release
|
||||||
|
streamConcurrency: 2, // max number of video streams (m3u8 etc.) to fetch and process at once
|
||||||
},
|
},
|
||||||
titleSlugLength: 50,
|
titleSlugLength: 50,
|
||||||
};
|
};
|
||||||
|
|
|
@ -4968,7 +4968,7 @@ const sites = [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'Horny doctor',
|
name: 'Horny Doctor',
|
||||||
slug: 'hornydoctor',
|
slug: 'hornydoctor',
|
||||||
url: 'https://www.hornydoctor.com',
|
url: 'https://www.hornydoctor.com',
|
||||||
parent: 'porncz',
|
parent: 'porncz',
|
||||||
|
|
|
@ -30,11 +30,6 @@ const { argv } = yargs
|
||||||
type: 'boolean',
|
type: 'boolean',
|
||||||
alias: 'web',
|
alias: 'web',
|
||||||
})
|
})
|
||||||
.option('all', {
|
|
||||||
describe: 'Scrape channels and networks defined in configuration',
|
|
||||||
type: 'boolean',
|
|
||||||
alias: 'scrape',
|
|
||||||
})
|
|
||||||
.option('networks', {
|
.option('networks', {
|
||||||
describe: 'Network to scrape all channels from (overrides configuration)',
|
describe: 'Network to scrape all channels from (overrides configuration)',
|
||||||
type: 'array',
|
type: 'array',
|
||||||
|
|
10
src/media.js
10
src/media.js
|
@ -13,6 +13,7 @@ const mime = require('mime');
|
||||||
const ffmpeg = require('fluent-ffmpeg');
|
const ffmpeg = require('fluent-ffmpeg');
|
||||||
const sharp = require('sharp');
|
const sharp = require('sharp');
|
||||||
const blake2 = require('blake2');
|
const blake2 = require('blake2');
|
||||||
|
const taskQueue = require('promise-task-queue');
|
||||||
|
|
||||||
const logger = require('./logger')(__filename);
|
const logger = require('./logger')(__filename);
|
||||||
const argv = require('./argv');
|
const argv = require('./argv');
|
||||||
|
@ -22,6 +23,7 @@ const bulkInsert = require('./utils/bulk-insert');
|
||||||
const { get } = require('./utils/qu');
|
const { get } = require('./utils/qu');
|
||||||
|
|
||||||
const pipeline = util.promisify(stream.pipeline);
|
const pipeline = util.promisify(stream.pipeline);
|
||||||
|
const streamQueue = taskQueue();
|
||||||
|
|
||||||
function sampleMedias(medias, limit = config.media.limit, preferLast = true) {
|
function sampleMedias(medias, limit = config.media.limit, preferLast = true) {
|
||||||
// limit media sets, use extras as fallbacks
|
// limit media sets, use extras as fallbacks
|
||||||
|
@ -419,7 +421,7 @@ async function fetchHttpSource(source, tempFileTarget, hashStream) {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
async function fetchStreamSource(source, tempFileTarget, tempFilePath, hashStream) {
|
streamQueue.define('fetchStreamSource', async ({ source, tempFileTarget, hashStream }) => {
|
||||||
const meta = { mimetype: 'video/mp4' };
|
const meta = { mimetype: 'video/mp4' };
|
||||||
|
|
||||||
const video = ffmpeg(source.stream)
|
const video = ffmpeg(source.stream)
|
||||||
|
@ -434,7 +436,9 @@ async function fetchStreamSource(source, tempFileTarget, tempFilePath, hashStrea
|
||||||
logger.verbose(`Finished fetching stream from ${source.stream}`);
|
logger.verbose(`Finished fetching stream from ${source.stream}`);
|
||||||
|
|
||||||
return meta;
|
return meta;
|
||||||
}
|
}, {
|
||||||
|
concurrency: config.media.streamConcurrency,
|
||||||
|
});
|
||||||
|
|
||||||
async function fetchSource(source, baseMedia) {
|
async function fetchSource(source, baseMedia) {
|
||||||
logger.silly(`Fetching media from ${source.src}`);
|
logger.silly(`Fetching media from ${source.src}`);
|
||||||
|
@ -457,7 +461,7 @@ async function fetchSource(source, baseMedia) {
|
||||||
});
|
});
|
||||||
|
|
||||||
const { mimetype } = source.stream
|
const { mimetype } = source.stream
|
||||||
? await fetchStreamSource(source, tempFileTarget, tempFilePath, hashStream)
|
? await streamQueue.push('fetchStreamSource', { source, tempFileTarget, hashStream })
|
||||||
: await fetchHttpSource(source, tempFileTarget, hashStream);
|
: await fetchHttpSource(source, tempFileTarget, hashStream);
|
||||||
|
|
||||||
hasher.end();
|
hasher.end();
|
||||||
|
|
|
@ -20,10 +20,10 @@ function curateRelease(release, withMedia = false) {
|
||||||
id: release.entity.id,
|
id: release.entity.id,
|
||||||
name: release.entity.name,
|
name: release.entity.name,
|
||||||
slug: release.entity.slug,
|
slug: release.entity.slug,
|
||||||
parent: release.entity.parent && {
|
parent: release.parent && {
|
||||||
id: release.entity.parent.id,
|
id: release.parent.id,
|
||||||
name: release.entity.parent.name,
|
name: release.parent.name,
|
||||||
slug: release.entity.parent.slug,
|
slug: release.parent.slug,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
actors: (release.actors || []).map(actor => ({
|
actors: (release.actors || []).map(actor => ({
|
||||||
|
|
|
@ -37,7 +37,7 @@ async function filterUniqueReleases(latestReleases, accReleases) {
|
||||||
return uniqueReleases;
|
return uniqueReleases;
|
||||||
}
|
}
|
||||||
|
|
||||||
function needNextPage(uniqueReleases, pageAccReleases) {
|
function needNextPage(uniqueReleases, pageAccReleases, hasDates) {
|
||||||
if (uniqueReleases.length === 0) {
|
if (uniqueReleases.length === 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -47,7 +47,7 @@ function needNextPage(uniqueReleases, pageAccReleases) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (uniqueReleases.every(release => !!release.date)) {
|
if (hasDates) {
|
||||||
const oldestReleaseOnPage = uniqueReleases
|
const oldestReleaseOnPage = uniqueReleases
|
||||||
.sort((releaseA, releaseB) => releaseB.date - releaseA.date)
|
.sort((releaseA, releaseB) => releaseB.date - releaseA.date)
|
||||||
.slice(-1)[0];
|
.slice(-1)[0];
|
||||||
|
@ -74,18 +74,15 @@ async function scrapeReleases(scraper, entity, preData, upcoming = false) {
|
||||||
return accReleases;
|
return accReleases;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* prevents argv.last from being satisfied
|
|
||||||
if (latestReleases.length === 0) {
|
|
||||||
// scraper successfully requested releases, but found none
|
|
||||||
return accReleases;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
const latestReleasesWithEntity = latestReleases.map(release => ({
|
const latestReleasesWithEntity = latestReleases.map(release => ({
|
||||||
...release,
|
...release,
|
||||||
entity: release.entity || entity, // allow override
|
entity: release.entity || entity, // allow override
|
||||||
})); // attach entity the release is assigned to when stored
|
})); // attach entity the release is assigned to when stored
|
||||||
|
|
||||||
|
const hasDates = latestReleasesWithEntity.every(release => !!release.date);
|
||||||
|
|
||||||
|
console.log(hasDates);
|
||||||
|
|
||||||
const uniqueReleases = argv.redownload
|
const uniqueReleases = argv.redownload
|
||||||
? latestReleasesWithEntity
|
? latestReleasesWithEntity
|
||||||
: await filterUniqueReleases(latestReleasesWithEntity, accReleases);
|
: await filterUniqueReleases(latestReleasesWithEntity, accReleases);
|
||||||
|
@ -94,7 +91,7 @@ async function scrapeReleases(scraper, entity, preData, upcoming = false) {
|
||||||
|
|
||||||
logger.verbose(`Scraped '${entity.name}' (${entity.parent?.name}) ${upcoming ? 'upcoming' : 'latest'} page ${page}, found ${uniqueReleases.length} unique updates`);
|
logger.verbose(`Scraped '${entity.name}' (${entity.parent?.name}) ${upcoming ? 'upcoming' : 'latest'} page ${page}, found ${uniqueReleases.length} unique updates`);
|
||||||
|
|
||||||
if (needNextPage(uniqueReleases, pageAccReleases)) {
|
if (needNextPage(uniqueReleases, pageAccReleases, hasDates)) {
|
||||||
return scrapePage(page + 1, pageAccReleases);
|
return scrapePage(page + 1, pageAccReleases);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue