* Build on Azure instead of Appveyor
* fixup! Update Nuget
* fixup! installer and tests
* fixup! automation tests mac/linux
* Fix .gitattributes
* Fix line endings
* Try to fix integration tests
* Install mediainfo
* Update sqlite3 binaries for windows and mac
* Update media info to 20.03 and fix test
* Fix HttpClientTests, Use Servarr HttpBin Mirror
* Update test script
* Add media info to tests
* Fix tests
* Ignore tests ignored on Aphrodite
* partial automation update
* Reveet mac mediaInfo upgrade
* fixup! automation tests
* Revert "Reveet mac mediaInfo upgrade"
This reverts commit b54a76446b.
* Don't run linux tests on mac
* Exclude test failing on mac
Co-authored-by: ta264 <ta264@users.noreply.github.com>
* Added Dolby Digital Plus with Atmos
Added Dolby Digital Plus with Atmos by checking the codec additional features for JOC, which stands for Joint Object Coding and is the technique used for adding Atmos metadata to Dolby Digital Plus audio streams. This is similar to the 16-ch additional feature used to distinguish Atmos in a TrueHD audio stream.
* Corrected positioning of EAC3 Atmos
* Changed the formatting from aphrodite to dapper
"splitAdditionalFeatures.ContainsIgnoreCase" was changed to "audioAdditionalFeatures =="
* Removed White Space at the end of line 176
* Fix IMDb IDs
* Fix type errors
* Attribute is named imdb
* Use TryParse instead
* Use TryParse properly
* Pass out keyword
* Use variable instead of property
* Added UHD, X265, WEB-DL etc. to NZB Finder
This works for Sonarr, can Radarr also add custom categories like this?
* Remove root and foreign categories for NZB Finder
As discussed https://github.com/Radarr/Radarr/pull/3568
* Remove duplicate preset
* Added qBittorent state 'moving'
The state 'moving' wasn't being recording in Radarr, so it would show up
as a warning.
* Updated unknown state to be info
* Fixed#1958
- extra file module will search for any subfolder and filename
- fixed language parser to match RARBG format
- Add .srt subs according to level of details such that higher detailed sub gets loaded to media player first
* Fixed Code Factor issue on SubtitleService.cs:104
* Fixed: issues on unit test for TV subs; added test cases for RARBG movie subs
* Updated RARBG parser so it won't match movie title format
* Cleaned up code for review
* Update SubtitleService.cs
* Fixed: When refreshing info about a movie, the alt titles should now correctly be deleted / updated, even from TMDB.
Fixes#3542
* Fixed: Small things fixup.
* Add tags support to NetImport (Lists)
* Keep indentation consistent with current code
* Initialize set of empty tags
* Add tags from list to movie
* Prevent tags used by lists from being removed
* Adding CheckForFinishedDownloadInterval to config service
Changed TaskManager to use a configurable interval for CheckForFinishedDownloadCommand
* Adding new CheckForFinishedDownloadInterval to UI
Fixes#840
* Added support for Gotify notifications
* Use string interpolation to build url
* Adapt changes by markus101 over at Sonarr
* Remove blank line
Fixes#3472
After the changes from PR #2948, the regex was too eager to match any
substring contain "SK", such as in "MASK". Fix by requiring word
separation around it, as was already the case with the "CZ" token.
* Rename all 'episodeFile' variables to 'movieFile'
* Improve media info extraction with more fields
* Improve media info tokens extraction
* Add missing fields to MediaInfoModel
* Restore to previous implementation of null handling
* Forgot to add MediaInfoFormatter to project
* Add missing EqualsIgnoreCase extension method
* Simplify Logger.Debug() invocations
* Add missing StartsWithIgnoreCase extension method
* This '.Value' shouldn't be required
* Remove TODO comment
* Upgrade MediaInfo from 17.10 to 18.08.1
* Use correct media info field for files listing
* Replace media info "VideoCodec" (deprecated) with "VideoFormat"
* Fix 'Formatiting' typos
* Add support for media info Format_AdditionalFeatures' field
* Add proper support for all DTS and TrueHD flavors
* Add support for '3D' media info token
* Remove deprecated media info video/audio profile fields
* Add support for 'HDR' media info token
* Add new video parameters to anime file name sample
* Adapt tests for new media info fields
* Revert "Remove deprecated media info video/audio profile fields"
* Include missing test files in core test project
* Fix small regression issue
* Allow sample movie to be detected as HDR
* Do not parse audio channel positions if there are no channels
* Clean up extra blank line
* Reuse already declared variable
* Fix wrong audio channels detection on DTS:X streams
* Fix all failing unit tests
* Fix remaining failing unit tests
- Rescan old movie files to apply new custom formats!
- Delete poorly thought out life choi..., I mean custom formats.
- Rename R (regex) to RX and RE (required) to RQ, which of course makes way more sense
- Remove unwanted UI code
- Actually implemented idea that was supposed to be there from the beginning (I blame git) (Reject releases if custom format is not wanted by profile)
- Remember file names? Radarr intermittently forgot about them too! (Fixed Radarr not using filenames for parsing)
- Your custom format does not work??? Well now you at least know a bit more about that.
- When editing / creating a custom format, it will now be highlighted in the testing area, so you actually know if you are making it worse.
- You prefer large or small? Radarr doesn't judge! Create custom formats tailored to your preferences with the new size format tag! (G_)
- Want to manually edit your qualities since you are paranoid? Now Radarr has a unified quality editing UI for both manual import and files! (Also you can now manually set the custom formats for a file)
- Scared of change? Custom formats are completely hidden unless you enable advanced settings! - Rescan old movie files to apply new custom formats! - Delete poorly thought out life choi..., I mean custom formats. - Rename R (regex) to RX and RE (required) to RQ, which of course makes way more sense - Remove unwanted UI code - Actually implemented idea that was supposed to be there from the beginning (I blame git) (Reject releases if custom format is not wanted by profile) - Remember file names? Radarr intermittently forgot about them too! (Fixed Radarr not using filenames for parsing) - Your custom format does not work??? Well now you at least know a bit more about that. - When editing / creating a custom format, it will now be highlighted in the testing area, so you actually know if you are making it worse. - You prefer large or small? Radarr doesn't judge! Create custom formats tailored to your preferences with the new size format tag! (G_) - Want to manually edit your qualities since you are paranoid? Now Radarr has a unified quality editing UI for both
Originally called project metis, this feature allows you to do a lot of cool stuff, such as upgrading to a x265 encode, downloading releases with multiple languages, etc. Check out the wiki page at: https://github.com/Radarr/Radarr/wiki/Custom-Formats to learn more! Note: This feature is currently in "beta" and will get more tags and features in the future. Please let me know, if you have any issues and I hope this will allow for a lot of customization!
Fixes#2585
Merge remote-tracking branch 'origin/develop' into develop
Revert "Fixed: NLog causing a crash under mono 5.10"
This reverts commit d11b565eda.
Added console logging in case NLog fails to initialize.
Fixed: Updated NLog to 4.5 RC6 to handle mono 5.10
Fixed: Messed up merge from Cherry pick
Fixed: Appveyor build.
Revert "Fixed: Appveyor build."
This reverts commit 99282359c4.
Revert "Fixed: Messed up merge from Cherry pick"
This reverts commit 450d90586d.
Revert "Fixed: Updated NLog to 4.5 RC6 to handle mono 5.10"
This reverts commit 1b20cbb5e3.
Fixed: NLog causing issues with mono 5.10
Old folder is now only left behind if extra files are also present in new dir and cannot be overwritten. Generally Dynamic Paths should be more stable now. Fixes#2048
* Added: some tips to how to build. Gave some info to Windows developers.
* Fixed: Alignment of validation errors in labels
* Fixed: error message mentioning 'series'
* New: Initial state for torrents added to UTorrent
Closes#409
(cherry picked from commit 19a4d3536b)
* Change default port
* Rename TvCategory to MovieCategory
Added: Ability to force download movies that could not be mapped correctly. This also shares these mappings with other users, so everyone can profit :)
Added: A secondary year will also be pulled from mappings.radarr.video.
Added: An option to force download a movie with wrong year / title. Radarr then adds the year / title to mappings.radarr.video.
Added: Option to make mapping more lenient. This should practically allow all movies to be correctly mapped. Though it also opens the path for movies being wrongly mapped! (So it is a toggable option)
Added: Improved edition parsing. Now almost all releases should have the correct edition, even ones with no year, etc.
* Added advanced configuration options to support filtering Categories, Codecs, and Medium to the HDBits indexer.
* Changes to use the existing tags with a controlled vocabulary.
* 1) Sorting select options by name
2) Moved the autocomplete tag code into taginput as requested
* removed commented out line
* require cleanups
Discovery results now show physical release date (if present).
All physical release dates now should show a note (if available) detailing what kind of release date it is (e.g. Netflix, DVD, Streaming, etc.)
Currently new exclusions can only be added when adding new movies or deleting old ones. Not manually in the settings menu.
Movies can now be hidden in the new discover feature by using the new import exclusions!
* Fix HDbits
* Fix pending release service, also fix the deduper
* Clean up the cleanup'er (housekeeping)
* Revert "Clean up the cleanup'er (housekeeping)"
This reverts commit c03c13d924.
* Housekeeping updates, without breaking tests
* Fix last test
* clear localStorage on radarr update.. ya mon
* Fix when movie folder is deleted from disk and keeps showing up as downloaded in radarr
* Clear all UI localStorage items on update, set pageSize to what it needs to be.
* Update message when the person has no movies with helpful links
* Added ImdbId to the release info from AwesomeHD
* Add ImdbId to release info for PTP and HDBits
* ImdbId is required for HDBits
* Added some error handling in SkyHook for TMDb
* Remove un-needed imports
* DIsable movie search after list sync (causing issues)
* small change
* Fix HDBits tests
* Update BlacklistService
* Update HistoryService, HistoryRepo and History
* Update UI in Blacklists to movies
* set the movie model so the movie title prints in blacklist
* Would be working if I implemented the Event Handler for MovieFileDeleted
* Move ToUrlSlug to Parser, fix issue with trakt lists that have non-alphanumeric characters
* Move "Add movies" link in nav to the first link
* String interpolation!
* Add Limit to Trakt List Settings to limit the amount of movies returned, 50 by default
* Updates to FailedDownload
* Update DownloadService and CompleteDownloadService
* Add Installation section with Installation, Docker and Setup Guide. Add feathub and wiki to Support.
* Convert to badges and use the best colors.
* Fix silly mistake of leaving [Word]s in.
* Switch to b7b7b7 which is easier to read w/ white text.
* Use github color from simpleicons.org.
* Changed colors a bit.
* Added FAQ
* Cleaning up some jsLiniting problems
* fix jshint issue with variablle declaration
This shouldn't be an issue because of hoisting but, jshint is finicky.
* Update variable names, also pass imdb to parsing service from downloaddescisionmaker
* Changes to the DownloadDescisionMaker to use ImdbId when looking for movie. Should fix a lot of Unknown Movie errors.
* Add movie link to nav bar, update Movies image to be fa-film :) Minor UI change.
the change fixed sorting titles of newly added movies without a refresh
however, people have noticed it broke sorting of "In Cinemas" column in general.
i commented out the change; but also added a special case in the comment, that would fix the case in question, without
breaking the others; however, more investigating is needed because there is an issue with sorting newly added movies in general and the
fix this reverts was never good enough anyway.
* Replace Sonarr with Radarr in some more places, update rTorrent to use
* Uncomment some lines
* Fix CP importing
* Upon first sync with adding movies with Lists, it will search for the movie.
* Update rarbg indexer, add method to netimportsearch service
* Replace german chars in movie title when searching newznab. Update netimportsearchservice
* First fixing of tests.
* Updated more tests.
* Fix some tests
* Fix all prioritization tests.
And add new for preferred words.
* Updated CompletedDownloadservice tests
* Fixed a lot of tests
* Fixed all indexer requests. We should add more for the indexers we added.
To lazy for that though ¯\_(ツ)_/¯
* Fixed organizer tests.
Should probably be also updated to incorporate our newly added tags.
* Fix notification tests.
* Fixed update test for osx
* Fixed a few more tests.
* Fixed some more tests.
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update appveyor.yml
* Update activity.less
* Update appveyor.yml
* Update appveyor.yml
* Update CommonVersionInfo.cs
* Update build-appveyor.cake
Let's hope this works.
* Update CommonVersionInfo.cs
Just to kickstart appveyor
* Fixed a few tests
* Just ignore those tests.
* Fixed more tests.
* First steps in fixing Core.Test.Download.DownloadApprovedFixture
* Fix most DownloadApprovedFixture tests
* Fixed something.
* Fixed a few more tests.
* Fixed pending release tests.
* All Core tests are now fixed.
* Fixed the last tests :)
* Fixed Download Station Tests.
* Fixed Vuze and Transmission default settings which caused the tests to fail.
* Fix most tests.
* Fix RootFolder tests.
* Fixed last tests
* Improve indexer health check messages
Fixed: Improve health check message when all enabled indexers are disabled due to failures
Closes#1551
* Fixed: Health check failing and preventing others from running
* Fixed Indexer Health Checks and tests.
* this fixes some issues where the table
was rendering with incorrect data
prior to it being updated....
it also has the FullCollection fetched when necessary..
this will make the movie Index be accurate even after deleting files
or when returning from the movieEditor..
The footer has been improved and since
FullMovieCollection is now kept up to date the footer changes
as the user performs operations and it shows all the time with proper info
even after deletions or changes made in the movieEditor.
Prior to this it was necessary to totally refresh the page..
switching between movie editor and movie index would give unpredicatable results.
these issues have been fixed
* this is a much better solution...
still testing, but likel ready to be merged
* removing comments
* fix the movieEditor -- client side paging in movieEditor
* major code cleanup, and a slightly better implementation
no need to use FullMovieCollection..
just use moviesCollection.fullCollection when in client mode
* display a message when saving is done
perhaps eventually we can have a spinning status indicator on the
save button.. but that is not necessary right away
* some minor adjustments
* remove parseInt for tmdbId
* fix bugs
* remove some alerts
* accidentally changes this on last commit
* use the same FullMovieList everywhere
* add back alert when save is done
* Update inCinemas column to abide by the short date set in settings (#511)
* Set default port to 587 for Email Settings, should help with all the people with gmail
* set SSL to true by default
* Fixed problem with TMDb list when Year is null
* Fuck it, just skip movies with no year. Once they have a year they will be automagically added if sync is enabled.
* Revert using UrlPathEncode on newznab requests
* First steps.
* Not really sure what I am doing here.
* Pretty hacky, but it works :)
* First filter works now.
* Fix all filters.
* Fix some filters.
* PageSize saving now works.
* Fixed items being added when a refresh movie is done.
* Downloaded sort not working.
* Sorting by downloaded status now works.
Extremely hacky, but ¯\_(ツ)_/¯
* Fixed issue where users were stuck when filtering.
* Sorting via that button works now.
* Removed temp thingy.
was searching all missing and monitored only
though the dialog that popped up was informing the user it was
going to search for x movies, where x corresponded to the number
of movies filtered on the page.
I changed this button, so now it will search all the items as they are
filtered on the page.
For example, if you want to search all missing (regardless of
monitor/unmonitor) click the all filter and click the button.
If you want to search only monitored/missing, click the monitored button
and then click the search all button...
this included the old functionality, but allows the user alot more
flexibility...
i also added the all filter, and refactored the code,
so that builds the expression for the LINQ.. since this needed to be
used in two places.. just implement it once and use it in both places..
I tested this out... and stepped through with debugger.. i also did a
quick test of everything else. Im confident that the featureset
implemented and bugs fixed by this commit are OK... Im not 100% that
other parts of radarr dont use the same MissingMovieSearch routines..
but i dont think so...
* availability specification to prevent downloading titles before their
release
* pull inCinamas status out of js handlebars and set it in SkyHook
* minor code improvement
* add incinemas to footer
* typo
* another typo
* release date handling
* still print cinema date out for announced titles
* revert a minor change from before since its unnecessary
* early implementation of minimumAvailability --> when does radarr
consider a movie "available" should be specified by user
default to "Physical release?"
this isn't functional yet, but it has a skeleton + comments. I dont
know how to have the minimumavailability attribute default to something
or to have it actually populate the Movieinfo object
could use some help with that
* adding another comment for another location that might need to be
updated to handle minimumAvailability
* the implementation is now function;
however, i still need to specify default values for minimumAvailability
* missed these changes in the previous commit
* fix rounded corners on new field in editmovie dialog
* add minimum availability specification to the addMovie page
* minor adjustment from last commit
* handle the case where minimumavailability has never yet been set
nullstring.. if its never been set, default to Released (Physical/Web)
represented by integer value 3
* minAvailability specification on NetImport lists
* add support for min availability to the movie editor
* use enum MovieStatusType values directly
makes for cleaner code
* need to fix up the migration forgot in last commit
* cleaning up code, proper case
* erroneous code added in this feature needed to be removed
* update "Wanted" page to take into account minimumAvailability
* implement preDB minimumAvailability as default.. behaves same as
Physical/Web a few comments with TODO for when preDB is implemented
* minor adjustment
* remove some unused code (leave commented for now)
* improve code for minimumavailability and add option for
availabilitydelay (but doesnt do anything yet)
* improve isAvailable method
* clean up and fix helper info on indexer configuration page
* add buttons in Wanted/Missing view
* Filter out existing movies upon import
* Update collection based on what is imported
* Ensure root folders are loaded before collectionview
TODO:
* Ensure grid region exists
* Return information about what wasn't imported
* Filter collection based on duplicates
* Fix double ? in log
* Rename Download Station to TorrentDownloadStation
* Rename Trakt, TMDb, and set Enable sync default to false
* Added omgwtfnzbs Newznab prefix
* Update Media info for Windows/macOS to 0.7.92.1
* Inital TMDb List, needs paging support and user lists, private or public
* Clean up Base
* TMDb grabs upto 5 pages for import, update validation, added minimum vote average
* Added logic for MovieLinksTemplate
* Clean up a bit
* Add Public Lists
* Alter IMDb lists to what was requested: #697
* Update Pending Release
* Tests (these need to be updated further)
* Alter table migration, movieId already exists
* Update HouseKeeping for pending release
* Fix migratiom and pendingrelease housekeeping
* First pass at bulk import.
* First pass at paging implementation for bulk import.
* Another pass at UI for bulk import
WHY WON'T THE ROWS SELECT?!?!
* Paging mostly done. UI needs to show loading still.
* Fix for selection
* fixes.
* Add caching to bulk import
* Tried to fix paging.
* Fix has next
* Fix link error.
* Pageable now works almost perfectly.
Collection now works really nicely when paged. Also movies from different pages can be added no problemo.
* /bulk-import: ProfileCell
Various other QoL changes
* Profile selection works now
Still kinda hacky
* Default monitored to true.
* Add Monitor Cell
Update styling, added path tooltip as well
* Update model when changing tmdbId
Ensure monitor status doesn't change as well
* Added spinner feedback for tmdbid cell.
* /bulk-import: Add page-size selector
* change default label to radarr for rtorrent
* change utorrent default label to radarr
* change hadoken to use radarr label
* change blackhole default to radarr, update hoduken
* Episodes don't work, but it needs to be here
* Fix blackhole xD
* Remove Wombles and kickass
* Clean up TorrentPotato Request Gen
* Opps, we need to use SupportedMovieSearchParameters xD
* Consistancy
* Clean up Newznab Request Gen, add year to search if cannot use IMDB
* Added SpecialCharRegex to remove \ / : &
* Fix notification text on rename
* Fixed profile tooltip for minimum sizes
* Updated link to now point to Radarr's FAQ
* Revert "Updated link to now point to Radarr's FAQ"
This reverts commit 726e0cc870.
Revert 726e0cc
* Fixed: Updated link to now point to Radarr's FAQ
* Bare bones of notifications working.
* Add MovieDownload event handler
To allow Download notificaitons
* Update pushover text to indicate movie
* Initial Notification Support
On Download and On Grab notifications should work.
* Telegram Notification Text
* Update Custom Script For Movies
* Update PP script WiKi page
Also added wiki page to Radarr wiki.
* Optimized logo
Inkscape compatible SVG Honeycomb is slightly different)
File size optimized PNG's (446kB->163kB)
* Use Sonarr honeycomb and proper id's for future use
New png's included
* And final fixes are done
* top buttons don't yet work
* new missing module for movies
* find missing movies method to movie service
* new movie status cell with text
* adapted UI missing collection and layout
* added YouTubeTrailerId to movie model
* db migration for new column
* added videos to append_to_response for tmdb
* increased height of .series-posters-item
* new handlebar helper to build the trailer url
* Remove example warning as it does not apply
* Modify the way apt packages work in .travis.yml
By modifying the way apt packages work (remove the need to directly require sudo), the builds can now run on container-based infrastructure.
* Adding file info tab. Not finished yet.
* Adding more media info options.
* Deleting files now works. Fixes#127
* Fix button for modifying episode files.
* Get Media Info when running DiskScanService.
* Added PassThePopcorn indexe
* Added checkboxes for Gold and Checked torrents thanks @evulhotdog
* Sorted movie releases by golden -> checked -> upload date
* Refactored logic.
* Added flags at the end of torrent name for golden / approved
* Updated PTP GOlden to be the popcorn emoji
* Revert "Updated PTP GOlden to be the popcorn emoji"
This reverts commit c6cf0f5fc5.
* Opps, hopefully build will pass now.
* Move PTP props to new subclass.
* Change Sonarr / NzbDrone auto-updater stuff to Radarr.
This is required in order for the auto-updater to work.
* Change default branch to develop instead of forcing it.
Additionally, a whole series (or movie in this case) can now be
downloaded manually.
Note: It probably won't start downloading missed releases. Only manually
clicking search for is working ATM.
Currently working:
- Searching for new Movies on IMDb (very hacky)
- Adding movie as a series with one season and episode (very hacky)
- Rarbg.to indexer. (somewhat hacky)
TODO:
- Tweak release specifications so that they do not cause exceptions.
- Add Movie struct so that searching for ones is not so hacky.
- rework movies UI.
**Just because you receive an exception in your logs, doesn't mean it's a bug and should be reported here. Often it's something else, such as a permission error. If you are unsure ask on the Discord or Subreddit first.**
Provide a description of the feature request or bug, the more details the better.
Please use https://forums.sonarr.tv/ for support or other questions. (When in doubt, use the forums)
Visit our [Discord server](https://discord.gg/NWYch8M) or [Subreddit](https://reddit.com/r/radarr) for support or longer discussions. Support questions posed on here will be closed immediately.
Provide a description of the feature request or bug here, the more details the better.
Please also include the following if you are reporting a bug. If you do not include it, the issue will probably be closed as we cannot help you. -->
**Radarr Version:**
**Mono Version:**
**Debug Logs:**
# Do not remove anything from your logs and post the full logs! If not everything fits in here use a service like https://pastebin.com to upload them.
<!-- Please use the search bar (make sure to include closed issues as well) and make sure you are not submitting an already submitted issue. -->
about: Support requests will be closed immediately, if you are unsure go to our Discord
or Subreddit first. Exceptions do not mean you found a bug!
---
**Describe the bug**
A clear and concise description of what the bug is.
**To Reproduce**
Steps to reproduce the behavior:
1. Go to '...'
2. Click on '....'
3. Scroll down to '....'
4. See error
**Expected behavior**
A clear and concise description of what you expected to happen.
**Screenshots**
If applicable, add screenshots to help explain your problem.
**Desktop (please complete the following information):**
- OS: [e.g. Windows]
- Mono Version: [e.g. Mono 5.8] (Only needed under Linux and Mac, found under System -> Status)
- Browser and Version [e.g. chrome, safari] (Only needed for UI issues)
- Version [e.g. 22]
**Debug Logs**
Turn on debug logs under Settings -> General and wait for the bug to occur again. **Upload the full log file here (or another site and link it). Issues will be closed, if they do not include this!**
# Number of days of inactivity before an issue becomes stale
daysUntilStale:60
# Number of days of inactivity before a stale issue is closed
daysUntilClose:7
# Issues with these labels will never be considered stale
exemptLabels:
- feature request
- parser
- confirmed
# Label to use when marking an issue as stale
staleLabel:stale
# Comment to post when marking an issue as stale. Set to `false` to disable
markComment:>
This issue has been automatically marked as stale because it has not had recent activity. Please verify that this is still an issue with the latest version of Radarr and report back. Otherwise this issue will be closed.
# Comment to post when closing a stale issue. Set to `false` to disable
# Configuration for support-requests - https://github.com/dessant/support-requests
# Label used to mark issues as support requests
supportLabel:support
# Comment to post on issues marked as support requests. Add a link
# to a support page, or set to `false` to disable
supportComment:>
We use the issue tracker exclusively for bug reports and feature requests.
However, this issue appears to be a support request. Please hop over onto our [Discord](https://discord.gg/ZDmT7qb) or [Subreddit](https://reddit.com/r/radarr)
# Whether to close issues marked as support requests
close:true
# Whether to lock issues marked as support requests
Thank you for your interest in contributing to Sonarr ("We" or "Us").
Thank you for your interest in contributing to Radarr ("We" or "Us").
This contributor agreement ("Agreement") documents the rights granted by contributors to Us. To make this document effective, please complete the form below. This is a legally binding document, so please read it carefully before agreeing to it. The Agreement may cover more than one software project managed by Us.
We're always looking for people to help make Sonarr even better, there are a number of ways to contribute.
We're always looking for people to help make Radarr even better, there are a number of ways to contribute.
## Documentation ##
Setup guides, FAQ, the more information we have on the wiki the better.
@@ -8,14 +8,14 @@ Setup guides, FAQ, the more information we have on the wiki the better.
## Development ##
### Tools required ###
- Visual Studio 2013
- HTML/Javascript editor of choice (Sublime Text/Webstorm/etc)
- Visual Studio 2015
- HTML/Javascript editor of choice (Sublime Text/Webstorm/Atom/etc)
- npm (node package manager)
- git
### Getting started ###
1. Fork Sonarr
1. Fork Radarr
2. Clone (develop branch) *you may need pull in submodules separately if you client doesn't clone them automatically (CurlSharp)*
3. Run `npm install`
4. Run `npm start` - Used to compile the UI components and copy them.
@@ -24,8 +24,8 @@ Setup guides, FAQ, the more information we have on the wiki the better.
5. Compile in Visual Studio
### Contributing Code ###
- If you're adding a new, already requested feature, please comment on [Github Issues](https://github.com/Sonarr/Sonarr/issues "Github Issues") so work is not duplicated (If you want to add something not already on there, please talk to us first)
- Rebase from Sonarr's develop branch, don't merge
- If you're adding a new, already requested feature, please comment on [Github Issues](https://github.com/Radarr/Radarr/issues "Github Issues") so work is not duplicated (If you want to add something not already on there, please talk to us first)
- Rebase from Radarr's develop branch, don't merge
- Make meaningful commits, or squash them
- Feel free to make a pull request before work is complete, this will let us see where its at and make comments/suggest improvements
- Reach out to us on the forums or on IRC if you have any questions
Radarr is an __independent__ fork of [Sonarr](https://github.com/Sonarr/Sonarr) reworked for automatically downloading movies via Usenet and BitTorrent.
The project was inspired by other Usenet/BitTorrent movie downloaders such as CouchPotato.
See the [Roadmap blogpost](https://blog.radarr.video/development/update/2018/11/11/roadmap-update.html) for an overview of planned features.
* [Install Radarr for your desired OS](https://github.com/Radarr/Radarr/wiki/Installation) *or* use [Docker](https://github.com/Radarr/Radarr/wiki/Docker)
* *For Linux users*, run `radarr` and *optionally* have [Radarr start automatically](https://github.com/Radarr/Radarr/wiki/Autostart-on-Linux)
* Connect to the UI through <http://localhost:7878> or <http://your-ip:7878> in your web browser
* See the [Setup Guide](https://github.com/Radarr/Radarr/wiki/Setup-Guide) for further configuration
Radarr is currently undergoing rapid development and pull requests are actively added into the repository.
## Features
### Current Features
* Adding new movies with lots of information, such as trailers, ratings, etc.
* Support for major platforms: Windows, Linux, macOS, Raspberry Pi, etc.
* Can watch for better quality of the movies you have and do an automatic upgrade. *eg. from DVD to Blu-Ray*
* Automatic failed download handling will try another release if one fails
* Manual search so you can pick any release or to see why a release was not downloaded automatically
* Full integration with SABnzbd and NZBGet
* Automatically searching for releases as well as RSS Sync
* Automatically importing downloaded movies
* Recognizing Special Editions, Director's Cut, etc.
* Identifying releases with hardcoded subs
* All indexers supported by Sonarr also supported
* New PassThePopcorn Indexer
* QBittorrent, Deluge, rTorrent, Transmission and uTorrent download client (Other clients are coming)
* New TorrentPotato Indexer
* Torznab Indexer now supports Movies (Works well with [Jackett](https://github.com/Jackett/Jackett))
* Scanning PreDB to know when a new release is available
* Importing movies from various online sources, such as IMDb Watchlists (A complete list can be found [here](https://github.com/Radarr/Radarr/issues/114))
* Full integration with Kodi, Plex (notification, library update)
* And a beautiful UI
* Importing Metadata such as trailers or subtitles
* Adding metadata such as posters and information for Kodi and others to use
* Advanced customization for profiles, such that Radarr will always download the copy you want
### Planned Features
See the [Roadmap blogpost](https://blog.radarr.video/development/update/2018/11/11/roadmap-update.html) for an overview of planned features.
* [Visual Studio Community 2017](https://www.visualstudio.com/vs/community/) or [Rider](http://www.jetbrains.com/rider/)
* [Git](https://git-scm.com/downloads)
* [Node.js](https://nodejs.org/en/download/)
### Setup
* Make sure all the required software mentioned above are installed
* Clone the repository into your development machine ([*info*](https://help.github.com/desktop/guides/contributing/working-with-your-remote-repository-on-github-or-github-enterprise))
* Install the required Node Packages `npm install`
* Start gulp to monitor your dev environment for any changes that need post processing using `npm start` command.
> **Notice**
> Gulp must be running at all times while you are working with Radarr client source files.
### Build
* To build run `sh build.sh`
**Note:** Windows users must have bash available to do this. If you installed git, you should have a git bash utility that works.
### Development
* Open `NzbDrone.sln` in Visual Studio 2017 or run the build.sh script, if Mono is installed. Alternatively you can use Jetbrains Rider, since it works on all Platforms.
* Make sure `NzbDrone.Console` is set as the startup project
* Run `build.sh` before running
## Supporters
This project would not be possible without the support by these amazing folks. [**Become a sponsor or backer**](https://opencollective.com/radarr) to help us out!
Thank you to [<img src="/Logo/jetbrains.svg" alt="JetBrains" width="32"> JetBrains](http://www.jetbrains.com/) for providing us with free licenses to their great tools
Sonarr is a PVR for Usenet and BitTorrent users. It can monitor multiple RSS feeds for new episodes of your favorite shows and will grab, sort and rename them. It can also be configured to automatically upgrade the quality of files already downloaded when a better quality format becomes available.
## Major Features Include: ##
* Support for major platforms: Windows, Linux, OSX, Raspberry Pi, etc.
* Automatically detects new episodes
* Can scan your existing library and download any missing episodes
* Can watch for better quality of the episodes you already have and do an automatic upgrade. *eg. from DVD to Blu-Ray*
* Automatic failed download handling will try another release if one fails
* Manual search so you can pick any release or to see why a release was not downloaded automatically
* Fully configurable episode renaming
* Full integration with SABNzbd and NzbGet
* Full integration with XBMC, Plex (notification, library update, metadata)
* Full support for specials and multi-episode releases
* And a beautiful UI
## Configuring Development Environment: ##
### Requirements ###
- Visual Studio 2015 [Free Community Edition](https://www.visualstudio.com/en-us/products/visual-studio-community-vs.aspx)
- [Git](http://git-scm.com/downloads)
- [NodeJS](http://nodejs.org/download/)
### Setup ###
- Make sure all the required software mentioned above are installed.
- Clone the repository into your development machine. [*info*](https://help.github.com/articles/working-with-repositories)
<xs:enumerationvalue="seedtype"/><!-- TBD, which criteria must be met. was going for 'ratio,seedtime,both' but afaik it's always 'either' -->
<xs:enumerationvalue="minimumratio"/>
<xs:enumerationvalue="minimumseedtime"/>
<xs:enumerationvalue="downloadvolumefactor"/><!-- factor for the download volume, in most cases it should be set to 1, if a torrent is set to freeleech set it to 0, if only 50% is counted set it to 0.5 -->
<xs:enumerationvalue="uploadvolumefactor"/><!-- factor for the upload volume, in most cases it should be set to 1, if a torrent is set to neutral leech (upload is not counted) set it to 0, if it's set to double upload set it to 2 -->
Name: "windowsService"; Description: "Install Windows Service (Starts when the computer starts)"; GroupDescription: "Start automatically"; Flags: exclusive
Name: "startupShortcut"; Description: "Create shortcut in Startup folder (Starts when you log into Windows)"; GroupDescription: "Start automatically"; Flags: exclusive unchecked
// Error message displayed when invalid token is detected.
protectedconstStringInvalidTokenMessage="\n\nIt appears your LOGENTRIES_TOKEN value is invalid or missing.\n\n";
// Error message displayed when invalid account_key or location parameters are detected.
protectedconstStringInvalidHttpPutCredentialsMessage="\n\nIt appears your LOGENTRIES_ACCOUNT_KEY or LOGENTRIES_LOCATION values are invalid or missing.\n\n";
// Error message deisplayed when queue overflow occurs.
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Everyone is permitted to copy and distribute verbatim copies
of this license document, but changing it is not allowed.
Preamble
The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public License is intended to guarantee your freedom to share and change free software--to make sure the software is free for all its users. This General Public License applies to most of the Free Software Foundation's software and to any other program whose authors commit to using it. (Some other Free Software Foundation software is covered by the GNU Library General Public License instead.) You can apply it to your programs, too.
When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for this service if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs; and that you know you can do these things.
To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the software, or if you modify it.
For example, if you distribute copies of such a program, whether gratis or for a fee, you must give the recipients all the rights that you have. You must make sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights.
We protect your rights with two steps: (1) copyright the software, and (2) offer you this license which gives you legal permission to copy, distribute and/or modify the software.
Also, for each author's protection and ours, we want to make certain that everyone understands that there is no warranty for this free software. If the software is modified by someone else and passed on, we want its recipients to know that what they have is not the original, so that any problems introduced by others will not reflect on the original authors' reputations.
Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that redistributors of a free program will individually obtain patent licenses, in effect making the program proprietary. To prevent this, we have made it clear that any patent must be licensed for everyone's free use or not licensed at all.
The precise terms and conditions for copying, distribution and modification follow.
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
0. This License applies to any program or other work which contains a notice placed by the copyright holder saying it may be distributed under the terms of this General Public License. The "Program", below, refers to any such program or work, and a "work based on the Program" means either the Program or any derivative work under copyright law: that is to say, a work containing the Program or a portion of it, either verbatim or with modifications and/or translated into another language. (Hereinafter, translation is included without limitation in the term "modification".) Each licensee is addressed as "you".
Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running the Program is not restricted, and the output from the Program is covered only if its contents constitute a work based on the Program (independent of having been made by running the Program). Whether that is true depends on what the Program does.
1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and give any other recipients of the Program a copy of this License along with the Program.
You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee.
2. You may modify your copy or copies of the Program or any portion of it, thus forming a work based on the Program, and copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions:
a) You must cause the modified files to carry prominent notices stating that you changed the files and the date of any change.
b) You must cause any work that you distribute or publish, that in whole or in part contains or is derived from the Program or any part thereof, to be licensed as a whole at no charge to all third parties under the terms of this License.
c) If the modified program normally reads commands interactively when run, you must cause it, when started running for such interactive use in the most ordinary way, to print or display an announcement including an appropriate copyright notice and a notice that there is no warranty (or else, saying that you provide a warranty) and that users may redistribute the program under these conditions, and telling the user how to view a copy of this License. (Exception: if the Program itself is interactive but does not normally print such an announcement, your work based on the Program is not required to print an announcement.)
These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Program, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Program, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it.
Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Program.
In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the Program) on a volume of a storage or distribution medium does not bring the other work under the scope of this License.
3. You may copy and distribute the Program (or a work based on it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 above provided that you also do one of the following:
a) Accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or,
b) Accompany it with a written offer, valid for at least three years, to give any third party, for a charge no more than your cost of physically performing source distribution, a complete machine-readable copy of the corresponding source code, to be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or,
c) Accompany it with the information you received as to the offer to distribute corresponding source code. (This alternative is allowed only for noncommercial distribution and only if you received the program in object code or executable form with such an offer, in accord with Subsection b above.)
The source code for a work means the preferred form of the work for making modifications to it. For an executable work, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the executable. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable.
If distribution of executable or object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place counts as distribution of the source code, even though third parties are not compelled to copy the source along with the object code.
4. You may not copy, modify, sublicense, or distribute the Program except as expressly provided under this License. Any attempt otherwise to copy, modify, sublicense or distribute the Program is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance.
5. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Program or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Program (or any work based on the Program), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the Program or works based on it.
6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a license from the original licensor to copy, distribute or modify the Program subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the rights granted herein. You are not responsible for enforcing compliance by third parties to this License.
7. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not distribute the Program at all. For example, if a patent license would not permit royalty-free redistribution of the Program by all those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from distribution of the Program.
If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply and the section as a whole is intended to apply in other circumstances.
It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system, which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice.
This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License.
8. If the distribution and/or use of the Program is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder who places the Program under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License.
9. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns.
Each version is given a distinguishing version number. If the Program specifies a version number of this License which applies to it and "any later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of this License, you may choose any version ever published by the Free Software Foundation.
10. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are different, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally.
NO WARRANTY
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
varerrMsg=string.Format("Function calls are not supported by the Where clause expression parser. Please evaluate your function call, '{0}', manually and then use the resulting paremeter value in your Where expression.",methodExp.Method.Name);
Some files were not shown because too many files have changed in this diff
Show More
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.