Package Exports
- node-csfd-api
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (node-csfd-api) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
CSFD API 2021
Tiny NPM library for scraping csfd.cz
- Browser + Node.js (SSR)
- TypeScript 100%
- ✅ Ready for CSFD 2021!
Scraper:
Install
via yarn
yarn add node-csfd-apivia npm
npm install node-csfd-apiUsage
Movie
Get info about this movie
import { csfd } from 'node-csfd-api';
csfd.movie(535121).then((movie) => console.log(movie));Results
{
title: 'Na špatné straně',
year: '2018',
descriptions: [
'Otupělý policejní veterán Ridgeman (Mel Gibson)...',
'Brett je policajt tesne ...'
],
genres: [ 'Krimi', 'Drama', 'Thriller' ],
type: 'film',
url: 'https://www.csfd.cz/film/535121',
origins: [ 'USA', 'Kanada' ],
colorRating: 'good',
rating: 73,
otherTitles: [
{ country: 'USA', title: 'Dragged Across Concrete' },
{ country: 'Kanada', title: 'Dragged Across Concrete' },
{ country: 'Slovensko', title: 'Na zlej strane' },
{ country: 'Austrálie', title: 'Dragged Across Concrete' },
{ country: 'Velká Británie', title: 'Dragged Across Concrete' }
],
poster: '//img.csfd.cz/files/images/film/posters/163/579/163579352_bf8737.jpg?h180',
directors: [
{
id: 87470,
name: 'S. Craig Zahler',
url: 'https://www.csfd.cz/tvurce/87470-s-craig-zahler/'
}
],
actors: [
{
id: 1,
name: 'Mel Gibson',
url: 'https://www.csfd.cz/tvurce/1-mel-gibson/'
},
// ...
],
basedOn: [],
writers: [
{
id: 87470,
name: 'S. Craig Zahler',
url: 'https://www.csfd.cz/tvurce/87470-s-craig-zahler/'
}
],
music: [
{
id: 203209,
name: 'Jeff Herriott',
url: 'https://www.csfd.cz/tvurce/203209-jeff-herriott/'
},
// ...
],
producers: [
{
id: 320006,
name: 'Sefton Fincham',
url: 'https://www.csfd.cz/tvurce/320006-sefton-fincham/'
},
// ...
]
}User Ratings
Last ratings (last page)
import { csfd } from 'node-csfd-api';
csfd.userRatings('912-bart').then((ratings) => console.log(ratings));All ratings (all pages)
Warning: Use it wisely. Can be detected and banned. Consider using it together with
allPagesDelayattribute.
import { csfd } from 'node-csfd-api';
csfd
.userRatings('912-bart', {
allPages: true, // Download all pages (one by one)
allPageDelay: 2000 // Make delay 2000ms on each page request
})
.then((ratings) => console.log(ratings));Results
[
{
title: 'David Attenborough: Život na naší planetě',
year: 2020,
type: 'film',
url: 'https://www.csfd.cz/film/812944-david-attenborough-zivot-na-nasi-planete/',
colorRating: 'good',
userDate: '01.11.2020',
userRating: 5
},
{
title: 'Coronation',
year: 2020,
type: 'film',
url: 'https://www.csfd.cz/film/912552-coronation/',
colorRating: 'good',
userDate: '28.10.2020',
userRating: 4
}
];Options
| Option | Type | Default | Description |
|---|---|---|---|
| includesOnly | CSFDFilmTypes[] | null | Including only film types. eg. ['TV Seriál', 'koncert'] |
| exclude | CSFDFilmTypes[] | null | Excluding film types eg. ['epizoda', 'série'] |
| allPages | boolean | false | Get all pages |
| allPagesDelay | number | 0 | Delay on each page request. In milliseconds |
Note: You can not use both parameters 'includesOnly' and 'excludes'. Parameter 'includesOnly' has a priority.
Roadmap
Scraping more pages
- Search (branch)
- Movies
- TV Series
- Users
- Creators
- Creators
- Bio
- Movies
- User Ratings
- Last ratings
- All pages
Development
Developing and debugging library
yarn startRun demo locally
You can find and modify it in ./demo.ts file
yarn demoDevelopment (notes for me)
Publish Stable
yarn release:patch
# yarn release:minor
# yarn release:majorPublish next channel
- Bump version
-beta.0inpackage.json yarn release:beta
Contribution
I welcome you to customize this according to your needs ;)
Pull requests for any improvements would be great!
Donation
If this project have helped you save time please consider making a donation for some 🍺 or 🍵 ;)
Privacy Policy
I DO NOT STORE ANY DATA. PERIOD.
I physically can't. I have nowhere to store it. I don't even have a server database to store it. So even if Justin Bieber asked nicely to see your data, I wouldn't have anything to show him.
That's why, with CSFD Api, what happens on your device stays on your device till disappear.
License
Copyright © 2021 Lukas Bartak
Proudly powered by nature 🗻, wind 💨, tea 🍵 and beer 🍺 ;)
All contents are licensed under the MIT license.