const upsert = require('../src/utils/upsert'); const tagPosters = Object.entries({ 'anal-creampie': ['poster'], 'ass-to-mouth': ['poster', 'Alysa Gap and Logan in "Anal Buffet 4" for Evil Angel'], 'da-tp': [0, 'Natasha Teen in LegalPorno SZ2164'], 'double-anal': [2, 'Lana Rhoades in "Gangbang Me 3" for HardX'], 'double-penetration': ['poster', 'Mia Malkova in "DP!" for HardX'], 'double-vaginal': ['poster'], 'dv-tp': ['poster', 'Juelz Ventura in "Gangbanged 5" for Elegant Angel'], 'oral-creampie': [1, 'Keisha Grey in Brazzers House'], 'triple-anal': ['poster', 'Kristy Black in SZ1986 for LegalPorno'], airtight: [1, 'Jynx Maze in "Pump My Ass Full of Cum 3" for Jules Jordan'], anal: ['poster', 'Jynx Maze in "Anal Buffet 6" for Evil Angel'], asian: ['poster', 'Vina Sky in "Young and Glamorous 10" for Jules Jordan'], blowbang: ['poster'], bukkake: ['poster'], caucasian: ['poster'], creampie: ['poster'], ebony: [1, 'Sarah Banks for Brazzers'], facial: ['poster'], gangbang: ['poster', 'Kristen Scott in "Interracial Gangbang!" for Jules Jordan'], gaping: ['poster', 'Paulina in "Anal Buffet 4" for Evil Angel'], interracial: ['poster'], latina: ['poster'], mff: ['poster'], mfm: ['poster'], orgy: ['poster'], schoolgirl: [1, 'Eliza Ibarra for Brazzers'], swallowing: ['poster'], tattoo: ['poster', 'Kali Roses in "Goes All In For Anal" for Hussie Pass'], trainbang: ['poster', 'Kali Roses in "Passing Me Around" for Blacked'], }) .map(([slug, [filename, comment]], index) => ({ tagSlug: slug, path: `tags/${slug}/${filename}.jpeg`, thumbnail: `tags/${slug}/${filename}_thumb.jpeg`, mime: 'image/jpeg', index, comment, })); const tagPhotos = [ ['airtight', 2, 'Dakota Skye in "Dakota Goes Nuts" for ArchAngel'], ['airtight', 3, 'Anita Bellini in "Triple Dick Gangbang" for Hands On Hardcore (DDF Network)'], ['anal', 0], ['da-tp', 1, 'Francys Belle in SZ1702 for LegalPorno'], ['da-tp', 2, 'Angel Smalls in GIO408 for LegalPorno'], ['da-tp', 3, 'Evelina Darling in GIO294'], ['da-tp', 4, 'Ninel Mojado aka Mira Cuckold in GIO063 for LegalPorno'], ['double-anal', 'poster', 'Haley Reed in "Young Hot Ass" for Evil Angel'], ['double-anal', 0, 'Nicole Black doing double anal during a gangbang in GIO971 for LegalPorno'], ['double-anal', 1, 'Ria Sunn in SZ1801 for LegalPorno'], ['double-penetration', 0], ['dv-tp', 1, 'Adriana Chechik in "Adriana\'s Triple Anal Penetration!"'], ['dv-tp', 0, 'Luna Rival in LegalPorno SZ1490'], ['gangbang', 0, '"4 On 1 Gangbangs" for Doghouse Digital'], ['gangbang', 1, 'Ginger Lynn in "Gangbang Mystique", a photoset shot by Suze Randall for Puritan No. 10, 1984. This photo pushed the boundaries of pornography at the time, as depicting a woman \'fully occupied\' was unheard of.'], ['gangbang', 2, 'Riley Reid\'s double anal in "The Gangbang of Riley Reid" for Jules Jordan'], ['gaping', 3, 'Kelsi Monroe in "Brazzers House 2, Day 2" for Brazzers'], ['gaping', 0, 'McKenzee Miles in "Anal Buffet 4" for Evil Angel'], ['trainbang', 0, 'Nicole Black in GIO971 for LegalPorno'], ['triple-anal', 1, 'Natasha Teen in SZ2098 for LegalPorno'], ['triple-anal', 2, 'Kira Thorn in GIO1018 for LegalPorno'], ['oral-creampie', 'poster', 'Khloe Kapri'], ] .map(([slug, fileIndex, comment], index) => ({ tagSlug: slug, path: `tags/${slug}/${fileIndex}.jpeg`, thumbnail: `tags/${slug}/${fileIndex}_thumb.jpeg`, mime: 'image/jpeg', index, comment, })); /* eslint-disable max-len */ exports.seed = knex => Promise.resolve() .then(async () => { const tagMedia = tagPosters.concat(tagPhotos); const tags = await knex('tags').whereIn('slug', tagMedia.map(item => item.tagSlug)); const { inserted, updated } = await upsert('media', tagMedia.map(({ path, thumbnail, mime, index, comment, }) => ({ path, thumbnail, mime, index, comment, })), 'path', knex); const tagIdsBySlug = tags.reduce((acc, tag) => ({ ...acc, [tag.slug]: tag.id }), {}); const mediaIdsByPath = inserted.concat(updated).reduce((acc, item) => ({ ...acc, [item.path]: item.id }), {}); const tagPosterEntries = tagPosters.map(poster => ({ tag_id: tagIdsBySlug[poster.tagSlug], media_id: mediaIdsByPath[poster.path], })); const tagPhotoEntries = tagPhotos.map(photo => ({ tag_id: tagIdsBySlug[photo.tagSlug], media_id: mediaIdsByPath[photo.path], })); return Promise.all([ upsert('tags_posters', tagPosterEntries, 'tag_id', knex), upsert('tags_photos', tagPhotoEntries, ['tag_id', 'media_id'], knex), ]); });