-
-
Notifications
You must be signed in to change notification settings - Fork 443
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
.nfo Scraper #1143
base: master
Are you sure you want to change the base?
.nfo Scraper #1143
Conversation
Example <?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<movie>
<title>Abigail Part 2</title>
<userrating></userrating>
<plot>After her experience in the kitchen, they have been caught, and the job is done. It's time for the next job. A mature couple on their anniversary and the lady of the relationship has sent something a little special to her husband's room - in the shape of a new set of golf clubs. But Abigail and Lena are here to do a job - to end a relationship that needs help to come to it's conclusion - whatever the reason.</plot>
<uniqueid type="stash">1</uniqueid>
<tag>69</tag>
<tag>atm</tag>
<tag>missionary</tag>
<tag>riding</tag>
<premiered>2018-08-14</premiered>
<studio>Tushy</studio>
<actor>
<name>Abigail Mac</name>
<role></role>
<haircolor>blonde</haircolor>
<order>0</order>
<thumb>http://localhost/performer/88/image</thumb>
</actor>
<actor>
<name>Lena Paul</name>
<role></role>
<order>1</order>
<thumb>http://localhost/performer/93/image</thumb>
</actor>
<actor>
<name>Mick Blue</name>
<role></role>
<tattoos>No</tattoos>
<order>2</order>
<thumb>http://localhost/performer/440/image</thumb>
</actor>
<thumb aspect="poster">http://localhost/scene/1/screenshot</thumb>
<thumb aspect="clearlogo">http://localhost/studio/9/image</thumb>
<fanart><thumb>http://localhost/scene/1/screenshot</thumb>
<thumb>http://1localhost/studio/9/image</thumb></fanart>
</movie>
|
`folder.nfo` is useful when you have a folder that belongs to specific studio or a movie so you can set studio, date and more via that single .nfo file for all the scenes in the movie. Variables in `.nfo` files: They're useful when you want to for example mix a title with the studio and the filename, so the xml file may have `title` element as `[%studio_name%] %filename%` Supported variables at this time are: * `title` - The title found in .nfo file, otherwise the title in scene fragment * `filename` - The filename of the scene, without extension * `fileextension` - The scene's file extension, e.g `.mp4` * `studio_name` - The studio's name found in .nfo file, otherwise the studio in scene fragment * `date` - The date found in .nfo file, otherwise the date in scene fragment
32d41a2 commit brings the following features:
Variables in
<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<movie>
<title>[%studio_name%] %filename%</title>
<studio>Example</studio>
</movie> The nfo file above will set scene title for all the scenes in the folder like the data from |
Hi TgSeed. Seems we are working on the same idea with slightly different approaches. Are you on Discord so we can chat? My discord pseudo is also ArcCdr. If you are interested, my version is still early alpha (started this week): https://github.com/ArcCdr/CommunityScripts/tree/nfoSceneParser/plugins/nfoSceneParser |
@TgSeed @ArcCdr instead of starting from scratch have you checked #689 ? |
@TgSeed Indeed, finishing #689 is probably best. I started as a plug-in rather than a scraper => your concept is closer to the unfinished pr. Makes more sense that you continue on it...
|
Well, that was simple and honestly, i didn't liked it (i'm a man of .NET so i prefer classes over raw objects, they give type-hinting and more so coding and editing is easier)
Excuse me, I'm confused now. Those things must be handled at the
Yep, thanks. SceneObject.details = movie.findtext('plot') or movie.findtext('outline') or movie.findtext('tagline') or SceneObject.details I will do it later. |
I'll let @bnkai decide on the "new" vs "update" given the previous pr. I'm not part of stash's team, just I have done NFO import/export before => I'll focus my advice on that. Indeed, the plot/outline/tagline you can do like you mention. For others you need a bit more logic as the content are different as well and needs to be interpreted:
A good refresh on the spec is https://kodi.wiki/view/NFO_files/Templates if you don't use it already. Other things you might want to support is movie sets (Not just with the expectation that there will be a folder.nfo file). The nfo spec supports a "set" tag that I have seen used for porn movies (each file is a scene, the "set" is the movie). Directly in the scene nfo as "set tag then... I saw you decided not to support ratings. Maybe add constants at the beginning of your scraper to let the user decide by (un)commenting a flag? |
@ArcCdr any PR that is working and tests ok is fine to merge. Do you have by any chance any non Kodi generated NFO samples? Do we target Kodi compliant nfos or general XML based nfos? I think there were some samples in the first PR and the relevant issues, I will update when I get some time from my PC |
@bnkai Thanks for the clarification on "merge conditions" ;-) NFO spec is pretty much defined by KODI. If you target that, you are green. Other soft added proprietary extensions, but they are of low/no value to stash. I'll send you via Discord a few nfo files of different "origins" if you want to do some tests. |
Assuming the `.nfo` creator output the date and rating as is in stash, for example, date must be in format `2006-01-30` Thanks to @ArcCdr for the suggestions
Added the suggested aliases by @ArcCdr via c6b4b97 commit. I don't see any other changes that I'm going to do because it works assuming the exported @ArcCdr LMK If I'm correct so we will know and we it get merged finally. then you're of course free to enhance it all. |
@TgSeed I think you have build a very sound scraper! I understood from bnkai's past comments, it was good to merge the first time. @bnkai you were going to test with a few nfo's before the merge I think? Thanks for the most recent changes. For the "year" tag, I'm not sure how stash reacts when a plugin return just 4 digits year as date. Does it add "-01-01" to it or you need to do it in the plugin? Depending on that, you might want to contact the parsed year with month & day to avoid runtime errors. If you are on discord, let me know your id and I can send you a set of nfo files you can use to test ones generated by various sources (not only KODI or stash plugins). |
@TgSeed can you move the scraper in a separate folder and add a README, mostly to explain the folder.nfo usage and the variables?
I was not aware of a program exporting images in the nfo as base64 strings, is that available somewhere? Please add to the readme the assumptions you made as well @TgSeed if its ok with you i will merge after you are done with the scraper and then we will use a new PR to add extra functionality |
Done.
Unfortunately, there's not or I don't know of.
Sure, it's all done from my point of view. Thanks |
@TgSeed The nfo spec for images is to have them as separate files. for instance video.mp4 & video-landscape.jpg. I am working with Scruffy to refine his SNEK plugin that generates nfos. We will do it like that (image export as file, not as B64 text into the nfo). Let's try to stick to the spec as much as possible. So I guess you will be the only user of the B64 in the nfo ;-) You might want to support loading the image from the nfo compliant file structure as well... |
Hello
We have imagined a program that would allow us to categorize and watch our "videos" in our local devices, stash came... then we imagined if stash can find metadata of "videos" automatically, scrapers came... now we imagining if stash can simply get metadata without going through scenes, search results and scrapers one by one, here is the .nfo scraper!
.nfo scraper allow you to set Scenes', Performers' and Studios' data with ease, if other people gets into it.
.nfo
files contain data about the scene/movie, like the title, release date and many more. They're widely used by Kodi. You may have seen.nfo
files in torrent files and if you're professional in that, you know that.nfo
files are always in some torrent filesUnfortunately, i have never seen
.nfo
files with porn! i guess this is because it isn't going to be used.Imagine if you get your hundred recently downloaded porn videos getting their metadata and things set in a single click! That's how
.nfo
can help if it get correctly implemented in stash (look how well Kodi is spreading.nfo
files for "Movies")The scraper, by the time of writing this, is capable of reading scene data from
.nfo
files and send to stash the scene data (cover, date, tags and more.), performers' names and studio name. because of current stash limitations.Extending stash in some specific parts can unleash the
.nfo scraper
capabilities, without modifying the scraper so it will be able to create performers with their data (image, country, hair color, tattoos, tags and more.), studios with their name, aliases, URL and image.The scraper tries to read
.nfo
files in the same directory of the video with the same filename, but with the.nfo
extension.OR
.nfo
file with the same filename but in the.nfo/
directory within the video's directory.So so,
C:\video1.mp4
nfo file can beC:\video1.nfo
orC:\.nfo\video1.nfo
Scraping is easy peasy, because it uses Scrape by Fragment, you don't need to input search query or anything, and stash can do it in bulk.
There has been an attempt (#689) previously to make it and several Feature Requests (stashapp/stash#428, stashapp/stash#1199, #429) relating.
Side note: Currently there is a kodi-helper script by @WithoutPants which i found it has some minor issues with the latest stash or python 3.10 probably. Anyway, you may be able to use it to create .nfo files, however, let's wish for a better solution.