Compare commits
199 Commits
v0.2.0.112
...
v0.2
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
748e846c21 | ||
|
|
6b52d11577 | ||
|
|
62a0454bf7 | ||
|
|
deddb0ac6c | ||
|
|
923b959b6c | ||
|
|
b088a2220a | ||
|
|
e29e962bd5 | ||
|
|
62173c5258 | ||
|
|
e3bb4d9b59 | ||
|
|
e973701f1c | ||
|
|
62efca5084 | ||
|
|
f638278f4e | ||
|
|
69811b1291 | ||
|
|
802e5ac151 | ||
|
|
09fe1bfc96 | ||
|
|
1dd0df58ca | ||
|
|
747f4c87d3 | ||
|
|
ac2b9516e1 | ||
|
|
1f72e1de74 | ||
|
|
6b743439eb | ||
|
|
b254ee548d | ||
|
|
d8e0fa6ac2 | ||
|
|
bdb4f490b9 | ||
|
|
588771f3ee | ||
|
|
f0ef6c3601 | ||
|
|
01b0365884 | ||
|
|
e715905ea1 | ||
|
|
5d4ec1272d | ||
|
|
2d40914482 | ||
|
|
420e5fd730 | ||
|
|
b95c2e5c8b | ||
|
|
7ddc8d416c | ||
|
|
6160bbf113 | ||
|
|
a2f666445f | ||
|
|
92d6e81236 | ||
|
|
227101d59e | ||
|
|
080d0a9b04 | ||
|
|
1b58ae7d47 | ||
|
|
a5e2e5777c | ||
|
|
ddc2b42923 | ||
|
|
3ac3737de9 | ||
|
|
01ad015b14 | ||
|
|
3d57d5aba7 | ||
|
|
d65fe3a530 | ||
|
|
e100759e71 | ||
|
|
df068e9f0a | ||
|
|
c27f08738a | ||
|
|
61629a527c | ||
|
|
5291f42905 | ||
|
|
0ce5857094 | ||
|
|
443078a7e4 | ||
|
|
dbdda0da13 | ||
|
|
b5e1b83de3 | ||
|
|
8e43f5c4ae | ||
|
|
e6d3954e79 | ||
|
|
61066cb6cf | ||
|
|
2f76f3c6b6 | ||
|
|
7756b03555 | ||
|
|
5faaffc9c6 | ||
|
|
7a43bf3f60 | ||
|
|
84fab25af7 | ||
|
|
52520e356d | ||
|
|
cc44d022b3 | ||
|
|
f411903e90 | ||
|
|
9985554dcb | ||
|
|
f8c009a348 | ||
|
|
da012eb6b5 | ||
|
|
c79578e99f | ||
|
|
961fe70cb8 | ||
|
|
65267af512 | ||
|
|
ac387f208a | ||
|
|
80304d8804 | ||
|
|
cafb1a5a45 | ||
|
|
feef9b1b8d | ||
|
|
4aec27890c | ||
|
|
58ae4417df | ||
|
|
6287bfd9d9 | ||
|
|
5f139c0cb6 | ||
|
|
6cf257ac01 | ||
|
|
5cb5faa8a3 | ||
|
|
a28f2fd21d | ||
|
|
dbf12e1fa4 | ||
|
|
264629cfa5 | ||
|
|
53f49f3b07 | ||
|
|
a26016fc08 | ||
|
|
bd969e0bc3 | ||
|
|
3e96fe4a72 | ||
|
|
19299ad47f | ||
|
|
8902a3ca44 | ||
|
|
4015ff08a6 | ||
|
|
9bc50749ae | ||
|
|
34271605c3 | ||
|
|
8272a160d2 | ||
|
|
e7ad09cf62 | ||
|
|
420cbf6dd0 | ||
|
|
02eb30b8ee | ||
|
|
49b1f2a67d | ||
|
|
7c90667965 | ||
|
|
6d3cff85ae | ||
|
|
b9aba5f424 | ||
|
|
47b481e797 | ||
|
|
3ef224ed1d | ||
|
|
44b1252ecc | ||
|
|
44842a4e6b | ||
|
|
cd520b0341 | ||
|
|
fed4a0aebe | ||
|
|
ff894d5210 | ||
|
|
92b5822a39 | ||
|
|
cbdea30a6e | ||
|
|
969ef5c515 | ||
|
|
5b52115d68 | ||
|
|
899bd086ec | ||
|
|
d02d71c336 | ||
|
|
d4061bd13c | ||
|
|
c83995adc1 | ||
|
|
df18c34878 | ||
|
|
eb077b043e | ||
|
|
42015d5d95 | ||
|
|
09899fcf6c | ||
|
|
8e7b718209 | ||
|
|
d38562664d | ||
|
|
77950645af | ||
|
|
60a9be71bc | ||
|
|
49ee288dae | ||
|
|
443995cd93 | ||
|
|
1456200717 | ||
|
|
28155b09a0 | ||
|
|
9ba1d26f05 | ||
|
|
e0e531c287 | ||
|
|
5d0effa591 | ||
|
|
e62b6d1ddb | ||
|
|
34c838fdd5 | ||
|
|
4283de1e9e | ||
|
|
821653b941 | ||
|
|
2da1d9f105 | ||
|
|
97f111bec8 | ||
|
|
4009852c35 | ||
|
|
a50b74c177 | ||
|
|
9ea739f6cb | ||
|
|
ad3c01e986 | ||
|
|
173b6847e5 | ||
|
|
07cb844ce6 | ||
|
|
0783402470 | ||
|
|
46e728caf1 | ||
|
|
3b896e9011 | ||
|
|
623da76d16 | ||
|
|
95fdf38662 | ||
|
|
6c45c7db1b | ||
|
|
e01900628f | ||
|
|
4f4e6c494d | ||
|
|
0c542eeb13 | ||
|
|
27032a8db3 | ||
|
|
31c357fdde | ||
|
|
ab0bf64273 | ||
|
|
75b486c6c8 | ||
|
|
c566c6e18a | ||
|
|
3767bbec18 | ||
|
|
e4ba48eb61 | ||
|
|
057086a630 | ||
|
|
2b373f2006 | ||
|
|
df6f32f6c3 | ||
|
|
617c7bae83 | ||
|
|
64e8fde0e1 | ||
|
|
0903269b7c | ||
|
|
b2d6ef589f | ||
|
|
354105cf08 | ||
|
|
bf7689688d | ||
|
|
b4f456d5f0 | ||
|
|
1059e145c3 | ||
|
|
5751c3f5f5 | ||
|
|
a458cdc0a5 | ||
|
|
ed631142c4 | ||
|
|
091bcc2333 | ||
|
|
e15225f4fc | ||
|
|
79e570e571 | ||
|
|
d99e520baa | ||
|
|
3d1cbd1613 | ||
|
|
2cfc77abc3 | ||
|
|
b7012192b3 | ||
|
|
a24ea4feee | ||
|
|
43d9aa8627 | ||
|
|
ad94a4a603 | ||
|
|
efb4127c35 | ||
|
|
253546ded0 | ||
|
|
587b49aaba | ||
|
|
b865103871 | ||
|
|
b7e35fada8 | ||
|
|
409be45a19 | ||
|
|
b553d8aef6 | ||
|
|
c4ca2f12bb | ||
|
|
77f146b262 | ||
|
|
d046a73f78 | ||
|
|
728a50c68f | ||
|
|
5470378af4 | ||
|
|
304b3ef560 | ||
|
|
5e35b43e48 | ||
|
|
52ce836d5c | ||
|
|
fe7bf8ec9e | ||
|
|
0db74fa583 |
@@ -1,5 +0,0 @@
|
||||
FROM mono:4.8
|
||||
|
||||
RUN apt-get update && apt-get install -y git ssh tar gzip ca-certificates
|
||||
RUN curl -sL https://deb.nodesource.com/setup_6.x | bash -E -
|
||||
RUN apt-get install -y nodejs npm
|
||||
@@ -1,40 +0,0 @@
|
||||
version: 2
|
||||
|
||||
jobs:
|
||||
build:
|
||||
docker:
|
||||
- image: gallileo/radarr-cci-primary:4.8
|
||||
steps:
|
||||
- checkout
|
||||
- run: git submodule update --init --recursive
|
||||
- run:
|
||||
name: Clean Build
|
||||
command: ./build.sh Clean
|
||||
- run:
|
||||
name: Restore Nuget
|
||||
command: ./build.sh NugetMono
|
||||
- run:
|
||||
name: Build
|
||||
command: ./build.sh Build
|
||||
- run:
|
||||
name: Gulp
|
||||
command: ./build.sh Gulp
|
||||
- run:
|
||||
name: Package
|
||||
command: ./build.sh Package
|
||||
- run:
|
||||
name: Preparing Tests
|
||||
command: mkdir _tests/reports
|
||||
- run:
|
||||
name: Testing
|
||||
command: ./test.sh Linux Unit
|
||||
- store_test_results:
|
||||
path: _tests/reports/
|
||||
- store_artifacts:
|
||||
path: _output
|
||||
- store_artifacts:
|
||||
path: _output_mono
|
||||
- store_artifacts:
|
||||
path: _output_osx
|
||||
- store_artifacts:
|
||||
path: _output_osx_app
|
||||
@@ -1,69 +0,0 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
||||
<xsl:output method="xml" indent="yes"/>
|
||||
|
||||
<xsl:template match="/test-run">
|
||||
<testsuites tests="{@testcasecount}" failures="{@failed}" disabled="{@skipped}" time="{@duration}">
|
||||
<xsl:apply-templates/>
|
||||
</testsuites>
|
||||
</xsl:template>
|
||||
|
||||
<xsl:template match="test-suite">
|
||||
<xsl:if test="test-case">
|
||||
<testsuite tests="{@testcasecount}" time="{@duration}" errors="{@testcasecount - @passed - @skipped - @failed}" failures="{@failed}" skipped="{@skipped}" timestamp="{@start-time}">
|
||||
<xsl:attribute name="name">
|
||||
<xsl:for-each select="ancestor-or-self::test-suite/@name">
|
||||
<xsl:value-of select="concat(., '.')"/>
|
||||
</xsl:for-each>
|
||||
</xsl:attribute>
|
||||
<xsl:apply-templates select="test-case"/>
|
||||
</testsuite>
|
||||
<xsl:apply-templates select="test-suite"/>
|
||||
</xsl:if>
|
||||
<xsl:if test="not(test-case)">
|
||||
<xsl:apply-templates/>
|
||||
</xsl:if>
|
||||
</xsl:template>
|
||||
|
||||
<xsl:template match="test-case">
|
||||
<testcase name="{@name}" assertions="{@asserts}" time="{@duration}" status="{@result}" classname="{@classname}">
|
||||
<xsl:if test="@runstate = 'Skipped' or @runstate = 'Ignored'">
|
||||
<skipped/>
|
||||
</xsl:if>
|
||||
|
||||
<xsl:apply-templates/>
|
||||
</testcase>
|
||||
</xsl:template>
|
||||
|
||||
<xsl:template match="command-line"/>
|
||||
<xsl:template match="settings"/>
|
||||
|
||||
<xsl:template match="output">
|
||||
<system-out>
|
||||
<xsl:value-of select="."/>
|
||||
</system-out>
|
||||
</xsl:template>
|
||||
|
||||
<xsl:template match="stack-trace">
|
||||
</xsl:template>
|
||||
|
||||
<xsl:template match="test-case/failure">
|
||||
<failure message="{./message}">
|
||||
<xsl:value-of select="./stack-trace"/>
|
||||
</failure>
|
||||
</xsl:template>
|
||||
|
||||
<xsl:template match="test-suite/failure"/>
|
||||
|
||||
<xsl:template match="test-case/reason">
|
||||
<skipped message="{./message}"/>
|
||||
</xsl:template>
|
||||
|
||||
<xsl:template match="test-case/assertions">
|
||||
</xsl:template>
|
||||
|
||||
<xsl:template match="test-suite/reason"/>
|
||||
|
||||
<xsl:template match="properties"/>
|
||||
</xsl:stylesheet>
|
||||
|
||||
16
.gitattributes
vendored
@@ -1,13 +1,17 @@
|
||||
# Auto detect text files and perform LF normalization
|
||||
*text eol=lf
|
||||
* text=auto
|
||||
|
||||
# Explicitly set bash scripts to have unix endings
|
||||
*.sh text eol=lf
|
||||
macOS/Radarr text eol=lf
|
||||
|
||||
# Custom for Visual Studio
|
||||
*.cs diff=csharp
|
||||
*.sln merge=union
|
||||
*.csproj merge=union
|
||||
*.vbproj merge=union
|
||||
*.fsproj merge=union
|
||||
*.dbproj merge=union
|
||||
#*.sln merge=union
|
||||
#*.csproj merge=union
|
||||
#*.vbproj merge=union
|
||||
#*.fsproj merge=union
|
||||
#*.dbproj merge=union
|
||||
|
||||
# Standard to msysgit
|
||||
*.doc diff=astextplain
|
||||
|
||||
305
.gitchangelog.rc
@@ -1,305 +0,0 @@
|
||||
# -*- coding: utf-8; mode: python -*-
|
||||
##
|
||||
## Format
|
||||
##
|
||||
## ACTION: [AUDIENCE:] COMMIT_MSG [!TAG ...]
|
||||
##
|
||||
## Description
|
||||
##
|
||||
## ACTION is one of 'chg', 'fix', 'new'
|
||||
##
|
||||
## Is WHAT the change is about.
|
||||
##
|
||||
## 'chg' is for refactor, small improvement, cosmetic changes...
|
||||
## 'fix' is for bug fixes
|
||||
## 'new' is for new features, big improvement
|
||||
##
|
||||
## AUDIENCE is optional and one of 'dev', 'usr', 'pkg', 'test', 'doc'
|
||||
##
|
||||
## Is WHO is concerned by the change.
|
||||
##
|
||||
## 'dev' is for developpers (API changes, refactors...)
|
||||
## 'usr' is for final users (UI changes)
|
||||
## 'pkg' is for packagers (packaging changes)
|
||||
## 'test' is for testers (test only related changes)
|
||||
## 'doc' is for doc guys (doc only changes)
|
||||
##
|
||||
## COMMIT_MSG is ... well ... the commit message itself.
|
||||
##
|
||||
## TAGs are additionnal adjective as 'refactor' 'minor' 'cosmetic'
|
||||
##
|
||||
## They are preceded with a '!' or a '@' (prefer the former, as the
|
||||
## latter is wrongly interpreted in github.) Commonly used tags are:
|
||||
##
|
||||
## 'refactor' is obviously for refactoring code only
|
||||
## 'minor' is for a very meaningless change (a typo, adding a comment)
|
||||
## 'cosmetic' is for cosmetic driven change (re-indentation, 80-col...)
|
||||
## 'wip' is for partial functionality but complete subfunctionality.
|
||||
##
|
||||
## Example:
|
||||
##
|
||||
## new: usr: support of bazaar implemented
|
||||
## chg: re-indentend some lines !cosmetic
|
||||
## new: dev: updated code to be compatible with last version of killer lib.
|
||||
## fix: pkg: updated year of licence coverage.
|
||||
## new: test: added a bunch of test around user usability of feature X.
|
||||
## fix: typo in spelling my name in comment. !minor
|
||||
##
|
||||
## Please note that multi-line commit message are supported, and only the
|
||||
## first line will be considered as the "summary" of the commit message. So
|
||||
## tags, and other rules only applies to the summary. The body of the commit
|
||||
## message will be displayed in the changelog without reformatting.
|
||||
|
||||
|
||||
##
|
||||
## ``ignore_regexps`` is a line of regexps
|
||||
##
|
||||
## Any commit having its full commit message matching any regexp listed here
|
||||
## will be ignored and won't be reported in the changelog.
|
||||
##
|
||||
ignore_regexps = [
|
||||
r'@minor', r'!minor',
|
||||
r'@cosmetic', r'!cosmetic',
|
||||
r'@refactor', r'!refactor',
|
||||
r'@wip', r'!wip',
|
||||
r'^([cC]hg|[fF]ix|[nN]ew)\s*:\s*[p|P]kg:',
|
||||
r'^([cC]hg|[fF]ix|[nN]ew)\s*:\s*[d|D]ev:',
|
||||
r'^(.{3,3}\s*:)?\s*[fF]irst commit.?\s*$',
|
||||
r'^$', ## ignore commits with empty messages
|
||||
]
|
||||
|
||||
|
||||
## ``section_regexps`` is a list of 2-tuples associating a string label and a
|
||||
## list of regexp
|
||||
##
|
||||
## Commit messages will be classified in sections thanks to this. Section
|
||||
## titles are the label, and a commit is classified under this section if any
|
||||
## of the regexps associated is matching.
|
||||
##
|
||||
## Please note that ``section_regexps`` will only classify commits and won't
|
||||
## make any changes to the contents. So you'll probably want to go check
|
||||
## ``subject_process`` (or ``body_process``) to do some changes to the subject,
|
||||
## whenever you are tweaking this variable.
|
||||
##
|
||||
section_regexps = [
|
||||
('**New features**', [
|
||||
r'^[aA]dded?\s*:?\s*((dev|use?r|pkg|test|doc)\s*:\s*)?([^\n]*)$',
|
||||
r'^[uU]pdated?\s*:?\s*((dev|use?r|pkg|test|doc)\s*:\s*)?([^\n]*)$',
|
||||
r'^[cC]hanged?\s*:?\s*((dev|use?r|pkg|test|doc)\s*:\s*)?([^\n]*)$',
|
||||
r'^[nN]ew?\s*:?\s*((dev|use?r|pkg|test|doc)\s*:\s*)?([^\n]*)$',
|
||||
]),
|
||||
('**Fixes**', [
|
||||
r'^(?![mM]erge\s*)'
|
||||
]
|
||||
),
|
||||
|
||||
]
|
||||
|
||||
|
||||
## ``body_process`` is a callable
|
||||
##
|
||||
## This callable will be given the original body and result will
|
||||
## be used in the changelog.
|
||||
##
|
||||
## Available constructs are:
|
||||
##
|
||||
## - any python callable that take one txt argument and return txt argument.
|
||||
##
|
||||
## - ReSub(pattern, replacement): will apply regexp substitution.
|
||||
##
|
||||
## - Indent(chars=" "): will indent the text with the prefix
|
||||
## Please remember that template engines gets also to modify the text and
|
||||
## will usually indent themselves the text if needed.
|
||||
##
|
||||
## - Wrap(regexp=r"\n\n"): re-wrap text in separate paragraph to fill 80-Columns
|
||||
##
|
||||
## - noop: do nothing
|
||||
##
|
||||
## - ucfirst: ensure the first letter is uppercase.
|
||||
## (usually used in the ``subject_process`` pipeline)
|
||||
##
|
||||
## - final_dot: ensure text finishes with a dot
|
||||
## (usually used in the ``subject_process`` pipeline)
|
||||
##
|
||||
## - strip: remove any spaces before or after the content of the string
|
||||
##
|
||||
## - SetIfEmpty(msg="No commit message."): will set the text to
|
||||
## whatever given ``msg`` if the current text is empty.
|
||||
##
|
||||
## Additionally, you can `pipe` the provided filters, for instance:
|
||||
#body_process = Wrap(regexp=r'\n(?=\w+\s*:)') | Indent(chars=" ")
|
||||
#body_process = Wrap(regexp=r'\n(?=\w+\s*:)')
|
||||
#body_process = noop
|
||||
body_process = ReSub(r'((^|\n)[A-Z]\w+(-\w+)*: .*(\n\s+.*)*)+$', r'') | strip
|
||||
|
||||
|
||||
## ``subject_process`` is a callable
|
||||
##
|
||||
## This callable will be given the original subject and result will
|
||||
## be used in the changelog.
|
||||
## subject_process = (strip |
|
||||
## ReSub(r'^([aA]dd(ed?)?|[nN]ew)(\s?:?\s)(.*)$', r' \4') |
|
||||
## ReSub(r'^([cC]hang(ed?)?)(\s?:?\s)(.*)$', r' \4') |
|
||||
## ReSub(r'^([fF]ix(ed?)?)(\s?:?\s)(.*)$', r' \4') |
|
||||
## ReSub(r'^([uU]pdat(ed?)?)(\s?:?\s)(.*)$', r' \4') |
|
||||
## ReSub(r'#(\d{3,4})', r'[#\1](https://github.com/Radarr/Radarr/issues/\1)') |
|
||||
## SetIfEmpty("No commit message.") | ucfirst | final_dot)
|
||||
|
||||
## Available constructs are those listed in ``body_process`` doc.
|
||||
subject_process = (strip |
|
||||
ReSub(r'^([aA]dd(ed?)?|[nN]ew)(\s?:?\s)(.*)$', r' \4') |
|
||||
ReSub(r'^([cC]hang(ed?)?)(\s?:?\s)(.*)$', r' \4') |
|
||||
ReSub(r'^([fF]ix(ed?)?)(\s?:?\s)(.*)$', r' \4') |
|
||||
ReSub(r'^([uU]pdat(ed?)?)(\s?:?\s)(.*)$', r' \4') |
|
||||
ReSub(r'#(\d{3,4})', r'[#\1](https://github.com/Radarr/Radarr/issues/\1)') |
|
||||
SetIfEmpty("No commit message.") | ucfirst | final_dot)
|
||||
|
||||
|
||||
## ``tag_filter_regexp`` is a regexp
|
||||
##
|
||||
## Tags that will be used for the changelog must match this regexp.
|
||||
##
|
||||
tag_filter_regexp = r'^v[0]+\.[2-9]+\.[0-9]+\.[0-9]{3,4}$'
|
||||
|
||||
|
||||
## ``unreleased_version_label`` is a string or a callable that outputs a string
|
||||
##
|
||||
## This label will be used as the changelog Title of the last set of changes
|
||||
## between last valid tag and HEAD if any.
|
||||
unreleased_version_label = "(unreleased)"
|
||||
|
||||
|
||||
## ``output_engine`` is a callable
|
||||
##
|
||||
## This will change the output format of the generated changelog file
|
||||
##
|
||||
## Available choices are:
|
||||
##
|
||||
## - rest_py
|
||||
##
|
||||
## Legacy pure python engine, outputs ReSTructured text.
|
||||
## This is the default.
|
||||
##
|
||||
## - mustache(<template_name>)
|
||||
##
|
||||
## Template name could be any of the available templates in
|
||||
## ``templates/mustache/*.tpl``.
|
||||
## Requires python package ``pystache``.
|
||||
## Examples:
|
||||
## - mustache("markdown")
|
||||
## - mustache("restructuredtext")
|
||||
##
|
||||
## - makotemplate(<template_name>)
|
||||
##
|
||||
## Template name could be any of the available templates in
|
||||
## ``templates/mako/*.tpl``.
|
||||
## Requires python package ``mako``.
|
||||
## Examples:
|
||||
## - makotemplate("restructuredtext")
|
||||
##
|
||||
#output_engine = rest_py
|
||||
#output_engine = mustache("restructuredtext")
|
||||
output_engine = mustache("changelog.tpl")
|
||||
#output_engine = makotemplate("restructuredtext")
|
||||
|
||||
|
||||
## ``include_merge`` is a boolean
|
||||
##
|
||||
## This option tells git-log whether to include merge commits in the log.
|
||||
## The default is to include them.
|
||||
include_merge = False
|
||||
|
||||
|
||||
## ``log_encoding`` is a string identifier
|
||||
##
|
||||
## This option tells gitchangelog what encoding is outputed by ``git log``.
|
||||
## The default is to be clever about it: it checks ``git config`` for
|
||||
## ``i18n.logOutputEncoding``, and if not found will default to git's own
|
||||
## default: ``utf-8``.
|
||||
#log_encoding = 'utf-8'
|
||||
|
||||
|
||||
## ``publish`` is a callable
|
||||
##
|
||||
## Sets what ``gitchangelog`` should do with the output generated by
|
||||
## the output engine. ``publish`` is a callable taking one argument
|
||||
## that is an interator on lines from the output engine.
|
||||
##
|
||||
## Some helper callable are provided:
|
||||
##
|
||||
## Available choices are:
|
||||
##
|
||||
## - stdout
|
||||
##
|
||||
## Outputs directly to standard output
|
||||
## (This is the default)
|
||||
##
|
||||
## - FileInsertAtFirstRegexMatch(file, pattern, idx=lamda m: m.start())
|
||||
##
|
||||
## Creates a callable that will parse given file for the given
|
||||
## regex pattern and will insert the output in the file.
|
||||
## ``idx`` is a callable that receive the matching object and
|
||||
## must return a integer index point where to insert the
|
||||
## the output in the file. Default is to return the position of
|
||||
## the start of the matched string.
|
||||
##
|
||||
## - FileRegexSubst(file, pattern, replace, flags)
|
||||
##
|
||||
## Apply a replace inplace in the given file. Your regex pattern must
|
||||
## take care of everything and might be more complex. Check the README
|
||||
## for a complete copy-pastable example.
|
||||
##
|
||||
# publish = FileInsertIntoFirstRegexMatch(
|
||||
# "CHANGELOG.rst",
|
||||
# r'/(?P<rev>[0-9]+\.[0-9]+(\.[0-9]+)?)\s+\([0-9]+-[0-9]{2}-[0-9]{2}\)\n--+\n/',
|
||||
# idx=lambda m: m.start(1)
|
||||
# )
|
||||
#publish = stdout
|
||||
|
||||
def write_to_file(content):
|
||||
with open("CHANGELOG.md", "w+") as f:
|
||||
for chunk in content:
|
||||
f.write(chunk)
|
||||
|
||||
publish = write_to_file
|
||||
|
||||
|
||||
## ``revs`` is a list of callable or a list of string
|
||||
##
|
||||
## callable will be called to resolve as strings and allow dynamical
|
||||
## computation of these. The result will be used as revisions for
|
||||
## gitchangelog (as if directly stated on the command line). This allows
|
||||
## to filter exaclty which commits will be read by gitchangelog.
|
||||
##
|
||||
## To get a full documentation on the format of these strings, please
|
||||
## refer to the ``git rev-list`` arguments. There are many examples.
|
||||
##
|
||||
## Using callables is especially useful, for instance, if you
|
||||
## are using gitchangelog to generate incrementally your changelog.
|
||||
##
|
||||
## Some helpers are provided, you can use them::
|
||||
##
|
||||
## - FileFirstRegexMatch(file, pattern): will return a callable that will
|
||||
## return the first string match for the given pattern in the given file.
|
||||
## If you use named sub-patterns in your regex pattern, it'll output only
|
||||
## the string matching the regex pattern named "rev".
|
||||
##
|
||||
## - Caret(rev): will return the rev prefixed by a "^", which is a
|
||||
## way to remove the given revision and all its ancestor.
|
||||
##
|
||||
## Please note that if you provide a rev-list on the command line, it'll
|
||||
## replace this value (which will then be ignored).
|
||||
##
|
||||
## If empty, then ``gitchangelog`` will act as it had to generate a full
|
||||
## changelog.
|
||||
##
|
||||
## The default is to use all commits to make the changelog.
|
||||
#revs = ["^1.0.3", ]
|
||||
#revs = [
|
||||
# Caret(
|
||||
# FileFirstRegexMatch(
|
||||
# "CHANGELOG.rst",
|
||||
# r"(?P<rev>[0-9]+\.[0-9]+(\.[0-9]+)?)\s+\([0-9]+-[0-9]{2}-[0-9]{2}\)\n--+\n")),
|
||||
# "HEAD"
|
||||
#]
|
||||
revs = ["v0.2.0.134..."]
|
||||
@@ -1,311 +0,0 @@
|
||||
# -*- coding: utf-8; mode: python -*-
|
||||
##
|
||||
## Format
|
||||
##
|
||||
## ACTION: [AUDIENCE:] COMMIT_MSG [!TAG ...]
|
||||
##
|
||||
## Description
|
||||
##
|
||||
## ACTION is one of 'chg', 'fix', 'new'
|
||||
##
|
||||
## Is WHAT the change is about.
|
||||
##
|
||||
## 'chg' is for refactor, small improvement, cosmetic changes...
|
||||
## 'fix' is for bug fixes
|
||||
## 'new' is for new features, big improvement
|
||||
##
|
||||
## AUDIENCE is optional and one of 'dev', 'usr', 'pkg', 'test', 'doc'
|
||||
##
|
||||
## Is WHO is concerned by the change.
|
||||
##
|
||||
## 'dev' is for developpers (API changes, refactors...)
|
||||
## 'usr' is for final users (UI changes)
|
||||
## 'pkg' is for packagers (packaging changes)
|
||||
## 'test' is for testers (test only related changes)
|
||||
## 'doc' is for doc guys (doc only changes)
|
||||
##
|
||||
## COMMIT_MSG is ... well ... the commit message itself.
|
||||
##
|
||||
## TAGs are additionnal adjective as 'refactor' 'minor' 'cosmetic'
|
||||
##
|
||||
## They are preceded with a '!' or a '@' (prefer the former, as the
|
||||
## latter is wrongly interpreted in github.) Commonly used tags are:
|
||||
##
|
||||
## 'refactor' is obviously for refactoring code only
|
||||
## 'minor' is for a very meaningless change (a typo, adding a comment)
|
||||
## 'cosmetic' is for cosmetic driven change (re-indentation, 80-col...)
|
||||
## 'wip' is for partial functionality but complete subfunctionality.
|
||||
##
|
||||
## Example:
|
||||
##
|
||||
## new: usr: support of bazaar implemented
|
||||
## chg: re-indentend some lines !cosmetic
|
||||
## new: dev: updated code to be compatible with last version of killer lib.
|
||||
## fix: pkg: updated year of licence coverage.
|
||||
## new: test: added a bunch of test around user usability of feature X.
|
||||
## fix: typo in spelling my name in comment. !minor
|
||||
##
|
||||
## Please note that multi-line commit message are supported, and only the
|
||||
## first line will be considered as the "summary" of the commit message. So
|
||||
## tags, and other rules only applies to the summary. The body of the commit
|
||||
## message will be displayed in the changelog without reformatting.
|
||||
|
||||
|
||||
##
|
||||
## ``ignore_regexps`` is a line of regexps
|
||||
##
|
||||
## Any commit having its full commit message matching any regexp listed here
|
||||
## will be ignored and won't be reported in the changelog.
|
||||
##
|
||||
ignore_regexps = [
|
||||
r'@minor', r'!minor',
|
||||
r'@cosmetic', r'!cosmetic',
|
||||
r'@refactor', r'!refactor',
|
||||
r'@wip', r'!wip',
|
||||
r'^([cC]hg|[fF]ix|[nN]ew)\s*:\s*[p|P]kg:',
|
||||
r'^([cC]hg|[fF]ix|[nN]ew)\s*:\s*[d|D]ev:',
|
||||
r'^(.{3,3}\s*:)?\s*[fF]irst commit.?\s*$',
|
||||
r'^$', ## ignore commits with empty messages
|
||||
]
|
||||
|
||||
|
||||
## ``section_regexps`` is a list of 2-tuples associating a string label and a
|
||||
## list of regexp
|
||||
##
|
||||
## Commit messages will be classified in sections thanks to this. Section
|
||||
## titles are the label, and a commit is classified under this section if any
|
||||
## of the regexps associated is matching.
|
||||
##
|
||||
## Please note that ``section_regexps`` will only classify commits and won't
|
||||
## make any changes to the contents. So you'll probably want to go check
|
||||
## ``subject_process`` (or ``body_process``) to do some changes to the subject,
|
||||
## whenever you are tweaking this variable.
|
||||
##
|
||||
section_regexps = [
|
||||
('**New features**', [
|
||||
r'^[aA]dded?\s*:?\s*((dev|use?r|pkg|test|doc)\s*:\s*)?([^\n]*)$',
|
||||
r'^[uU]pdated?\s*:?\s*((dev|use?r|pkg|test|doc)\s*:\s*)?([^\n]*)$',
|
||||
r'^[cC]hanged?\s*:?\s*((dev|use?r|pkg|test|doc)\s*:\s*)?([^\n]*)$',
|
||||
r'^[nN]ew?\s*:?\s*((dev|use?r|pkg|test|doc)\s*:\s*)?([^\n]*)$',
|
||||
]),
|
||||
('**Fixes**', [
|
||||
r'^(?![mM]erge\s*)'
|
||||
]
|
||||
),
|
||||
|
||||
]
|
||||
|
||||
|
||||
## ``body_process`` is a callable
|
||||
##
|
||||
## This callable will be given the original body and result will
|
||||
## be used in the changelog.
|
||||
##
|
||||
## Available constructs are:
|
||||
##
|
||||
## - any python callable that take one txt argument and return txt argument.
|
||||
##
|
||||
## - ReSub(pattern, replacement): will apply regexp substitution.
|
||||
##
|
||||
## - Indent(chars=" "): will indent the text with the prefix
|
||||
## Please remember that template engines gets also to modify the text and
|
||||
## will usually indent themselves the text if needed.
|
||||
##
|
||||
## - Wrap(regexp=r"\n\n"): re-wrap text in separate paragraph to fill 80-Columns
|
||||
##
|
||||
## - noop: do nothing
|
||||
##
|
||||
## - ucfirst: ensure the first letter is uppercase.
|
||||
## (usually used in the ``subject_process`` pipeline)
|
||||
##
|
||||
## - final_dot: ensure text finishes with a dot
|
||||
## (usually used in the ``subject_process`` pipeline)
|
||||
##
|
||||
## - strip: remove any spaces before or after the content of the string
|
||||
##
|
||||
## - SetIfEmpty(msg="No commit message."): will set the text to
|
||||
## whatever given ``msg`` if the current text is empty.
|
||||
##
|
||||
## Additionally, you can `pipe` the provided filters, for instance:
|
||||
#body_process = Wrap(regexp=r'\n(?=\w+\s*:)') | Indent(chars=" ")
|
||||
#body_process = Wrap(regexp=r'\n(?=\w+\s*:)')
|
||||
#body_process = noop
|
||||
body_process = ReSub(r'((^|\n)[A-Z]\w+(-\w+)*: .*(\n\s+.*)*)+$', r'') | strip
|
||||
|
||||
|
||||
## ``subject_process`` is a callable
|
||||
##
|
||||
## This callable will be given the original subject and result will
|
||||
## be used in the changelog.
|
||||
## subject_process = (strip |
|
||||
## ReSub(r'^([aA]dd(ed?)?|[nN]ew)(\s?:?\s)(.*)$', r' \4') |
|
||||
## ReSub(r'^([cC]hang(ed?)?)(\s?:?\s)(.*)$', r' \4') |
|
||||
## ReSub(r'^([fF]ix(ed?)?)(\s?:?\s)(.*)$', r' \4') |
|
||||
## ReSub(r'^([uU]pdat(ed?)?)(\s?:?\s)(.*)$', r' \4') |
|
||||
## ReSub(r'#(\d{3,4})', r'[#\1](https://github.com/Radarr/Radarr/issues/\1)') |
|
||||
## SetIfEmpty("No commit message.") | ucfirst | final_dot)
|
||||
|
||||
## Available constructs are those listed in ``body_process`` doc.
|
||||
subject_process = (strip |
|
||||
ReSub(r'^([aA]dd(ed?)?|[nN]ew)(\s?:?\s)(.*)$', r'\4') |
|
||||
ReSub(r'^([cC]hang(ed?)?)(\s?:?\s)(.*)$', r'\4') |
|
||||
ReSub(r'^([fF]ix(ed?)?)(\s?:?\s)(.*)$', r'\4') |
|
||||
ReSub(r'^([uU]pdat(ed?)?)(\s?:?\s)(.*)$', r'\4') |
|
||||
ReSub(r'#(\d{3,4})', r'<a href="https://github.com/Radarr/Radarr/issues/\1">\1</a>') |
|
||||
SetIfEmpty("No commit message.") | ucfirst | final_dot)
|
||||
|
||||
|
||||
## ``tag_filter_regexp`` is a regexp
|
||||
##
|
||||
## Tags that will be used for the changelog must match this regexp.
|
||||
##
|
||||
tag_filter_regexp = r'^v[0]+\.[2-9]+\.[0-9]+\.[0-9]+$'
|
||||
|
||||
|
||||
## ``unreleased_version_label`` is a string or a callable that outputs a string
|
||||
##
|
||||
## This label will be used as the changelog Title of the last set of changes
|
||||
## between last valid tag and HEAD if any.
|
||||
unreleased_version_label = "(unreleased)"
|
||||
|
||||
|
||||
## ``output_engine`` is a callable
|
||||
##
|
||||
## This will change the output format of the generated changelog file
|
||||
##
|
||||
## Available choices are:
|
||||
##
|
||||
## - rest_py
|
||||
##
|
||||
## Legacy pure python engine, outputs ReSTructured text.
|
||||
## This is the default.
|
||||
##
|
||||
## - mustache(<template_name>)
|
||||
##
|
||||
## Template name could be any of the available templates in
|
||||
## ``templates/mustache/*.tpl``.
|
||||
## Requires python package ``pystache``.
|
||||
## Examples:
|
||||
## - mustache("markdown")
|
||||
## - mustache("restructuredtext")
|
||||
##
|
||||
## - makotemplate(<template_name>)
|
||||
##
|
||||
## Template name could be any of the available templates in
|
||||
## ``templates/mako/*.tpl``.
|
||||
## Requires python package ``mako``.
|
||||
## Examples:
|
||||
## - makotemplate("restructuredtext")
|
||||
##
|
||||
#output_engine = rest_py
|
||||
#output_engine = mustache("restructuredtext")
|
||||
output_engine = mustache("changelog_release.tpl")
|
||||
#output_engine = makotemplate("restructuredtext")
|
||||
|
||||
|
||||
## ``include_merge`` is a boolean
|
||||
##
|
||||
## This option tells git-log whether to include merge commits in the log.
|
||||
## The default is to include them.
|
||||
include_merge = False
|
||||
|
||||
|
||||
## ``log_encoding`` is a string identifier
|
||||
##
|
||||
## This option tells gitchangelog what encoding is outputed by ``git log``.
|
||||
## The default is to be clever about it: it checks ``git config`` for
|
||||
## ``i18n.logOutputEncoding``, and if not found will default to git's own
|
||||
## default: ``utf-8``.
|
||||
#log_encoding = 'utf-8'
|
||||
|
||||
|
||||
## ``publish`` is a callable
|
||||
##
|
||||
## Sets what ``gitchangelog`` should do with the output generated by
|
||||
## the output engine. ``publish`` is a callable taking one argument
|
||||
## that is an interator on lines from the output engine.
|
||||
##
|
||||
## Some helper callable are provided:
|
||||
##
|
||||
## Available choices are:
|
||||
##
|
||||
## - stdout
|
||||
##
|
||||
## Outputs directly to standard output
|
||||
## (This is the default)
|
||||
##
|
||||
## - FileInsertAtFirstRegexMatch(file, pattern, idx=lamda m: m.start())
|
||||
##
|
||||
## Creates a callable that will parse given file for the given
|
||||
## regex pattern and will insert the output in the file.
|
||||
## ``idx`` is a callable that receive the matching object and
|
||||
## must return a integer index point where to insert the
|
||||
## the output in the file. Default is to return the position of
|
||||
## the start of the matched string.
|
||||
##
|
||||
## - FileRegexSubst(file, pattern, replace, flags)
|
||||
##
|
||||
## Apply a replace inplace in the given file. Your regex pattern must
|
||||
## take care of everything and might be more complex. Check the README
|
||||
## for a complete copy-pastable example.
|
||||
##
|
||||
# publish = FileInsertIntoFirstRegexMatch(
|
||||
# "CHANGELOG.rst",
|
||||
# r'/(?P<rev>[0-9]+\.[0-9]+(\.[0-9]+)?)\s+\([0-9]+-[0-9]{2}-[0-9]{2}\)\n--+\n/',
|
||||
# idx=lambda m: m.start(1)
|
||||
# )
|
||||
publish = stdout
|
||||
|
||||
def write_to_file(content):
|
||||
with open("CHANGELOG.md", "w+") as f:
|
||||
for chunk in content:
|
||||
f.write(chunk)
|
||||
|
||||
#publish = write_to_file
|
||||
|
||||
|
||||
## ``revs`` is a list of callable or a list of string
|
||||
##
|
||||
## callable will be called to resolve as strings and allow dynamical
|
||||
## computation of these. The result will be used as revisions for
|
||||
## gitchangelog (as if directly stated on the command line). This allows
|
||||
## to filter exaclty which commits will be read by gitchangelog.
|
||||
##
|
||||
## To get a full documentation on the format of these strings, please
|
||||
## refer to the ``git rev-list`` arguments. There are many examples.
|
||||
##
|
||||
## Using callables is especially useful, for instance, if you
|
||||
## are using gitchangelog to generate incrementally your changelog.
|
||||
##
|
||||
## Some helpers are provided, you can use them::
|
||||
##
|
||||
## - FileFirstRegexMatch(file, pattern): will return a callable that will
|
||||
## return the first string match for the given pattern in the given file.
|
||||
## If you use named sub-patterns in your regex pattern, it'll output only
|
||||
## the string matching the regex pattern named "rev".
|
||||
##
|
||||
## - Caret(rev): will return the rev prefixed by a "^", which is a
|
||||
## way to remove the given revision and all its ancestor.
|
||||
##
|
||||
## Please note that if you provide a rev-list on the command line, it'll
|
||||
## replace this value (which will then be ignored).
|
||||
##
|
||||
## If empty, then ``gitchangelog`` will act as it had to generate a full
|
||||
## changelog.
|
||||
##
|
||||
## The default is to use all commits to make the changelog.
|
||||
#revs = ["^1.0.3", ]
|
||||
#revs = [
|
||||
# Caret(
|
||||
# FileFirstRegexMatch(
|
||||
# "CHANGELOG.rst",
|
||||
# r"(?P<rev>[0-9]+\.[0-9]+(\.[0-9]+)?)\s+\([0-9]+-[0-9]{2}-[0-9]{2}\)\n--+\n")),
|
||||
# "HEAD"
|
||||
#]
|
||||
# Gets the latest annoted tag and uses that as a base for new changes.
|
||||
|
||||
import subprocess
|
||||
|
||||
proc = subprocess.Popen(["git", "describe", "--abbrev=0", "--tags"], stdout=subprocess.PIPE)
|
||||
out = str(proc.communicate()[0].strip(), "utf-8")
|
||||
revs = [out+"..."]
|
||||
8
.github/FUNDING.yml
vendored
Normal file
@@ -0,0 +1,8 @@
|
||||
# These are supported funding model platforms
|
||||
|
||||
github: # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2]
|
||||
patreon: # Replace with a single Patreon username
|
||||
open_collective: radarr
|
||||
ko_fi: # Replace with a single Ko-fi username
|
||||
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
|
||||
custom: # Replace with a single custom sponsorship URL
|
||||
1
.github/reaction.yml
vendored
Normal file
@@ -0,0 +1 @@
|
||||
|
||||
60
.gitignore
vendored
@@ -11,6 +11,7 @@ src/**/[Oo]bj/
|
||||
*.user
|
||||
*.sln.docstates
|
||||
.vs/
|
||||
.vscode/
|
||||
|
||||
# Build results
|
||||
*_i.c
|
||||
@@ -45,6 +46,10 @@ _dotCover*
|
||||
# DevExpress CodeRush
|
||||
src/.cr/
|
||||
|
||||
# Emacs
|
||||
*~
|
||||
\#*\#
|
||||
|
||||
# NCrunch
|
||||
*.ncrunch*
|
||||
.*crunch*.local.xml
|
||||
@@ -80,7 +85,6 @@ TestResults
|
||||
[Tt]est[Rr]esult*
|
||||
*.Cache
|
||||
ClientBin
|
||||
[Ss]tyle[Cc]op.*
|
||||
~$*
|
||||
*.dbmdl
|
||||
Generated_Code #added for RIA/Silverlight projects
|
||||
@@ -102,40 +106,44 @@ _NCrunch_*
|
||||
_TeamCity*
|
||||
|
||||
# Radarr
|
||||
Backups/
|
||||
logs/
|
||||
MediaCover/
|
||||
UpdateLogs/
|
||||
xdg/
|
||||
config.xml
|
||||
logs.db*
|
||||
nzbdrone.db*
|
||||
nzbdrone.pid
|
||||
nzbdrone.log*txt
|
||||
UpdateLogs/
|
||||
*workspace.xml
|
||||
*.test-cache
|
||||
*.userprefs
|
||||
*/test-results/*
|
||||
src/UI/.idea/*
|
||||
*log.txt
|
||||
node_modules/
|
||||
_output*
|
||||
_artifacts
|
||||
_rawPackage/
|
||||
_dotTrace*
|
||||
_tests/
|
||||
*.Result.xml
|
||||
coverage*.xml
|
||||
coverage*.json
|
||||
setup/Output/
|
||||
*.~is
|
||||
|
||||
UI.Phantom/
|
||||
|
||||
# VS outout folders
|
||||
bin
|
||||
obj
|
||||
output/*
|
||||
|
||||
# .NET Core
|
||||
project.lock.json
|
||||
project.fragment.lock.json
|
||||
artifacts/
|
||||
**/Properties/launchSettings.json
|
||||
|
||||
# Packages
|
||||
Radarr_*/
|
||||
Radarr_*.zip
|
||||
Radarr_*.gz
|
||||
gecko.zip
|
||||
geckodriver.exe
|
||||
|
||||
# macOS metadata files
|
||||
._*
|
||||
@@ -153,4 +161,32 @@ Thumbs.db
|
||||
|
||||
# Cake
|
||||
/tools/Addins/*
|
||||
packages.config.md5sum
|
||||
packages.config.md5sum
|
||||
|
||||
|
||||
# Common IntelliJ Platform excludes
|
||||
|
||||
# User specific
|
||||
**/.idea/**/workspace.xml
|
||||
**/.idea/**/tasks.xml
|
||||
**/.idea/shelf/*
|
||||
**/.idea/dictionaries
|
||||
**/.idea/.idea.Radarr.Posix
|
||||
**/.idea/.idea.Radarr.Windows
|
||||
|
||||
# Sensitive or high-churn files
|
||||
**/.idea/**/dataSources/
|
||||
**/.idea/**/dataSources.ids
|
||||
**/.idea/**/dataSources.xml
|
||||
**/.idea/**/dataSources.local.xml
|
||||
**/.idea/**/sqlDataSources.xml
|
||||
**/.idea/**/dynamic.xml
|
||||
|
||||
# Rider
|
||||
# Rider auto-generates .iml files, and contentModel.xml
|
||||
**/.idea/**/*.iml
|
||||
**/.idea/**/contentModel.xml
|
||||
**/.idea/**/modules.xml
|
||||
# ignore node_modules symlink
|
||||
node_modules
|
||||
node_modules.nosync
|
||||
|
||||
1
.idea/.name
generated
@@ -1 +0,0 @@
|
||||
Sonarr
|
||||
24
.idea/Sonarr.iml
generated
@@ -1,24 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="WEB_MODULE" version="4">
|
||||
<component name="NewModuleRootManager">
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<excludeFolder url="file://$MODULE_DIR$/.idea" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/Logo" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/_output" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/_output_mono" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/_output_osx" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/_output_osx_app" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/_start" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/_tests" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/debian" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/node_modules" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/osx" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/schemas" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/setup" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/src" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/tools" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
59
.idea/codeStyleSettings.xml
generated
@@ -1,59 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectCodeStyleSettingsManager">
|
||||
<option name="PER_PROJECT_SETTINGS">
|
||||
<value>
|
||||
<option name="LINE_SEPARATOR" value=" " />
|
||||
<option name="RIGHT_MARGIN" value="190" />
|
||||
<option name="HTML_ATTRIBUTE_WRAP" value="0" />
|
||||
<option name="HTML_KEEP_LINE_BREAKS" value="false" />
|
||||
<option name="HTML_KEEP_BLANK_LINES" value="1" />
|
||||
<option name="HTML_ALIGN_ATTRIBUTES" value="false" />
|
||||
<option name="HTML_INLINE_ELEMENTS" value="" />
|
||||
<option name="HTML_DONT_ADD_BREAKS_IF_INLINE_CONTENT" value="" />
|
||||
<CssCodeStyleSettings>
|
||||
<option name="HEX_COLOR_LOWER_CASE" value="true" />
|
||||
<option name="HEX_COLOR_LONG_FORMAT" value="true" />
|
||||
<option name="VALUE_ALIGNMENT" value="1" />
|
||||
</CssCodeStyleSettings>
|
||||
<JSCodeStyleSettings>
|
||||
<option name="SPACE_BEFORE_PROPERTY_COLON" value="true" />
|
||||
<option name="ALIGN_OBJECT_PROPERTIES" value="2" />
|
||||
<option name="SPACE_BEFORE_FUNCTION_LEFT_PARENTH" value="false" />
|
||||
<option name="OBJECT_LITERAL_WRAP" value="2" />
|
||||
<option name="SPACES_WITHIN_OBJECT_LITERAL_BRACES" value="true" />
|
||||
</JSCodeStyleSettings>
|
||||
<XML>
|
||||
<option name="XML_LEGACY_SETTINGS_IMPORTED" value="true" />
|
||||
</XML>
|
||||
<codeStyleSettings language="CSS">
|
||||
<indentOptions>
|
||||
<option name="SMART_TABS" value="true" />
|
||||
</indentOptions>
|
||||
</codeStyleSettings>
|
||||
<codeStyleSettings language="JavaScript">
|
||||
<option name="LINE_COMMENT_AT_FIRST_COLUMN" value="true" />
|
||||
<option name="KEEP_LINE_BREAKS" value="false" />
|
||||
<option name="KEEP_FIRST_COLUMN_COMMENT" value="false" />
|
||||
<option name="KEEP_BLANK_LINES_IN_CODE" value="1" />
|
||||
<option name="CATCH_ON_NEW_LINE" value="true" />
|
||||
<option name="FINALLY_ON_NEW_LINE" value="true" />
|
||||
<option name="ALIGN_MULTILINE_PARAMETERS" value="false" />
|
||||
<option name="ALIGN_MULTILINE_BINARY_OPERATION" value="true" />
|
||||
<option name="SPACE_BEFORE_METHOD_PARENTHESES" value="true" />
|
||||
<option name="CALL_PARAMETERS_WRAP" value="1" />
|
||||
<option name="BINARY_OPERATION_WRAP" value="1" />
|
||||
<option name="TERNARY_OPERATION_SIGNS_ON_NEXT_LINE" value="true" />
|
||||
<option name="ARRAY_INITIALIZER_WRAP" value="2" />
|
||||
<option name="ARRAY_INITIALIZER_LBRACE_ON_NEXT_LINE" value="true" />
|
||||
<option name="ARRAY_INITIALIZER_RBRACE_ON_NEXT_LINE" value="true" />
|
||||
<option name="IF_BRACE_FORCE" value="3" />
|
||||
<option name="DOWHILE_BRACE_FORCE" value="3" />
|
||||
<option name="WHILE_BRACE_FORCE" value="3" />
|
||||
<option name="FOR_BRACE_FORCE" value="3" />
|
||||
</codeStyleSettings>
|
||||
</value>
|
||||
</option>
|
||||
<option name="USE_PER_PROJECT_SETTINGS" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
6
.idea/encodings.xml
generated
@@ -1,6 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding">
|
||||
<file url="PROJECT" charset="UTF-8" />
|
||||
</component>
|
||||
</project>
|
||||
6
.idea/jsLibraryMappings.xml
generated
@@ -1,6 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="JavaScriptLibraryMappings">
|
||||
<excludedPredefinedLibrary name="Radarr/node_modules" />
|
||||
</component>
|
||||
</project>
|
||||
14
.idea/misc.xml
generated
@@ -1,14 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectLevelVcsManager" settingsEditedManually="false">
|
||||
<OptionsSetting value="true" id="Add" />
|
||||
<OptionsSetting value="true" id="Remove" />
|
||||
<OptionsSetting value="true" id="Checkout" />
|
||||
<OptionsSetting value="true" id="Update" />
|
||||
<OptionsSetting value="true" id="Status" />
|
||||
<OptionsSetting value="true" id="Edit" />
|
||||
<ConfirmationsSetting value="0" id="Add" />
|
||||
<ConfirmationsSetting value="0" id="Remove" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" />
|
||||
</project>
|
||||
8
.idea/modules.xml
generated
@@ -1,8 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/.idea/Sonarr.iml" filepath="$PROJECT_DIR$/.idea/Sonarr.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
6
.idea/vcs.xml
generated
@@ -1,6 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="$PROJECT_DIR$" vcs="Git" />
|
||||
</component>
|
||||
</project>
|
||||
16
.travis.yml
@@ -1,16 +0,0 @@
|
||||
language: csharp
|
||||
solution: src/NzbDrone.sln
|
||||
addons:
|
||||
apt:
|
||||
packages:
|
||||
- nodejs
|
||||
# - npm apparently not needed anymore.
|
||||
script:
|
||||
- ./build.sh
|
||||
- chmod +x test.sh
|
||||
# - ./test.sh Linux Unit Takes far too long, maybe even crashes travis :/
|
||||
after_success:
|
||||
- chmod +x package.sh
|
||||
- ./package.sh
|
||||
notifications:
|
||||
- webhooks: https://discordapp.com/api/webhooks/266910310219251712/V-QvCcnYkg3O8PMevcAJOJyCgrYkZQoF2pupLDGbaISNUECmYPd6LRwl3avKHsPyfgWP
|
||||
960
CHANGELOG.md
@@ -1,960 +0,0 @@
|
||||
# Changelog
|
||||
|
||||
## (unreleased)
|
||||
|
||||
### **New features**
|
||||
-  AHD_Internal and G_Scene indexer flags. Also linked a wiki page with more information about indexer flags. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  indexer flags to the list of environmental variable for customs scripts (on grab) ([#2801](https://github.com/Radarr/Radarr/issues/2801)) [<a href="https://github.com/bobbintb">bobbintb</a>]
|
||||
-  issue templates. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  Rare timing issue on first-use causing duplicate naming config ([#2790](https://github.com/Radarr/Radarr/issues/2790)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Qbittorrent state and eta fixes ([#2789](https://github.com/Radarr/Radarr/issues/2789)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Purge alt titles on movie delete ([#2796](https://github.com/Radarr/Radarr/issues/2796)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Don’t allow profiles in use by lists to be deleted ([#2797](https://github.com/Radarr/Radarr/issues/2797)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Throwing error when indexer doesn't support a category. Now only warns the user. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Broken Newznab testing. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Omgwtfnzbs API categories (UHD, Full BR and Other) ([#2764](https://github.com/Radarr/Radarr/issues/2764)) [<a href="https://github.com/jusher00">jusher00</a>]
|
||||
-  Indexers that do not support movie search should give better error messages. Radarr now also complains if an indexer does not support certain categories. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  RSS Feeds with no description failing to be added. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.1067 (2018-04-17)
|
||||
|
||||
### **Fixes**
|
||||
-  Radarr not loading with an invalid sort key. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.1066 (2018-04-16)
|
||||
|
||||
### **New features**
|
||||
-  More logging for strange PTP errors. Please report them immediately when you see them. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Setting for Colon Replacement Format ([#2711](https://github.com/Radarr/Radarr/issues/2711)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Enable Download Client Priorities ([#2699](https://github.com/Radarr/Radarr/issues/2699)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Radarr now stores cookies for PTP beyond restarts. Should limit active sessions correctly. ([#2643](https://github.com/Radarr/Radarr/issues/2643)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Setting for absolute maximum size for a release ([#2662](https://github.com/Radarr/Radarr/issues/2662)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  A Huge Cleanup of old Series Code. (Let's pray nothing breaks :P) ([#2589](https://github.com/Radarr/Radarr/issues/2589)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  stale.yml. [<a href="https://github.com/AeonLucid">AeonLucid</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  Register as Radarr to avoid issues with Sonarr ([#2715](https://github.com/Radarr/Radarr/issues/2715)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Handling of unknown status types in DownloadStation and Import from torrent Download Station should move since DS maintains an internal copy for seeding. ([#2420](https://github.com/Radarr/Radarr/issues/2420)) [<a href="https://github.com/Marcelo Castagna">Marcelo Castagna</a>]
|
||||
-  Misc Extra File Improvements (This changes mapping of backdrop images to Fanart instead of Banner) ([#2642](https://github.com/Radarr/Radarr/issues/2642)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Multiple Calendar Issues, Other UI Fixes ([#2685](https://github.com/Radarr/Radarr/issues/2685)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Cutoff Unmet Sorting by Downloaded Quality not working. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Add form param before submitting request ([#2674](https://github.com/Radarr/Radarr/issues/2674)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Don't add category when removing torrent from qBittorrent ([#2661](https://github.com/Radarr/Radarr/issues/2661)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  underscore to host part of URI regex ([#2633](https://github.com/Radarr/Radarr/issues/2633)) [<a href="https://github.com/mueslo">mueslo</a>]
|
||||
-  ICS malformed in a lot of cases. Also events are now all day. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Set category when adding torrent to qBittorrent ([#2649](https://github.com/Radarr/Radarr/issues/2649)) [<a href="https://github.com/themagicbullet">themagicbullet</a>]
|
||||
- Create support.yml. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Incorrect Kodi nfo date format ([#2605](https://github.com/Radarr/Radarr/issues/2605)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Sort by Downloaded not working. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.995 (2018-03-04)
|
||||
|
||||
### **New features**
|
||||
-  Copy & Paste now triggers search ([#2587](https://github.com/Radarr/Radarr/issues/2587)) [<a href="https://github.com/Paul Kozlovitch">Paul Kozlovitch</a>]
|
||||
-  console logging in case NLog fails to initialize. [<a href="https://github.com/Taloth Saldono">Taloth Saldono</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  Changes in http redirect logic causing failed grabs and >25% cpu usage. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  http->https redirects do not use the tls1.2 curl fallback. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Dates before 1970 causing an exception. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Browser not updating on Movie File Imported. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Movies not getting unmonitored when folder gets deleted ([#2588](https://github.com/Radarr/Radarr/issues/2588)) [<a href="https://github.com/Simon Chapman">Simon Chapman</a>]
|
||||
-  NLog causing a crash under mono 5.10. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Revert "Fixed: Updated NLog to 4.5 RC6 to handle mono 5.10" [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Revert "Fixed: Messed up merge from Cherry pick" [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Revert "Fixed: Appveyor build." [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Appveyor build. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Messed up merge from Cherry pick. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Updated NLog to 4.5 RC6 to handle mono 5.10. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Revert "Fixed: NLog causing a crash under mono 5.10" [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Pin cake and addin versions. [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Temp Workaround for Appveyor Cake Issue. [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  NLog causing a crash under mono 5.10. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Poster sliding issues ([#2570](https://github.com/Radarr/Radarr/issues/2570)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Multiple History Issues ([#2571](https://github.com/Radarr/Radarr/issues/2571)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
|
||||
|
||||
## v0.2.0.980 (2018-02-21)
|
||||
|
||||
### **New features**
|
||||
-  Metadata links are now better readable. Also fixed links in the poster view. ([#2562](https://github.com/Radarr/Radarr/issues/2562)) [<a href="https://github.com/thezoggy">thezoggy</a>]
|
||||
-  Handle ctrl-c more gracefully. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Device names for Join notifications ([#2544](https://github.com/Radarr/Radarr/issues/2544)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Same File Size MediaFile Specification ([#2532](https://github.com/Radarr/Radarr/issues/2532)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  NLog to version 4.4.12. Should fix [#2218](https://github.com/Radarr/Radarr/issues/2218) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Importing extra files from downloaded movies and generate metadata such as .nfo ([#2506](https://github.com/Radarr/Radarr/issues/2506)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Quotes around alternative titles ([#2522](https://github.com/Radarr/Radarr/issues/2522)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Backup improvements from Sonarr ([#2513](https://github.com/Radarr/Radarr/issues/2513)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  NzbDrone references in FirewallAdapter.cs ([#2504](https://github.com/Radarr/Radarr/issues/2504)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  Another Delete modal is fixed. ([#2560](https://github.com/Radarr/Radarr/issues/2560)) [<a href="https://github.com/thezoggy">thezoggy</a>]
|
||||
-  Messed up movie deletion modal ([#2552](https://github.com/Radarr/Radarr/issues/2552)) [<a href="https://github.com/thezoggy">thezoggy</a>]
|
||||
-  Remove sorting on Monitor/Profile columns to prevent unexpected results until sorting can properly be handled. Quick Fix for [#2540](https://github.com/Radarr/Radarr/issues/2540) ([#2553](https://github.com/Radarr/Radarr/issues/2553)) [<a href="https://github.com/thezoggy">thezoggy</a>]
|
||||
-  OSX app has bundle name of Sonarr ([#2555](https://github.com/Radarr/Radarr/issues/2555)) [<a href="https://github.com/thezoggy">thezoggy</a>]
|
||||
-  Alt Titles from TMDB not getting added when mappings server throws 404. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Unable to execute custom scripts if IMDB ID is null ([#2543](https://github.com/Radarr/Radarr/issues/2543)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
- Cleanup TV related code in API ([#2530](https://github.com/Radarr/Radarr/issues/2530)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Omgwtfnbs parsing being too greedy. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Help icon not centered ([#2531](https://github.com/Radarr/Radarr/issues/2531)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Radarr Changes every file due to timezones ([#2533](https://github.com/Radarr/Radarr/issues/2533)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Filters not working. Fuck you backbone. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Cleanup Series Code from UI ([#2525](https://github.com/Radarr/Radarr/issues/2525)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Apostrophe getting replaced by an empty string causing no search results. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Integration Unit Tests ([#2500](https://github.com/Radarr/Radarr/issues/2500)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  XSS vulnerability in the navbar search. ([#2505](https://github.com/Radarr/Radarr/issues/2505)) [<a href="https://github.com/Scott">Scott</a>]
|
||||
-  StartNzbDroneService.cs unit test ([#2499](https://github.com/Radarr/Radarr/issues/2499)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
- SelectAll and deselectAll MovieEditor buttons. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  build problem on windows. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Revert "Fixed: Removed hebrew ISO, since english movies are still in english. ([#1922](https://github.com/Radarr/Radarr/issues/1922))" [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Error with deluge when it doesn’t report a Hash. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Logging error when accessing mount point. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Invalid runtime from CP causing issues importing. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Typo in TMDB Settings. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Hopefully fixed errors with Delay Profiles. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Error when importing files and old folder doesn’t exist. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Zooqle torrents not getting added, since their torrent file is messed up. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.935 (2018-02-06)
|
||||
|
||||
### **New features**
|
||||
-  Include total space with root folders. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Manual Import now adds year after movie title for filtering. This should help finding movies such as IT. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Option to require indexer flags per indexer. (e.g. only download freeleech torrents from a private tracker) ([#2460](https://github.com/Radarr/Radarr/issues/2460)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Files downloaded with different quality than grabbed will get rejected. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  TMDbSettings.cs to allow pipe for or for genre ids ([#2389](https://github.com/Radarr/Radarr/issues/2389)) [<a href="https://github.com/crhammock">crhammock</a>]
|
||||
-  Dynamic paths cleanup old folders now! [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  No Physical Release Date causing exception when setting last write time. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Movies not getting unmonitored when folder gets deleted. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Rare case of null quality causing issues with manual import. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Manual Import not automatically choosing right movie. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Rare case of RequiredIndexerFlags failing with old Newznab indexers. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Folder name getting messed up when adding movies via a list. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Error when adding an already excluded movie to the exclusion list. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Last commit still not compiling (whoops squared) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Last commit not compiling (whoops) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Clean Library being to agressive when lists are having failures. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Error when nno quality was associated with a movie file. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Allowing in use Profiles to be Deleted. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Error when Movie has no imdbid when searching Rargb. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Rargb failing when imdbid is not found. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  {Original Filename} not allowed in Movie Filename. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Look for changes to package.json before using old build cache ([#2445](https://github.com/Radarr/Radarr/issues/2445)) [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  HistoryDetailsLayoutTemplate.hbs ([#2361](https://github.com/Radarr/Radarr/issues/2361)) [<a href="https://github.com/Pieter Janssens">Pieter Janssens</a>]
|
||||
|
||||
|
||||
## v0.2.0.910 (2017-12-13)
|
||||
|
||||
### **New features**
|
||||
-  Separate naming tags for AudioLanguage and SubtitleLanguage ([#2261](https://github.com/Radarr/Radarr/issues/2261)) (Fixes [#2257](https://github.com/Radarr/Radarr/issues/2257)) [<a href="https://github.com/fhscholl">fhscholl</a>]
|
||||
-  Include APFS disks in disk space calculation. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Upgrade MediaInfo to 17.10 (Windows/macOS) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Support for VF2 french tag. ([#2291](https://github.com/Radarr/Radarr/issues/2291)) (Fixes [#2290](https://github.com/Radarr/Radarr/issues/2290)) [<a href="https://github.com/kriegalex">kriegalex</a>]
|
||||
-  Customize Slack Channel ([#2308](https://github.com/Radarr/Radarr/issues/2308)) (Fixes [#2298](https://github.com/Radarr/Radarr/issues/2298)) [<a href="https://github.com/grokdesigns">grokdesigns</a>]
|
||||
-  SceneName to MovieFile API output ([#2250](https://github.com/Radarr/Radarr/issues/2250)) (Fixes [#2245](https://github.com/Radarr/Radarr/issues/2245)) [<a href="https://github.com/fhscholl">fhscholl</a>]
|
||||
-  Functionality to XBMC and Plex to update indivdual titles. Also: Notification Cleanup ([#2240](https://github.com/Radarr/Radarr/issues/2240)) [<a href="https://github.com/fhscholl">fhscholl</a>]
|
||||
-  FolderPath to the Movie Webhook ([#2230](https://github.com/Radarr/Radarr/issues/2230)) [<a href="https://github.com/adnanklink">adnanklink</a>]
|
||||
-  Download_Id to On Download/On Upgrade ([#2229](https://github.com/Radarr/Radarr/issues/2229)) [<a href="https://github.com/adnanklink">adnanklink</a>]
|
||||
-  Movie_Quality to onGrab ([#2221](https://github.com/Radarr/Radarr/issues/2221)) (Fixes [#1833](https://github.com/Radarr/Radarr/issues/1833)) [<a href="https://github.com/fhscholl">fhscholl</a>]
|
||||
-  Webhook Improvements ([#2220](https://github.com/Radarr/Radarr/issues/2220)) (Fixes [#1751](https://github.com/Radarr/Radarr/issues/1751)) [<a href="https://github.com/fhscholl">fhscholl</a>]
|
||||
-  Message about adblockers preventing the log table from loading ([#2213](https://github.com/Radarr/Radarr/issues/2213)) (Fixes [#2209](https://github.com/Radarr/Radarr/issues/2209)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Sabnzbd Update test cases and rename to MovieCategory ([#2212](https://github.com/Radarr/Radarr/issues/2212)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Nzbget Rename TvCategory references to MovieCategory ([#2211](https://github.com/Radarr/Radarr/issues/2211)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  default port of qBittorrent download client config ([#2187](https://github.com/Radarr/Radarr/issues/2187)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Initial state for torrents added to qBittorrent ([#2176](https://github.com/Radarr/Radarr/issues/2176)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Adjust ambiguous date options ([#2165](https://github.com/Radarr/Radarr/issues/2165)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  a default name for Radarr.ics ([#2163](https://github.com/Radarr/Radarr/issues/2163)) [<a href="https://github.com/James White">James White</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  MediaCover endpoint. [<a href="https://github.com/Taloth Saldono">Taloth Saldono</a>]
|
||||
-  Don't handle content requests in IndexHtmlMapper. [<a href="https://github.com/Mark McDowall">Mark McDowall</a>]
|
||||
-  Movies parsed from lists with no year and only title getting added mutliple times. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Security Vulnerabilities allowing authentication to be bypassed (discovered by Kyle Neideck) [<a href="https://github.com/Taloth Saldono">Taloth Saldono</a>]
|
||||
-  Movie Editor Path screwed up. Might also fix some other movie editor issues. (Fixes [#2170](https://github.com/Radarr/Radarr/issues/2170)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Tags disappearing (Fixes [#2204](https://github.com/Radarr/Radarr/issues/2204)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  moment.js deprecated zone and add functions (Fixes [#2232](https://github.com/Radarr/Radarr/issues/2232)) (Fixes [#2231](https://github.com/Radarr/Radarr/issues/2231)) ([#2264](https://github.com/Radarr/Radarr/issues/2264)) [<a href="https://github.com/Fish2">Fish2</a>]
|
||||
-  CPU locking at a 100% in certain instances. ([#2258](https://github.com/Radarr/Radarr/issues/2258)) (Fixes [#2218](https://github.com/Radarr/Radarr/issues/2218)) [<a href="https://github.com/Mike">Mike</a>]
|
||||
- Revert "Fixed: moment.js deprecated zone and Added: and lossless compression of images ([#2232](https://github.com/Radarr/Radarr/issues/2232)) (Fixes [#2231](https://github.com/Radarr/Radarr/issues/2231))" [<a href="https://github.com/Fish2">Fish2</a>]
|
||||
-  moment.js deprecated zone and Added: and lossless compression of images ([#2232](https://github.com/Radarr/Radarr/issues/2232)) (Fixes [#2231](https://github.com/Radarr/Radarr/issues/2231)) [<a href="https://github.com/Fish2">Fish2</a>]
|
||||
- Fixes [#2218](https://github.com/Radarr/Radarr/issues/2218). ([#2254](https://github.com/Radarr/Radarr/issues/2254)) [<a href="https://github.com/Mike">Mike</a>]
|
||||
- Minor error message tweak ([#1778](https://github.com/Radarr/Radarr/issues/1778)) [<a href="https://github.com/Oliver Rivett-Carnac">Oliver Rivett-Carnac</a>]
|
||||
- UTorrent initial state feature ([#2192](https://github.com/Radarr/Radarr/issues/2192)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  IsUpgrade and related deleted file paths for CustomScript ([#2205](https://github.com/Radarr/Radarr/issues/2205)) [<a href="https://github.com/fhscholl">fhscholl</a>]
|
||||
-  typo on margin-bottom ([#2182](https://github.com/Radarr/Radarr/issues/2182)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Manual Import. Fixes [#2160](https://github.com/Radarr/Radarr/issues/2160) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Remove unit on zero values ([#2178](https://github.com/Radarr/Radarr/issues/2178)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Jackett apikey cleaned from log again. ([#2177](https://github.com/Radarr/Radarr/issues/2177)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Manual Movie Page Filtering. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  MediaInfo not getting read when quality isn't Bluray, Web-dl or HDTV. Fixes [#1465](https://github.com/Radarr/Radarr/issues/1465). Fixes [#1572](https://github.com/Radarr/Radarr/issues/1572). [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.870 (2017-10-09)
|
||||
|
||||
### **New features**
|
||||
-  new codec HEVC with ID=5 for HDBits ([#2146](https://github.com/Radarr/Radarr/issues/2146)) [<a href="https://github.com/Wyall">Wyall</a>]
|
||||
-  Option to omit year from indexer searches when searching by title. Also added option to force a movie search by title instead of imdb id. Fixes [#1912](https://github.com/Radarr/Radarr/issues/1912) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Last round of optimisation. Large libraries should load around 2x faster again compared to the last version. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Improved load times of very large libraries again (around x5) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Movie files are now eager loaded. This should speed up the loading process a lot as well as RSS Sync and other tasks. It should also prevent some other bugs. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  Alignment and buttons position of Trakt Auth ([#2153](https://github.com/Radarr/Radarr/issues/2153)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  SUBBED in release name not recognized as hardcoded subs. Fixes [#1520](https://github.com/Radarr/Radarr/issues/1520) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  1080i not correctly recognized as 1080p. Fixes [#1622](https://github.com/Radarr/Radarr/issues/1622) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Releases with UHD not getting correct resolution label. Fixes [#2134](https://github.com/Radarr/Radarr/issues/2134) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  WebDL gets marked as Remux. Fixes [#1954](https://github.com/Radarr/Radarr/issues/1954) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Parsing of TSRip and HDTSRip. Fixes [#1998](https://github.com/Radarr/Radarr/issues/1998) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  unclosed <span> tag on BulkImportView ([#2110](https://github.com/Radarr/Radarr/issues/2110)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Change to correct provider of search results ([#2113](https://github.com/Radarr/Radarr/issues/2113)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Icon not being hidden on Discover New Movies button in X-Small breakpoint ([#2114](https://github.com/Radarr/Radarr/issues/2114)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Font folder case fix ([#2066](https://github.com/Radarr/Radarr/issues/2066)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Add space in confirmation message ([#2101](https://github.com/Radarr/Radarr/issues/2101)) [<a href="https://github.com/Adam Dangoor">Adam Dangoor</a>]
|
||||
- Create LICENSE. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Alternative Titles appearing multiple times. Duplicate alt titles will be deleted. Fixes [#2040](https://github.com/Radarr/Radarr/issues/2040) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.852 (2017-09-10)
|
||||
|
||||
### **New features**
|
||||
-  WOFF2 fonts for better performance in supported browsers ([#1994](https://github.com/Radarr/Radarr/issues/1994)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Tweak NavbarLayoutTemplate.hbs ([#1996](https://github.com/Radarr/Radarr/issues/1996)) [<a href="https://github.com/James White">James White</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  Scripts should be included before closing body tag ([#1995](https://github.com/Radarr/Radarr/issues/1995)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Allow toolbar buttons to be full width on x-small and small breakpoints ([#1972](https://github.com/Radarr/Radarr/issues/1972)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Alt titles with less than 4 votes being used. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Cleanup of unused alt titles. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.846 (2017-08-27)
|
||||
|
||||
### **New features**
|
||||
-  Ability to force download movies that could not be mapped correctly. This also shares these mappings with other users, so everyone can profit :) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Display breakpoint name in browser window in debug mode ([#1968](https://github.com/Radarr/Radarr/issues/1968)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Ability to delete multiple movies at once via the movie editor. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Deprecation warning about Drone Factory to front end ([#1938](https://github.com/Radarr/Radarr/issues/1938)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Package-lock.json for npm 5 ([#1939](https://github.com/Radarr/Radarr/issues/1939)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  FontAwesome to 4.7.0 ([#1928](https://github.com/Radarr/Radarr/issues/1928)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Hebrew language ([#1909](https://github.com/Radarr/Radarr/issues/1909)) [<a href="https://github.com/Rotem">Rotem</a>]
|
||||
-  Run tests through powershell. ([#1903](https://github.com/Radarr/Radarr/issues/1903)) [<a href="https://github.com/Mike">Mike</a>]
|
||||
-  Alternative Titles are now also pulled from mappings.radarr.video. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Alternative Titles were reworked greatly. This should speed up RSS Sync massively, especially for large libraries (up to 4x). [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  Refresh movie failing. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Refresh movie failing for most movies. (Fixes [#2007](https://github.com/Radarr/Radarr/issues/2007)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  A few issues with the new alternative titles feature. ([#2008](https://github.com/Radarr/Radarr/issues/2008)) (Fixes [#1919](https://github.com/Radarr/Radarr/issues/1919), [#1927](https://github.com/Radarr/Radarr/issues/1927) and [#1917](https://github.com/Radarr/Radarr/issues/1917)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  A lot of small ui errors (e.g. More not showing) (Revert of [#1959](https://github.com/Radarr/Radarr/issues/1959)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Adjust Sonarr references to Radarr ([#1977](https://github.com/Radarr/Radarr/issues/1977)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Rename movie not working ([#1970](https://github.com/Radarr/Radarr/issues/1970)) (Fixes [#1908](https://github.com/Radarr/Radarr/issues/1908)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Error with CP Import when no info is present. Fixes [#1792](https://github.com/Radarr/Radarr/issues/1792) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Movie files & folders will actually get deleted now ([#1966](https://github.com/Radarr/Radarr/issues/1966)) (Fixes [#694](https://github.com/Radarr/Radarr/issues/694)) [<a href="https://github.com/Tom">Tom</a>]
|
||||
-  Bulk UI cleanup, fixes and consistency improvements ([#1959](https://github.com/Radarr/Radarr/issues/1959)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Parser error when using `(year) name` folder ([#1956](https://github.com/Radarr/Radarr/issues/1956)) (Fixes [#1951](https://github.com/Radarr/Radarr/issues/1951)) [<a href="https://github.com/MangaValk">MangaValk</a>]
|
||||
-  Missing icon preventing detailed explanation validation errors explanations from appearing. ([#1944](https://github.com/Radarr/Radarr/issues/1944)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Mask-icon and other resources when UrlBase is in use ([#1933](https://github.com/Radarr/Radarr/issues/1933)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Slack/Mattermost notifications improvements from Sonarr ([#1930](https://github.com/Radarr/Radarr/issues/1930)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  fontawesome path (Icons disappearing) ([#1929](https://github.com/Radarr/Radarr/issues/1929)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Charset and meta in index.html and login.html ([#1926](https://github.com/Radarr/Radarr/issues/1926)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Removed hebrew ISO, since english movies are still in english. ([#1922](https://github.com/Radarr/Radarr/issues/1922)) [<a href="https://github.com/Rotem">Rotem</a>]
|
||||
-  Adjust column sizes relative to size of dropdown values ([#1923](https://github.com/Radarr/Radarr/issues/1923)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Additional jshint warnings ([#1921](https://github.com/Radarr/Radarr/issues/1921)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Minor issues on MoreInfoViewTemplate.hbs ([#1916](https://github.com/Radarr/Radarr/issues/1916)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  gulp jshint warnings ([#1873](https://github.com/Radarr/Radarr/issues/1873)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Replace GitHub wiki references to Radarr's wiki URL ([#1914](https://github.com/Radarr/Radarr/issues/1914)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Hanging form-group div ([#1911](https://github.com/Radarr/Radarr/issues/1911)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Migration failing and thus making Radarr unable to start. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Task name of PreDB Sync task ([#1875](https://github.com/Radarr/Radarr/issues/1875)) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Check that Quality Profile is not in use before deleting it. [<a href="https://github.com/Qstick">Qstick</a>]
|
||||
-  Category not setting with qBitTorrent 3.3.14 and other api errors. (upstream from Sonarr) [<a href="https://github.com/James White">James White</a>]
|
||||
-  Non-Freeleech torrents showing as freeleech for AHD. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Older movies (released more than 30 days ago) are now not refreshed as often anymore (every 30 days) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  (Hopefully) Bug where movie file was not correctly linked to movie. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  No API Key required with SignalR connections. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Guard agains null reference exception with newznab capabilities. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Update Info.plist to avoid conflict with Sonarr ([#1783](https://github.com/Radarr/Radarr/issues/1783)) [<a href="https://github.com/Marc Runkel">Marc Runkel</a>]
|
||||
-  Relax SingleInstancePolicy when using a custom data directory Fixes [#1765](https://github.com/Radarr/Radarr/issues/1765) ([#1782](https://github.com/Radarr/Radarr/issues/1782)) [<a href="https://github.com/Richard Schwab">Richard Schwab</a>]
|
||||
-  Lists are fetched much more efficiently. (Up to 40x loading time improvement with large lists!) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Revert "Fixed: Support for Mono 5.x with the newer BoringTLS provider." [<a href="https://github.com/Taloth Saldono">Taloth Saldono</a>]
|
||||
-  Support for Mono 5.x with the newer BoringTLS provider. [<a href="https://github.com/Taloth Saldono">Taloth Saldono</a>]
|
||||
-  Old Plex ValidationFailure message ([#1770](https://github.com/Radarr/Radarr/issues/1770)) [<a href="https://github.com/Sandro Stikić">Sandro Stikić</a>]
|
||||
-  BDRemux not recognized as such and BDRips without resolution recognized as DVD. Fixes [#1755](https://github.com/Radarr/Radarr/issues/1755) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  A as part of an acronym being removed from clean title. Fixes [#1747](https://github.com/Radarr/Radarr/issues/1747) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Folder in List settings appearing blank in some browsers. Fixes [#1711](https://github.com/Radarr/Radarr/issues/1711) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Minimum Seeders not saving for Torznab indexer. Fixes [#1736](https://github.com/Radarr/Radarr/issues/1736) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.778 (2017-06-20)
|
||||
|
||||
### **New features**
|
||||
-  Radarr API url now points to new v2 version. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Name of Radarr Lists. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  More detailed descriptions why a movie was not able to be mapped. ([#1696](https://github.com/Radarr/Radarr/issues/1696)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Options to make parsing more lenient. (Adds support for some german and french releasegroups) ([#1692](https://github.com/Radarr/Radarr/issues/1692)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Bootstrap Tags Input ([#1674](https://github.com/Radarr/Radarr/issues/1674)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Include css files in minification ([#1672](https://github.com/Radarr/Radarr/issues/1672)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Upgrade to Bootstrap 3.3.7 ([#1673](https://github.com/Radarr/Radarr/issues/1673)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Allow minimum seeders to be set on a per indexer basis. Pulled from Sonarr Upstream ([#1624](https://github.com/Radarr/Radarr/issues/1624)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Remove redundant IE meta tag as we use http header instead ([#1655](https://github.com/Radarr/Radarr/issues/1655)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Use cleancss for minification ([#1654](https://github.com/Radarr/Radarr/issues/1654)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Ability to see TMDB and lists going through the Radarr API on the discovery page. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Search 5 alternative titles as well. This should help with french as well as movies with very different titles. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  [Radarr] tag for Twitter Notifications ([#1558](https://github.com/Radarr/Radarr/issues/1558)) [<a href="https://github.com/Jason Costomiris">Jason Costomiris</a>]
|
||||
-  Custom Class for Radarr API requests. Also implements new error handling present on staging server. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  HDBits Category, Codec, and Medium Filtering Capability ([#1458](https://github.com/Radarr/Radarr/issues/1458)) [<a href="https://github.com/randellhodges">randellhodges</a>]
|
||||
-  radarr api url. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  TaskManager.cs. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  LogEntries token again :) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  migration. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Redirect calls missing URL Base ([#1668](https://github.com/Radarr/Radarr/issues/1668)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Twitter oAuth callback URL ([#1669](https://github.com/Radarr/Radarr/issues/1669)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Error when processing manual import decisions ([#1670](https://github.com/Radarr/Radarr/issues/1670)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Create README.md. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  license. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Urls missing from multiple indexers after latest nightly update. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Follow 301 redirects when fetching torrents ([#1653](https://github.com/Radarr/Radarr/issues/1653)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Ensure an API Key is set when starting Radarr ([#1652](https://github.com/Radarr/Radarr/issues/1652)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Minimum availability is now working similarely to profile when adding a movie. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Forgot to include some js files in the last commit. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  error when we get invalid datetime from our api. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Lossless compression of images saved 92KB ([#1620](https://github.com/Radarr/Radarr/issues/1620)) [<a href="https://github.com/Fish2">Fish2</a>]
|
||||
- Mostly fixes UI glitches for list settings. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Refresh IsDuplicate in bulk import when the tmdbId changes ([#1570](https://github.com/Radarr/Radarr/issues/1570)) [<a href="https://github.com/Sentir101">Sentir101</a>]
|
||||
- Encourage Torznab use with Jackett ([#1559](https://github.com/Radarr/Radarr/issues/1559)) [<a href="https://github.com/flightlevel">flightlevel</a>]
|
||||
-  PTP indexer being disabled if no results are found for a movie. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  basic naming settings. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Discovery of upcoming movies points to our server now. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Most likely fixed [#745](https://github.com/Radarr/Radarr/issues/745) now. [<a href="https://github.com/Mike">Mike</a>]
|
||||
- Chmod osx file as executable. ([#1539](https://github.com/Radarr/Radarr/issues/1539)) [<a href="https://github.com/Mike">Mike</a>]
|
||||
-  IMDB URL to notifications ([#1531](https://github.com/Radarr/Radarr/issues/1531)) [<a href="https://github.com/tsubus">tsubus</a>]
|
||||
-  design calendar css bug ([#1527](https://github.com/Radarr/Radarr/issues/1527)) [<a href="https://github.com/Levi Wilcox">Levi Wilcox</a>]
|
||||
- Correct Program Name ([#1524](https://github.com/Radarr/Radarr/issues/1524)) [<a href="https://github.com/Luke Anderson">Luke Anderson</a>]
|
||||
- Correct Program Name ([#1523](https://github.com/Radarr/Radarr/issues/1523)) [<a href="https://github.com/Luke Anderson">Luke Anderson</a>]
|
||||
- Osx updater now updates plist file to point to the correct executable binary. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Using our own logentries token now. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  osx updater failing. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.696 (2017-05-12)
|
||||
|
||||
### **New features**
|
||||
-  TaskManager.cs. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  test. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Movies with same name but different year being downloaded regardlessly is now fixed! [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.692 (2017-05-11)
|
||||
|
||||
### **New features**
|
||||
-  ability to discover new movies based on upcoming blurays as well as popular movies (borrowed from steven lu :)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Kodi icon, fixes [#1464](https://github.com/Radarr/Radarr/issues/1464) ([#1492](https://github.com/Radarr/Radarr/issues/1492)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  initial migration. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  trailer links to the discovery page. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  discovery tab based on tmdb recommendations based on your existing movies. ([#1450](https://github.com/Radarr/Radarr/issues/1450)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  default page size to 250. Should help with safari timeouts. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  multiple new editions such as FanEdit, Anniversary and 2in1. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  design issue when deleting css bug ([#1480](https://github.com/Radarr/Radarr/issues/1480)) Fixes [#1475](https://github.com/Radarr/Radarr/issues/1475) [<a href="https://github.com/Levi Wilcox">Levi Wilcox</a>]
|
||||
- 10 Movies are now shown on discover as well as search results. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Hotfix for when ignored movies would appear again after clicking on show more. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  appveyor build. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Completely overhauled how import exclusions work. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Hopefully more logging to catch errors better. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  A small bug fix for items loading as undefined in organize modal. Movie titles should now show up correctly. ([#1424](https://github.com/Radarr/Radarr/issues/1424)) [<a href="https://github.com/PatrickGHanna">PatrickGHanna</a>]
|
||||
-  error when language is present in title, but has dots instead of spaces. For example The.Danish.Girl.2015. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Final in titles parsing as an edition. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Radarr not importing torrents in Vuze if the torrent already finished seeding and was stopped ([#1471](https://github.com/Radarr/Radarr/issues/1471)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Incorrect imports with Vuze when torrent contains a single file. ([#1470](https://github.com/Radarr/Radarr/issues/1470)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Sonarr UI Authentication cookie should be placed on path (UrlBase) instead of domain alone. Fixes #[#1451](https://github.com/Radarr/Radarr/issues/1451) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Use Post for tmdbids request, to avoid too long URIs. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Tidy up layout of buttons on the Add Movies page for mobile/tablet ([#1454](https://github.com/Radarr/Radarr/issues/1454)) [<a href="https://github.com/David Pooley">David Pooley</a>]
|
||||
- Rename Sonarr to Radarr for OSX App. [<a href="https://github.com/morberg">morberg</a>]
|
||||
- Minor text fixes. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Enable automatic renaming, according to naming scheme, of movie folder after creation of the movie. ([#1349](https://github.com/Radarr/Radarr/issues/1349)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  for error when clicking Rescan Drone Folder. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  for error when trying to manually import. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.654 (2017-04-18)
|
||||
|
||||
### **New features**
|
||||
-  smtp.google.com to smtp.gmail.com ([#1410](https://github.com/Radarr/Radarr/issues/1410)) [<a href="https://github.com/Donald Webster">Donald Webster</a>]
|
||||
-  debug movie title to include Year. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Series reference to Movies, should fix [#1399](https://github.com/Radarr/Radarr/issues/1399) ([#1402](https://github.com/Radarr/Radarr/issues/1402)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  test for fix in last commit. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  branch. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  packages.sh some more. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  package.sh script. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  PTP_Approved turning into HDBits Internal. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  ptp tests. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- AHD, PTP and HDB support the new indexer flags too now! Indexer flags can be preferred over other releases. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Movies with Umlauts are now correctly matched and have correct CleanTitles. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Minor Text fixes. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  error when MinimumAvailability was Announced and Delay was negative. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Disable PreDB sync for now. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Stats are now sent to our server instead of Sonarr's :) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  for sql error. Did not think everything through exactly. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  when MovieTitle is the empty string (should not occur, but what evs) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Fixes Movie Size not showing correctly. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  an issue where movies which were labelled with an alternative title could not be found. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Indexer flags implementation. ([#1377](https://github.com/Radarr/Radarr/issues/1377)) Will be further finalized over the next few weeks with Freelech, preferring of certain flags, etc. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  default runtime when runtime info of tmdb says 0. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Fixes an issue where the semicolon and space afterwards was replaced. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Final tweak for package.sh. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- This should finally fix all packaging stuff. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Test fixes. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- More test debugging. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Remote Test debugging yey! [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Remove unecessary test. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Using NUnit.Runners so that teamcity build works. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Turn installer back on. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Disabled installer being picked up, causes error with update api. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Now artifacts get pushed even if tests fail. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  package script for Teamcity. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Log if ParsedMovieInfo is NULL. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Catching predb.me errors hopefully. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.596 (2017-04-10)
|
||||
|
||||
### **New features**
|
||||
-  nzbdrone.iss. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  appveyor.yml. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  build-appveyor.cake. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  appveyor.yml. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  appveyor.yml. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  nzbdrone.iss. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  build-appveyor.cake. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  build-appveyor.cake. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  appveyor.yml. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  build-appveyor.cake. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  appveyor.yml. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  nzbdrone.iss. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  nzbdrone.iss. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  README.md. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  "Additional Parameters Field" for Trakt RSS Feed ([#1308](https://github.com/Radarr/Radarr/issues/1308)) [<a href="https://github.com/rmangahas-coupa">rmangahas-coupa</a>]
|
||||
-  movie search ([#1212](https://github.com/Radarr/Radarr/issues/1212)) [<a href="https://github.com/thejacer87">thejacer87</a>]
|
||||
-  ISSUE_TEMPLATE.md. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  ISSUE_TEMPLATE.md. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  ISSUE_TEMPLATE.md. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
|
||||
### **Fixes**
|
||||
- Just getting Appveyor to build. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Installer should be built too now. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Text fixes and got pending releases finally fully working. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  searching for movie after it is added from a list. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Specific Subtitle tags (such as nlsub) can now be whitelisted and will be downloaded. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Allow Hardcoded subs to be downloaded still. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Catching HTTP Errors when adding movies from a list. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- SABnzbd 2.0 API compatibility ([#1339](https://github.com/Radarr/Radarr/issues/1339)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Zero length file causes MediaInfo hanging in 100% cpu load. ([#1340](https://github.com/Radarr/Radarr/issues/1340)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  Newznab default capabilities erroneously cached if indexer is unavailable. ([#1341](https://github.com/Radarr/Radarr/issues/1341)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Cleanup on mapping logic. Movies with up to 4500 parts are now supported! [<a href="https://github.com/Rusk85">Rusk85</a>]
|
||||
- Released icon is back. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  spelling mistake. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  an error when searching for movies with no imdbid. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  DownloadStation api client for DSM 5.x. ([#1259](https://github.com/Radarr/Radarr/issues/1259)) [<a href="https://github.com/Marcelo Castagna">Marcelo Castagna</a>]
|
||||
- Should fix covers not being local. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  error when downloading a movie. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  only one movie appearing when list does not give us a tmdbid. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- This should fix all imdbid problems with indexers. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Revert "Move up IMDB logic in ParsingService, should help with the mismatched movies" [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Move up IMDB logic in ParsingService, should help with the mismatched movies. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Clean up jsHint warnings ([#1225](https://github.com/Radarr/Radarr/issues/1225)) [<a href="https://github.com/Zach">Zach</a>]
|
||||
-  pending release service, HDBits, also the release deduper. Clean up housekeeping ([#1211](https://github.com/Radarr/Radarr/issues/1211)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/onedr0p 3 16 17 ([#1200](https://github.com/Radarr/Radarr/issues/1200)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Revert "Small changes to list sync ([#1179](https://github.com/Radarr/Radarr/issues/1179))" [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Small changes to list sync ([#1179](https://github.com/Radarr/Radarr/issues/1179)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/onedr0p 3 14 17 ([#1171](https://github.com/Radarr/Radarr/issues/1171)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Maybe fix PTP? Don't have an account, so cannot test. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  for editing quality of movie files. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Patch/onedr0p 3 13 17 ([#1166](https://github.com/Radarr/Radarr/issues/1166)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  issue where 1080p Telesyncs get tagged as 1080p Blurays. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.535 (2017-03-12)
|
||||
|
||||
### **New features**
|
||||
-  blacklist to work with movies ([#1089](https://github.com/Radarr/Radarr/issues/1089)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  README.md. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  error to include Radarr instead of Sonarr ([#1069](https://github.com/Radarr/Radarr/issues/1069)) [<a href="https://github.com/flightlevel">flightlevel</a>]
|
||||
-  wiki link for sorting and renaming ([#1045](https://github.com/Radarr/Radarr/issues/1045)) [<a href="https://github.com/aptalca">aptalca</a>]
|
||||
|
||||
### **Fixes**
|
||||
- Grammar check HelpText for CouchPotato lists ([#1142](https://github.com/Radarr/Radarr/issues/1142)) [<a href="https://github.com/James White">James White</a>]
|
||||
- Preliminary Fix for downloaded error in Wanted section. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Fixes banners when searching for new movies. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  issue where searching for new movies is not possible. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  helptext for Jackett API key ([#1121](https://github.com/Radarr/Radarr/issues/1121)) [<a href="https://github.com/Mathew Giljum">Mathew Giljum</a>]
|
||||
- Better method to obtain the folderName. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Keep the current page the same after clicking Save. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  Parsing headers that have a trailing semi-colon ([#1117](https://github.com/Radarr/Radarr/issues/1117)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- PreDB Integration. Update Library is advisable. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- QOL changes to PTP logic ([#1114](https://github.com/Radarr/Radarr/issues/1114)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  for VS for Mac. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Ammend to previous commit. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Hopefully fix all issues with unlinked movie files. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- This needs to match with the property forclient mode. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- CP list hotfix. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Incorrect check for imdbId prefix. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  regression for missing libgdiplus ([#1073](https://github.com/Radarr/Radarr/issues/1073)) [<a href="https://github.com/SWu">SWu</a>]
|
||||
- Refactor so that filteringExpressions are constructed in one place less code duplication, easier to manage moving forward. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  filters were added, but they werent being handled via the API. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Allow larger trakt lists than 500. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Restructeured readme and added a new logo asset ([#1088](https://github.com/Radarr/Radarr/issues/1088)) [<a href="https://github.com/Matthew Treadwell">Matthew Treadwell</a>]
|
||||
- Onedr0p/3 8 17 ([#1087](https://github.com/Radarr/Radarr/issues/1087)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Ensure drone factory runs on its specificed interval ([#1067](https://github.com/Radarr/Radarr/issues/1067)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  hotio's nightly docker image. ([#1084](https://github.com/Radarr/Radarr/issues/1084)) [<a href="https://github.com/Donald Webster">Donald Webster</a>]
|
||||
-  Installation, Docker and Setup Guide to new Install section and add Feathub and Wiki to Support ([#1083](https://github.com/Radarr/Radarr/issues/1083)) [<a href="https://github.com/Donald Webster">Donald Webster</a>]
|
||||
-  the parser for movies with A. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Loads only request movie first into full collection. Should fix things. ([#1046](https://github.com/Radarr/Radarr/issues/1046)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Addressing jshint warnings ([#1050](https://github.com/Radarr/Radarr/issues/1050)) [<a href="https://github.com/Bill Szeliga">Bill Szeliga</a>]
|
||||
- Correct DownloadDescisionMaker to use ImdbId, and update the ui a little. ([#1068](https://github.com/Radarr/Radarr/issues/1068)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Deluge 1.3.14 API support due to changed json-rpc checks. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Reverting a change made yesterday regarding sorting 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. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Oops -- this was a fix from the last merge - sorry. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- URLEncode the string for searching ([#1055](https://github.com/Radarr/Radarr/issues/1055)) [<a href="https://github.com/Mihai Blaga">Mihai Blaga</a>]
|
||||
-  client mode fetching.. only setPageSize when necessary. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  error with weirdly formatted audioChannelPositions on MediaInfo. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  a couple typos ([#1049](https://github.com/Radarr/Radarr/issues/1049)) [<a href="https://github.com/Greg Fitzgerald">Greg Fitzgerald</a>]
|
||||
-  tests. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/onedr0p ([#1048](https://github.com/Radarr/Radarr/issues/1048)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  all tests and even added some new ones :) ([#835](https://github.com/Radarr/Radarr/issues/835)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Fixes issue where quality settings wont save due to no pagesize. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Fixes sorting after adding movies. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  most paging issues on first load. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- /movies without pagesize or page gives back the old format. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- This seems to make it more stable. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Im not too sure why this fixes the problem but now the filterState is respected when returning from another page. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Use href instead of hostname+port. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Improve RSS parsing for movies without year. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  ReplaceGermanUmlauts method. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
|
||||
|
||||
## v0.2.0.453 (2017-03-05)
|
||||
|
||||
### **New features**
|
||||
-  new TestCase for Parser and fixed spelling error. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  FindByAlternativeTitle in MovieRepo. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  debug messages to check quality. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Needed to pass the filterType, received the filterType and handle the filterType. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  more filters to the movie editor ([#905](https://github.com/Radarr/Radarr/issues/905)) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  parsing french movies ([#899](https://github.com/Radarr/Radarr/issues/899)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
|
||||
### **Fixes**
|
||||
- Try to add year to release titles that have no year (foriegn release groups) ([#1028](https://github.com/Radarr/Radarr/issues/1028)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  Delay profiles are no longer hidden under advanced settings ([#1019](https://github.com/Radarr/Radarr/issues/1019)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Revert "Added FindByAlternativeTitle in MovieRepo." [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Use http request builder (aided by onedrop) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Improve indexer health check messages ([#1015](https://github.com/Radarr/Radarr/issues/1015)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Clean RSS feed before detecting type ([#1014](https://github.com/Radarr/Radarr/issues/1014)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Store titleSlug in tags for exclusions and always use TMDBID. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Also use TMDBID on list sync. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Always check exclusions with tmdbid. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- An updated radarrAPI has been deployed --> this commit makes trakt authentication ready to be merged to the develop branch. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Fully functional traktAuthentication using api.couchpota.to with comments for when updated RadarrAPI is deployed. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  error with null dates. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/more updates ([#1009](https://github.com/Radarr/Radarr/issues/1009)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Revert.. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  "wrong" quality being detected. Scan will be slower though. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  for wrong qualities showing up. Will be slower to load though. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Patch/onedr0p 3 4 2017 ([#1006](https://github.com/Radarr/Radarr/issues/1006)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Respect the page when initializing the layout. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Patch/onedr0p updates ([#998](https://github.com/Radarr/Radarr/issues/998)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- The movie was not being printed correctly, and i believe this was also causing movies to be added when they shouldnt have been... [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Clean up the fetching on loading of MovieEditor and MovieIndex once and for all. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- I dont know why i was doing this inside the for loop... It did not scale well ! fixed. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Use clone so that we only detect empty collection when collectio is empty.. not when current filter is empty but collectionis not. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- I believe these are old code that is not needed since pagination.. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Default Wanted and Cutoff to be 50 movies per page, added filtering options to Cutoff and a Search all ([#984](https://github.com/Radarr/Radarr/issues/984)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Empty string case should not be only for the contains case. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Reset filters on save.. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Possible fix for Custom script ([#973](https://github.com/Radarr/Radarr/issues/973)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Hotfix when importing movie ([#971](https://github.com/Radarr/Radarr/issues/971)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  infinite loop. Added default destination test when adding client ([#968](https://github.com/Radarr/Radarr/issues/968)) [<a href="https://github.com/Marcelo Castagna">Marcelo Castagna</a>]
|
||||
- Date added in Movie List & Possible Fix for Importing Movies. ([#969](https://github.com/Radarr/Radarr/issues/969)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Ensure collection is synced before opening movieDetails. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Revert some changes -- use FullCollection (maybe just for now) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Just show imdbid or tmdbid for now in exclusions. [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- MovieIndexPage Stability + MovieEditor fix ([#925](https://github.com/Radarr/Radarr/issues/925)) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Patch/galileo fixes ([#951](https://github.com/Radarr/Radarr/issues/951)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/updates onedr0p ([#946](https://github.com/Radarr/Radarr/issues/946)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  problem with TMDb list when Year is null, Revert using UrlPathEncode on newznab requests ([#937](https://github.com/Radarr/Radarr/issues/937)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Expose more information to the Webhook notification ([#935](https://github.com/Radarr/Radarr/issues/935)) [<a href="https://github.com/Ross Valler">Ross Valler</a>]
|
||||
- Fix/implement Webhook notifications ([#901](https://github.com/Radarr/Radarr/issues/901)) [<a href="https://github.com/Ross Valler">Ross Valler</a>]
|
||||
-  remux 1080p and 2160p as qualities ([#900](https://github.com/Radarr/Radarr/issues/900)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- NZBGet delete:scan treated as failure ([#898](https://github.com/Radarr/Radarr/issues/898)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Small changes. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Hotfix. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- List sync with removal ([#656](https://github.com/Radarr/Radarr/issues/656)) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  the footer to show correct information and refresh when FullCollection changes ([#893](https://github.com/Radarr/Radarr/issues/893)) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Increase fullCollection page size, update Refresh Library command. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Patch/updates ([#887](https://github.com/Radarr/Radarr/issues/887)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  poster placeholder height on small screens ([#883](https://github.com/Radarr/Radarr/issues/883)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
- Small UI fixes ([#882](https://github.com/Radarr/Radarr/issues/882)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
- Me = idiot. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  an issue where an unloaded movie could case linking to fail. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Maybe fix issue with imported files not being linked to the movie? [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Search is now fixed too. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Should fix most issues with paging. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  first steps of paging to movie editor. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- HDBits prefer/require internal release ([#584](https://github.com/Radarr/Radarr/issues/584)) ([#881](https://github.com/Radarr/Radarr/issues/881)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Ignore Deleted Movies ([#755](https://github.com/Radarr/Radarr/issues/755)) ([#879](https://github.com/Radarr/Radarr/issues/879)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- First fixes for Movie Editor. Testing to see if this approach could work. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  missing showing downloaded instead. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  issue where details page wont load. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Paging for movies :) ([#861](https://github.com/Radarr/Radarr/issues/861)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Bug fixes ([#874](https://github.com/Radarr/Radarr/issues/874)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- The Search All Missing button ([#860](https://github.com/Radarr/Radarr/issues/860)) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Cleanup min availability ([#846](https://github.com/Radarr/Radarr/issues/846)) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Some minor cleanup + changed filter on wanted/missing ([#845](https://github.com/Radarr/Radarr/issues/845)) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
- Min availability ([#816](https://github.com/Radarr/Radarr/issues/816)) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  NZB Station for Synology ([#841](https://github.com/Radarr/Radarr/issues/841)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/filter trakt ([#838](https://github.com/Radarr/Radarr/issues/838)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  language parsing of movies with language in movie name. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.375 (2017-02-22)
|
||||
|
||||
### **New features**
|
||||
-  .travis.yml. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  notification logos ([#804](https://github.com/Radarr/Radarr/issues/804)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  ISSUE_TEMPLATE.md. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  PULL_REQUEST_TEMPLATE.md. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  dl-clients ([#732](https://github.com/Radarr/Radarr/issues/732)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- NetImport - Do not allow TV Series / Mini-Series (works with IMDb) [#699](https://github.com/Radarr/Radarr/issues/699) ([#727](https://github.com/Radarr/Radarr/issues/727)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  ISSUE_TEMPLATE.md. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  sort options to match UI ([#707](https://github.com/Radarr/Radarr/issues/707)) [<a href="https://github.com/zductiv">zductiv</a>]
|
||||
-  test for ! [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  parser tests. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
### **Fixes**
|
||||
- Patch/bulk import tests ([#833](https://github.com/Radarr/Radarr/issues/833)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Patch/bulk import qol ([#785](https://github.com/Radarr/Radarr/issues/785)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- URL Encode for newznab query strings, closes [#818](https://github.com/Radarr/Radarr/issues/818) ([#819](https://github.com/Radarr/Radarr/issues/819)) [<a href="https://github.com/Mihai Blaga">Mihai Blaga</a>]
|
||||
- Rename Sonarr to Radarr in DownloadStation client ([#812](https://github.com/Radarr/Radarr/issues/812)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Fixes error message for MovieExistsValidator to state the movie doesn't exist ([#723](https://github.com/Radarr/Radarr/issues/723)) ([#808](https://github.com/Radarr/Radarr/issues/808)) [<a href="https://github.com/Ryan Matthews">Ryan Matthews</a>]
|
||||
- Set PROWL application to Radarr ([#770](https://github.com/Radarr/Radarr/issues/770)) ([#807](https://github.com/Radarr/Radarr/issues/807)) [<a href="https://github.com/Ryan Matthews">Ryan Matthews</a>]
|
||||
- TMDb Lists should be working now :) ([#775](https://github.com/Radarr/Radarr/issues/775)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Roll back some code on Net Import ([#772](https://github.com/Radarr/Radarr/issues/772)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Check to see if output path is right when DownloadClient.Test is invoked ([#768](https://github.com/Radarr/Radarr/issues/768)) [<a href="https://github.com/Marcelo Castagna">Marcelo Castagna</a>]
|
||||
- TMDb Filtering Options: Rating, Min Votes, Min Vote Ave, Original Language, TMDb Genre Ids (CSV), ([#765](https://github.com/Radarr/Radarr/issues/765)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Small consistancy updates to PTP and AwesomeHD ([#758](https://github.com/Radarr/Radarr/issues/758)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/onedr0p ([#757](https://github.com/Radarr/Radarr/issues/757)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Handle download data diskstation ([#744](https://github.com/Radarr/Radarr/issues/744)) [<a href="https://github.com/Marcelo Castagna">Marcelo Castagna</a>]
|
||||
- When refreshing movie, refresh Files tab. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Feature/Add TMDb Functionality ([#739](https://github.com/Radarr/Radarr/issues/739)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  downloaded quality column to movie editor ([#738](https://github.com/Radarr/Radarr/issues/738)) [<a href="https://github.com/zductiv">zductiv</a>]
|
||||
- Clean up Trakt a little ([#735](https://github.com/Radarr/Radarr/issues/735)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  Synology Download Station ([#725](https://github.com/Radarr/Radarr/issues/725)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  pending release table. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Hardcoded .DKSubs. ([#726](https://github.com/Radarr/Radarr/issues/726)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/re add ghost migrations ([#724](https://github.com/Radarr/Radarr/issues/724)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/onedr0p ([#716](https://github.com/Radarr/Radarr/issues/716)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Increase timeout when waiting for rTorrent to finish adding torrent ([#721](https://github.com/Radarr/Radarr/issues/721)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
-  RescanMovie command for single movie. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Hopefully fixes a lot of null reference bugs in BulkImport. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Should fix blacklist items disappearing. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  manual import for when downloaded movies are in a folder. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Search all missing movie works - missing tab only ([#710](https://github.com/Radarr/Radarr/issues/710)) [<a href="https://github.com/zductiv">zductiv</a>]
|
||||
- Limit TMDb requests when importing via IMDBid ([#703](https://github.com/Radarr/Radarr/issues/703)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  parsing with lower bluray qualities. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Fixes issue with movies with same name but different years being downloaded. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  a few parser issues. Also added some tests. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Cutoff tab actually working now. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  trakt links for movies (like sonarr for shows) ([#690](https://github.com/Radarr/Radarr/issues/690)) [<a href="https://github.com/geogolem">geogolem</a>]
|
||||
-  Sorting In Wanted and Cutoff ([#693](https://github.com/Radarr/Radarr/issues/693)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Pass at seeing if this works on linux now ([#692](https://github.com/Radarr/Radarr/issues/692)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Small UI changes ([#691](https://github.com/Radarr/Radarr/issues/691)) [<a href="https://github.com/zductiv">zductiv</a>]
|
||||
-  required flag for PTP ([#688](https://github.com/Radarr/Radarr/issues/688)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Wanted & Missing ([#687](https://github.com/Radarr/Radarr/issues/687)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- * Make Missing/Wanted Work again ([#686](https://github.com/Radarr/Radarr/issues/686)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  MovieMissingModule failed while processing [MovieDownloadedEvent] [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- UI Enhancements for Manual Import ([#681](https://github.com/Radarr/Radarr/issues/681)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- May be fix loading view? Idk. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Display loading view when changing page size. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  ordering in PTP, should prefer GP releases ([#667](https://github.com/Radarr/Radarr/issues/667)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Patch/onedr0p updates ([#664](https://github.com/Radarr/Radarr/issues/664)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Make Movie Title and Status sortable on Wanted tab ([#662](https://github.com/Radarr/Radarr/issues/662)) [<a href="https://github.com/schumi2004">schumi2004</a>]
|
||||
-  paging breaking in bulk import. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Bulk Import. ([#583](https://github.com/Radarr/Radarr/issues/583)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.299 (2017-02-07)
|
||||
|
||||
### **New features**
|
||||
-  notif list warning when importing from a list ([#648](https://github.com/Radarr/Radarr/issues/648)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
|
||||
### **Fixes**
|
||||
- Wait 5 seconds before getting the next 35 movies from TMDb using X-RateLimit-Remaining ([#647](https://github.com/Radarr/Radarr/issues/647)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Correct the Kickass migration ([#649](https://github.com/Radarr/Radarr/issues/649)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  movies not showing up in Queue when downloading ([#640](https://github.com/Radarr/Radarr/issues/640)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  Movie link in history tab ([#637](https://github.com/Radarr/Radarr/issues/637)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Clean up download clients to use radarr as label, fix hoduken, and blackhole. ([#635](https://github.com/Radarr/Radarr/issues/635)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Use Movie Name-TmdbId for slug, update toUrlSlug ([#629](https://github.com/Radarr/Radarr/issues/629)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Removed Wombles and Kickass, updated torrentpotato and torznab ([#625](https://github.com/Radarr/Radarr/issues/625)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Various ui text fixes ([#620](https://github.com/Radarr/Radarr/issues/620)) [<a href="https://github.com/Abzie">Abzie</a>]
|
||||
- Delay Profile: Fix for when preferred words is null. ([#618](https://github.com/Radarr/Radarr/issues/618)) [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
|
||||
|
||||
## v0.2.0.288 (2017-02-05)
|
||||
|
||||
### **New features**
|
||||
-  'Case Insensitive.' to preferred tags info to help-inline. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  more options to trakt, popular movies, upcoming, anticipated etc.. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
|
||||
### **Fixes**
|
||||
- Preferredcount -> preferredCount. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Delay Profile: Require preferred word to skip delay. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Delay Profile: Delay for at least 1 preferred word. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Delay Profile: Upgradable Check Fix. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
-  ical ics file ([#603](https://github.com/Radarr/Radarr/issues/603)) [<a href="https://github.com/schumi2004">schumi2004</a>]
|
||||
-  issue where quality weight was mapped wrongly. Fixes [#597](https://github.com/Radarr/Radarr/issues/597) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Runtime error fix. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  runtime issues. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  glaringly obvious mistake that caused RSS Sync to fail. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  warning for docker users when switching branch. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  plain "ES" audioProfile. ([#569](https://github.com/Radarr/Radarr/issues/569)) [<a href="https://github.com/Chris Allen">Chris Allen</a>]
|
||||
-  delay specification when delay is not set to zero. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Use shorter format Profile string. ([#561](https://github.com/Radarr/Radarr/issues/561)) [<a href="https://github.com/Chris Allen">Chris Allen</a>]
|
||||
- Use movieFile instead of episodeFile. ([#560](https://github.com/Radarr/Radarr/issues/560)) [<a href="https://github.com/Chris Allen">Chris Allen</a>]
|
||||
-  expanded DTS audio codecs to FileNameBuilder and fix up Atmos TrueHD audioCodec string. ([#559](https://github.com/Radarr/Radarr/issues/559)) [<a href="https://github.com/Chris Allen">Chris Allen</a>]
|
||||
- Don't display mapped movies in import list. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  Delete modal when adding movie. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Delete files now works. Fixes [#127](https://github.com/Radarr/Radarr/issues/127) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- First pass regarding delete. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  error for movies with less than 4 characters. Fixes [#507](https://github.com/Radarr/Radarr/issues/507) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
|
||||
|
||||
## v0.2.0.267 (2017-01-30)
|
||||
|
||||
### **New features**
|
||||
- Updates to ptp, and using caching for cookie. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  the regex in Parser, Add workprint and telesync, change R5 to regional allow for R[0-9]{1}, changed the weights. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  weights. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  new qualities, added new qualities to profile class. Left to do: write migration, and tests. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  Fetch List button style. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  options for watched, and watchlist, and customlist to trakt. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  HDBits to work with Radarr. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  taskscheduler when config is saved with netimportsynccommand. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  Synology Indexer For Movies ([#486](https://github.com/Radarr/Radarr/issues/486)) [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
-  option to specify preferred words in quality profile. ([#462](https://github.com/Radarr/Radarr/issues/462)) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  GeneralViewTemplate.hbs. [<a href="https://github.com/Jordan">Jordan</a>]
|
||||
-  lang in UI to what profile / lang they choose when they add a movie. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  JoinProxy.cs. [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  Plex Movie Sections. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
-  slack for movies. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
-  README.md. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  to favicon section, according to ([#416](https://github.com/Radarr/Radarr/issues/416)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  default sort order ([#429](https://github.com/Radarr/Radarr/issues/429)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  ico files. [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  UI logos. [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  localstorage key prefixes. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  Forms Auth Cookie. Fixes [#285](https://github.com/Radarr/Radarr/issues/285) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Files tab when movie renamed. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  Rename Preview to support folder renaming. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Net Import UI Updates. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  trakt user list importing. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  easy to use List Selection for manual import use later. The place where this resides will change. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Base URL. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  couchpotato, and added a test. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  README.md. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  MovieModule. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  ISSUE_TEMPLATE.md. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  sizing information in settings tab. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  height of posters to accomodate additional labels. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  SkyHookProxy.cs. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Test Files for AddPaused to NZBGET. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
-  Upgraded SQLite binares for macOS. [<a href="https://github.com/Keivan">Keivan</a>]
|
||||
-  Upgraded SQLite binaries for Windows (3.16.0) [<a href="https://github.com/Keivan Beigi">Keivan Beigi</a>]
|
||||
-  website and donation links. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Scheduled Refresh Series to Refresh Movie. Fixes [#301](https://github.com/Radarr/Radarr/issues/301) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  movie studio to movie details page ([#262](https://github.com/Radarr/Radarr/issues/262)) [<a href="https://github.com/Vlad Ilies">Vlad Ilies</a>]
|
||||
-  NewznabRequestGenerator.cs. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  README.md. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  trailer link to movie links ([#255](https://github.com/Radarr/Radarr/issues/255)) ([#282](https://github.com/Radarr/Radarr/issues/282)) [<a href="https://github.com/Vlad Ilies">Vlad Ilies</a>]
|
||||
-  HttpNetImporterBase. Still needs work to correctly handle failures. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  some abstraction for settings. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Qualties to Settings. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Updates and compile-able. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  README.md. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  .gitignore and remove Thumbs.db files ([#276](https://github.com/Radarr/Radarr/issues/276)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  README.md ([#271](https://github.com/Radarr/Radarr/issues/271)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  README.md. [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  README.md. [<a href="https://github.com/hotio">hotio</a>]
|
||||
- Updates. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
|
||||
### **Fixes**
|
||||
-  importfromlist abck. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  the filter modes on the movie list xD. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  issues with different languages than english when adding alternative titles. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Use username, password and passkey for passthepopcorn. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Migration migraine-tion. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Ensure qualities don't overflow profile card. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Migration. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Migration. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Make DVDR not unlimited. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Set Drone Factory Interval default to 0 ([#515](https://github.com/Radarr/Radarr/issues/515)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Make year nullable for trakt. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Make year nullable, and rmember the profileid. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  Proper port validation for download clients and connections. [<a href="https://github.com/Mark McDowall">Mark McDowall</a>]
|
||||
- Make NetImport sync interval work (needs some testing) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Allow Duplicate Preferred Words ([#484](https://github.com/Radarr/Radarr/issues/484)) [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
-  for movies without an imdbid. Fixes 176. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Quality of an existing movie file can now be edited. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  recognition of 4k Movies upon import. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- This should hopefully fix the error that decisions were not ordered correctly and therefore just the first release was grabbed. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Remove confusing warning about file not being loaded. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  movie year to NotificationService ([#496](https://github.com/Radarr/Radarr/issues/496)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Revert "Merge branch 'rename-existing-folder' into develop" [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Revert "Add movie year to NotificationService ([#489](https://github.com/Radarr/Radarr/issues/489))" [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Revert "Ensure the movie isn't delete when the folder isn't renamed ([#491](https://github.com/Radarr/Radarr/issues/491))" [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Ensure the movie isn't delete when the folder isn't renamed ([#491](https://github.com/Radarr/Radarr/issues/491)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  movie year to NotificationService ([#489](https://github.com/Radarr/Radarr/issues/489)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Kodi Update Fix: OldFiles -> OldMovieFiles ([#483](https://github.com/Radarr/Radarr/issues/483)) [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- More Notification Updates ([#482](https://github.com/Radarr/Radarr/issues/482)) [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Moviefile, what movie file? ([#466](https://github.com/Radarr/Radarr/issues/466)) [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Remove mofilefile id for now ([#464](https://github.com/Radarr/Radarr/issues/464)) [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Download Movie Quality & Formatting. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Custom Script Fix: Parse movie not episode. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Fixes issue [#447](https://github.com/Radarr/Radarr/issues/447) (Notification Icon for Join) [<a href="https://github.com/hotio">hotio</a>]
|
||||
- Only use internal for RSS Sync. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Include only internal for AHD. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  new rss-sync threshold. [<a href="https://github.com/schumi2004">schumi2004</a>]
|
||||
- "fixed" error message. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  link to Activity -> History Tab ([#408](https://github.com/Radarr/Radarr/issues/408)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Allow renaming of movies that don't have an "Edition" ([#432](https://github.com/Radarr/Radarr/issues/432)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- [#292](https://github.com/Radarr/Radarr/issues/292) - Allow longer threshold for RSS Sync ([#428](https://github.com/Radarr/Radarr/issues/428)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  year to search ([#425](https://github.com/Radarr/Radarr/issues/425)) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Initial Notification Updates and Support ([#401](https://github.com/Radarr/Radarr/issues/401)) [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Fixes an issue where movies with (year) at the beginning were recognized with a title of "(" [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Blind fix to support seperator in movie tags. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  issue with certain audio streams. Should fix [#404](https://github.com/Radarr/Radarr/issues/404) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  {Tags} to renaming options. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  when libgdiplus isn't present. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Proper ico and favicon. [<a href="https://github.com/hotio">hotio</a>]
|
||||
-  issue where monitored movies were still downloaded. Fixes [#326](https://github.com/Radarr/Radarr/issues/326) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Fixes issue when multiple audio channels are present. Fixes [#315](https://github.com/Radarr/Radarr/issues/315) Fixes [#294](https://github.com/Radarr/Radarr/issues/294) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  duplicate key prefixing. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Prefix localstorage keys with "Radarr" [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Optimized logo ([#375](https://github.com/Radarr/Radarr/issues/375)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
- Set update interval to 30 minutes if on nightly. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Prefix Keys with "Radarr" [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  more filter options to movie list. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Search selected button in wanted tab works. [<a href="https://github.com/Vlad Ilies">Vlad Ilies</a>]
|
||||
-  [#228](https://github.com/Radarr/Radarr/issues/228) - Fix Drone Factory interval input not saving. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Remove old folder and all contents. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Movie reference properly updates UI now. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Be more proper about Ensuring the folder exists. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Undo unecessary changes. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Move folder on rename; event doesn't fire yet. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Only show "Display Existing Movies" toggle after selecting a folder. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Clean up settings UI. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Manual Import works now! [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Only wanted is default for CP. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Manual importing almost done. Needs fixing for mapping movies. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Nullable all the fields.. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Rephrase wording. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Monitored to false for movies already downloaded on CP. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Allow null value for seed time. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  basic ui of manual import. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  importing for StevenLu. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  StevenLu to csproj. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- First pass at ui for manually importing from lists. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  import from http://movies.stevenlu.com/ [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Movies can now be added monitored or unmonitored. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Ability to set RootFolderPath for Net Import List. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  netimport search and add NetImportSyncCommand. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Remove duplicate code. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  movies being clobbered when a new list is sent thru. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Implement NetImportSearchService. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  urlBase option to CP settings. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  media info parsing of multiple audio channels. Fixes [#315](https://github.com/Radarr/Radarr/issues/315) Fixes [#294](https://github.com/Radarr/Radarr/issues/294) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  styling. Fixed definitions not being returned. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Rethought about where certain things are stored. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  stuff regarding the ordering of Fields. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  migration to include ConfigContract and EnableAuto. Also fixed redirects on lists. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Second UI Pass, Testing now works and other little things. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  up presets. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Make presets work for RSS Import :) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  CP list class. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Migration migrainetion. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Couchpotato API classes. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- WIP UI Update for adding lists. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Corruped Media Cover Images. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Should fix 4K releases not getting parsed. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Adds 'Movie Title, The' filename option ([#359](https://github.com/Radarr/Radarr/issues/359)) [<a href="https://github.com/Krystian Charubin">Krystian Charubin</a>]
|
||||
-  issue when movie file is null. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Should fix upgrading of existing movie files. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  tests for 4K quality. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Hopefully a fix for corrupt media covers. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  blacklist being ignored by download decision maker. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  helptext to nzbget "add paused" settings. ([#363](https://github.com/Radarr/Radarr/issues/363)) [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
-  year to quick search results. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  issue with reimporting on movie fresh ([#357](https://github.com/Radarr/Radarr/issues/357)) [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  MediaCoversUpdatedEvent broadcast. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Bug fix for 15 movie wanted tab ([#348](https://github.com/Radarr/Radarr/issues/348)) [<a href="https://github.com/Vlad Ilies">Vlad Ilies</a>]
|
||||
- Blacklisting works now. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  pushover priority values. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Hopefully fix issue when importing. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  download status to poster view. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  IMDb ID to file naming. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  build. [<a href="https://github.com/Vlad Ilies">Vlad Ilies</a>]
|
||||
- Basic implementation of the wanted tab (#31) [<a href="https://github.com/Vlad Ilies">Vlad Ilies</a>]
|
||||
- Revert DownloadedMovieScanCommand to DownloadedEpisodesScanCommand. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Turn off scene mapping task [#329](https://github.com/Radarr/Radarr/issues/329), update TaskManager to use 'DownloadedMovieScanCommand' [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Revert "Sonarr/sqlite updates" [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  "Add Paused" option for NZBGET downloader. [<a href="https://github.com/vertigo235">vertigo235</a>]
|
||||
- Upgraded System.Data.SQLite to 1.0.104.0. [<a href="https://github.com/Keivan Beigi">Keivan Beigi</a>]
|
||||
- Revert "Upgraded System.Data.SQLite to 1.0.104.0" [<a href="https://github.com/Keivan Beigi">Keivan Beigi</a>]
|
||||
- Remove series references. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Hopefully fix download ordering. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Maybe this will solve the error. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  Issue when adding some movies. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Hopefully fix RSSSync. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  publish date [#239](https://github.com/Radarr/Radarr/issues/239) [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  Issue #91 - "Search All Missing" wording. [<a href="https://github.com/Aenima99x">Aenima99x</a>]
|
||||
-  Support for changing file date to either cinema or physical release. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  for movies with . in title when importing them. Fixes [#268](https://github.com/Radarr/Radarr/issues/268) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Remove - as replacement for : [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  only one movie showing. Fix more button not showing up. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Audiochannels just being added together. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Clean up rename preview & organize. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Disambiguate Movie from Episode Renaming. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
-  for hardcoded subs regex. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  Calendar Tab back. Fixes #32. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Removed duplicate PublishDate. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
-  support section to README ([#281](https://github.com/Radarr/Radarr/issues/281)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
- First pass at hiding existing movies upon import. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- 95% done with hiding existing movies. [<a href="https://github.com/Tim Turner">Tim Turner</a>]
|
||||
- Basis of UI Update. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  base for netimport api. Still nothing on the UI side. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Imdbid parsing works now from url. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Big Abstraction for IMDBWatchlist -> RSSImport (With a test) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Whoops, only parse title once. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Reworked README ([#280](https://github.com/Radarr/Radarr/issues/280)) [<a href="https://github.com/hotio">hotio</a>]
|
||||
- Move Travis builds to container-based infrastructure ([#273](https://github.com/Radarr/Radarr/issues/273)) [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Adding only original title is now allowed. Fixes [#272](https://github.com/Radarr/Radarr/issues/272) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  for special characters when searching with title in Newznab. Fixes #97. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
-  {Original Title} to FileNameBuilder. Fixes [#103](https://github.com/Radarr/Radarr/issues/103) [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Release Group should now be available for renamer to use. [<a href="https://github.com/Leonardo Galli">Leonardo Galli</a>]
|
||||
- Cleanup README. [<a href="https://github.com/Mitchell Cash">Mitchell Cash</a>]
|
||||
- Few changes. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
- Initial autoimporter commit. [<a href="https://github.com/Devin Buhl">Devin Buhl</a>]
|
||||
|
||||
|
||||
BIN
Logo/256.png
|
Before Width: | Height: | Size: 10 KiB After Width: | Height: | Size: 28 KiB |
33
Logo/dottrace.svg
Normal file
@@ -0,0 +1,33 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!-- Generator: Adobe Illustrator 19.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
||||
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
||||
width="70px" height="70px" viewBox="0 0 70 70" style="enable-background:new 0 0 70 70;" xml:space="preserve">
|
||||
<g>
|
||||
<g>
|
||||
<linearGradient id="SVGID_1_" gradientUnits="userSpaceOnUse" x1="-1.3318" y1="43.7371" x2="67.0419" y2="26.0967">
|
||||
<stop offset="0.1237" style="stop-color:#7866FF"/>
|
||||
<stop offset="0.5376" style="stop-color:#FE2EB6"/>
|
||||
<stop offset="0.8548" style="stop-color:#FD0486"/>
|
||||
</linearGradient>
|
||||
<polygon style="fill:url(#SVGID_1_);" points="67.3,16 43.7,0 0,31.1 11.1,70 58.9,60.3 "/>
|
||||
<linearGradient id="SVGID_2_" gradientUnits="userSpaceOnUse" x1="45.9148" y1="38.9098" x2="67.6577" y2="9.0989">
|
||||
<stop offset="0.1237" style="stop-color:#FF0080"/>
|
||||
<stop offset="0.2587" style="stop-color:#FE0385"/>
|
||||
<stop offset="0.4109" style="stop-color:#FA0C92"/>
|
||||
<stop offset="0.5713" style="stop-color:#F41BA9"/>
|
||||
<stop offset="0.7363" style="stop-color:#EB2FC8"/>
|
||||
<stop offset="0.8656" style="stop-color:#E343E6"/>
|
||||
</linearGradient>
|
||||
<polygon style="fill:url(#SVGID_2_);" points="67.3,16 43.7,0 38,15.7 38,47.8 70,47.8 "/>
|
||||
</g>
|
||||
<g>
|
||||
<rect x="13.4" y="13.4" style="fill:#000000;" width="43.2" height="43.2"/>
|
||||
<rect x="17.4" y="48.5" style="fill:#FFFFFF;" width="16.2" height="2.7"/>
|
||||
<g>
|
||||
<path style="fill:#FFFFFF;" d="M17.4,19.1h6.9c5.6,0,9.5,3.8,9.5,8.9V28c0,5-3.9,8.9-9.5,8.9h-6.9V19.1z M21.4,22.7v10.7h3
|
||||
c3.2,0,5.4-2.2,5.4-5.3V28c0-3.2-2.2-5.4-5.4-5.4H21.4z"/>
|
||||
<polygon style="fill:#FFFFFF;" points="40.3,22.7 34.9,22.7 34.9,19.1 49.6,19.1 49.6,22.7 44.2,22.7 44.2,37 40.3,37 "/>
|
||||
</g>
|
||||
</g>
|
||||
</g>
|
||||
</svg>
|
||||
|
After Width: | Height: | Size: 1.8 KiB |
66
Logo/jetbrains.svg
Normal file
@@ -0,0 +1,66 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!-- Generator: Adobe Illustrator 19.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
||||
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
||||
width="120.1px" height="130.2px" viewBox="0 0 120.1 130.2" style="enable-background:new 0 0 120.1 130.2;" xml:space="preserve"
|
||||
>
|
||||
<g>
|
||||
<linearGradient id="XMLID_2_" gradientUnits="userSpaceOnUse" x1="31.8412" y1="120.5578" x2="110.2402" y2="73.24">
|
||||
<stop offset="0" style="stop-color:#FCEE39"/>
|
||||
<stop offset="1" style="stop-color:#F37B3D"/>
|
||||
</linearGradient>
|
||||
<path id="XMLID_3041_" style="fill:url(#XMLID_2_);" d="M118.6,71.8c0.9-0.8,1.4-1.9,1.5-3.2c0.1-2.6-1.8-4.7-4.4-4.9
|
||||
c-1.2-0.1-2.4,0.4-3.3,1.1l0,0l-83.8,45.9c-1.9,0.8-3.6,2.2-4.7,4.1c-2.9,4.8-1.3,11,3.6,13.9c3.4,2,7.5,1.8,10.7-0.2l0,0l0,0
|
||||
c0.2-0.2,0.5-0.3,0.7-0.5l78-54.8C117.3,72.9,118.4,72.1,118.6,71.8L118.6,71.8L118.6,71.8z"/>
|
||||
<linearGradient id="XMLID_3_" gradientUnits="userSpaceOnUse" x1="48.3607" y1="6.9083" x2="119.9179" y2="69.5546">
|
||||
<stop offset="0" style="stop-color:#EF5A6B"/>
|
||||
<stop offset="0.57" style="stop-color:#F26F4E"/>
|
||||
<stop offset="1" style="stop-color:#F37B3D"/>
|
||||
</linearGradient>
|
||||
<path id="XMLID_3049_" style="fill:url(#XMLID_3_);" d="M118.8,65.1L118.8,65.1L55,2.5C53.6,1,51.6,0,49.3,0
|
||||
c-4.3,0-7.7,3.5-7.7,7.7v0c0,2.1,0.8,3.9,2.1,5.3l0,0l0,0c0.4,0.4,0.8,0.7,1.2,1l67.4,57.7l0,0c0.8,0.7,1.8,1.2,3,1.3
|
||||
c2.6,0.1,4.7-1.8,4.9-4.4C120.2,67.3,119.7,66,118.8,65.1z"/>
|
||||
<linearGradient id="XMLID_4_" gradientUnits="userSpaceOnUse" x1="52.9467" y1="63.6407" x2="10.5379" y2="37.1562">
|
||||
<stop offset="0" style="stop-color:#7C59A4"/>
|
||||
<stop offset="0.3852" style="stop-color:#AF4C92"/>
|
||||
<stop offset="0.7654" style="stop-color:#DC4183"/>
|
||||
<stop offset="0.957" style="stop-color:#ED3D7D"/>
|
||||
</linearGradient>
|
||||
<path id="XMLID_3042_" style="fill:url(#XMLID_4_);" d="M57.1,59.5C57,59.5,17.7,28.5,16.9,28l0,0l0,0c-0.6-0.3-1.2-0.6-1.8-0.9
|
||||
c-5.8-2.2-12.2,0.8-14.4,6.6c-1.9,5.1,0.2,10.7,4.6,13.4l0,0l0,0C6,47.5,6.6,47.8,7.3,48c0.4,0.2,45.4,18.8,45.4,18.8l0,0
|
||||
c1.8,0.8,3.9,0.3,5.1-1.2C59.3,63.7,59,61,57.1,59.5z"/>
|
||||
<linearGradient id="XMLID_5_" gradientUnits="userSpaceOnUse" x1="52.1736" y1="3.7019" x2="10.7706" y2="37.8971">
|
||||
<stop offset="0" style="stop-color:#EF5A6B"/>
|
||||
<stop offset="0.364" style="stop-color:#EE4E72"/>
|
||||
<stop offset="1" style="stop-color:#ED3D7D"/>
|
||||
</linearGradient>
|
||||
<path id="XMLID_3057_" style="fill:url(#XMLID_5_);" d="M49.3,0c-1.7,0-3.3,0.6-4.6,1.5L4.9,28.3c-0.1,0.1-0.2,0.1-0.2,0.2l-0.1,0
|
||||
l0,0c-1.7,1.2-3.1,3-3.9,5.1C-1.5,39.4,1.5,45.9,7.3,48c3.6,1.4,7.5,0.7,10.4-1.4l0,0l0,0c0.7-0.5,1.3-1,1.8-1.6l34.6-31.2l0,0
|
||||
c1.8-1.4,3-3.6,3-6.1v0C57.1,3.5,53.6,0,49.3,0z"/>
|
||||
<g id="XMLID_3008_">
|
||||
<rect id="XMLID_3033_" x="34.6" y="37.4" style="fill:#000000;" width="51" height="51"/>
|
||||
<rect id="XMLID_3032_" x="39" y="78.8" style="fill:#FFFFFF;" width="19.1" height="3.2"/>
|
||||
<g id="XMLID_3009_">
|
||||
<path id="XMLID_3030_" style="fill:#FFFFFF;" d="M38.8,50.8l1.5-1.4c0.4,0.5,0.8,0.8,1.3,0.8c0.6,0,0.9-0.4,0.9-1.2l0-5.3l2.3,0
|
||||
l0,5.3c0,1-0.3,1.8-0.8,2.3c-0.5,0.5-1.3,0.8-2.3,0.8C40.2,52.2,39.4,51.6,38.8,50.8z"/>
|
||||
<path id="XMLID_3028_" style="fill:#FFFFFF;" d="M45.3,43.8l6.7,0v1.9l-4.4,0V47l4,0l0,1.8l-4,0l0,1.3l4.5,0l0,2l-6.7,0
|
||||
L45.3,43.8z"/>
|
||||
<path id="XMLID_3026_" style="fill:#FFFFFF;" d="M55,45.8l-2.5,0l0-2l7.3,0l0,2l-2.5,0l0,6.3l-2.3,0L55,45.8z"/>
|
||||
<path id="XMLID_3022_" style="fill:#FFFFFF;" d="M39,54l4.3,0c1,0,1.8,0.3,2.3,0.7c0.3,0.3,0.5,0.8,0.5,1.4v0
|
||||
c0,1-0.5,1.5-1.3,1.9c1,0.3,1.6,0.9,1.6,2v0c0,1.4-1.2,2.3-3.1,2.3l-4.3,0L39,54z M43.8,56.6c0-0.5-0.4-0.7-1-0.7l-1.5,0l0,1.5
|
||||
l1.4,0C43.4,57.3,43.8,57.1,43.8,56.6L43.8,56.6z M43,59l-1.8,0l0,1.5H43c0.7,0,1.1-0.3,1.1-0.8v0C44.1,59.2,43.7,59,43,59z"/>
|
||||
<path id="XMLID_3019_" style="fill:#FFFFFF;" d="M46.8,54l3.9,0c1.3,0,2.1,0.3,2.7,0.9c0.5,0.5,0.7,1.1,0.7,1.9v0
|
||||
c0,1.3-0.7,2.1-1.7,2.6l2,2.9l-2.6,0l-1.7-2.5h-1l0,2.5l-2.3,0L46.8,54z M50.6,58c0.8,0,1.2-0.4,1.2-1v0c0-0.7-0.5-1-1.2-1
|
||||
l-1.5,0v2H50.6z"/>
|
||||
<path id="XMLID_3016_" style="fill:#FFFFFF;" d="M56.8,54l2.2,0l3.5,8.4l-2.5,0l-0.6-1.5l-3.2,0l-0.6,1.5l-2.4,0L56.8,54z
|
||||
M58.8,59l-0.9-2.3L57,59L58.8,59z"/>
|
||||
<path id="XMLID_3014_" style="fill:#FFFFFF;" d="M62.8,54l2.3,0l0,8.3l-2.3,0L62.8,54z"/>
|
||||
<path id="XMLID_3012_" style="fill:#FFFFFF;" d="M65.7,54l2.1,0l3.4,4.4l0-4.4l2.3,0l0,8.3l-2,0L68,57.8l0,4.6l-2.3,0L65.7,54z"
|
||||
/>
|
||||
<path id="XMLID_3010_" style="fill:#FFFFFF;" d="M73.7,61.1l1.3-1.5c0.8,0.7,1.7,1,2.7,1c0.6,0,1-0.2,1-0.6v0
|
||||
c0-0.4-0.3-0.5-1.4-0.8c-1.8-0.4-3.1-0.9-3.1-2.6v0c0-1.5,1.2-2.7,3.2-2.7c1.4,0,2.5,0.4,3.4,1.1l-1.2,1.6
|
||||
c-0.8-0.5-1.6-0.8-2.3-0.8c-0.6,0-0.8,0.2-0.8,0.5v0c0,0.4,0.3,0.5,1.4,0.8c1.9,0.4,3.1,1,3.1,2.6v0c0,1.7-1.3,2.7-3.4,2.7
|
||||
C76.1,62.5,74.7,62,73.7,61.1z"/>
|
||||
</g>
|
||||
</g>
|
||||
</g>
|
||||
</svg>
|
||||
|
After Width: | Height: | Size: 4.8 KiB |
50
Logo/resharper.svg
Normal file
@@ -0,0 +1,50 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!-- Generator: Adobe Illustrator 19.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
||||
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
||||
width="70px" height="70px" viewBox="0 0 70 70" style="enable-background:new 0 0 70 70;" xml:space="preserve">
|
||||
<g>
|
||||
<g>
|
||||
<g>
|
||||
<linearGradient id="SVGID_1_" gradientUnits="userSpaceOnUse" x1="22.9451" y1="75.7869" x2="74.7868" y2="20.6415">
|
||||
<stop offset="1.612903e-002" style="stop-color:#B35BA3"/>
|
||||
<stop offset="0.4044" style="stop-color:#C41E57"/>
|
||||
<stop offset="0.4677" style="stop-color:#C41E57"/>
|
||||
<stop offset="0.6505" style="stop-color:#EB8523"/>
|
||||
<stop offset="0.9516" style="stop-color:#FEBD11"/>
|
||||
</linearGradient>
|
||||
<polygon style="fill:url(#SVGID_1_);" points="49.8,15.2 36,36.7 58.4,70 70,23.1 "/>
|
||||
<linearGradient id="SVGID_2_" gradientUnits="userSpaceOnUse" x1="17.7187" y1="73.2922" x2="69.5556" y2="18.1519">
|
||||
<stop offset="1.612903e-002" style="stop-color:#B35BA3"/>
|
||||
<stop offset="0.4044" style="stop-color:#C41E57"/>
|
||||
<stop offset="0.4677" style="stop-color:#C41E57"/>
|
||||
<stop offset="0.7043" style="stop-color:#EB8523"/>
|
||||
</linearGradient>
|
||||
<polygon style="fill:url(#SVGID_2_);" points="51.1,15.7 49,0 18.8,33.6 27.6,42.3 20.8,70 58.4,70 "/>
|
||||
</g>
|
||||
<linearGradient id="SVGID_3_" gradientUnits="userSpaceOnUse" x1="1.8281" y1="53.4275" x2="48.8245" y2="9.2255">
|
||||
<stop offset="1.612903e-002" style="stop-color:#B35BA3"/>
|
||||
<stop offset="0.6613" style="stop-color:#C41E57"/>
|
||||
</linearGradient>
|
||||
<polygon style="fill:url(#SVGID_3_);" points="49,0 11.6,0 0,47.1 55.6,47.1 "/>
|
||||
<linearGradient id="SVGID_4_" gradientUnits="userSpaceOnUse" x1="49.8935" y1="-11.5569" x2="48.8588" y2="24.0352">
|
||||
<stop offset="0.5" style="stop-color:#C41E57"/>
|
||||
<stop offset="0.6668" style="stop-color:#D13F48"/>
|
||||
<stop offset="0.7952" style="stop-color:#D94F39"/>
|
||||
<stop offset="0.8656" style="stop-color:#DD5433"/>
|
||||
</linearGradient>
|
||||
<polygon style="fill:url(#SVGID_4_);" points="55.3,47.1 51.1,15.7 49,0 41.7,23 "/>
|
||||
</g>
|
||||
<g>
|
||||
|
||||
<rect x="13.4" y="13.5" transform="matrix(-1 2.577289e-003 -2.577289e-003 -1 70.0288 70.081)" style="fill:#000000;" width="43.2" height="43.2"/>
|
||||
|
||||
<rect x="17.6" y="48.6" transform="matrix(1 -2.577289e-003 2.577289e-003 1 -0.1287 6.634109e-002)" style="fill:#FFFFFF;" width="16.2" height="2.7"/>
|
||||
<path style="fill:#FFFFFF;" d="M17.4,19.1l8.2,0c2.3,0,4,0.6,5.2,1.8c1,1,1.5,2.4,1.5,4.1l0,0.1c0,1.5-0.3,2.6-1.1,3.5
|
||||
c-0.7,0.9-1.6,1.6-2.8,2l4.4,6.4l-4.6,0l-3.7-5.5l-3.3,0l0,5.5l-3.9,0L17.4,19.1z M25.3,27.8c1,0,1.7-0.2,2.2-0.7
|
||||
c0.5-0.5,0.8-1.1,0.8-1.8l0-0.1c0-0.9-0.3-1.5-0.8-1.9c-0.5-0.4-1.3-0.6-2.3-0.6l-3.9,0l0,5.1L25.3,27.8z"/>
|
||||
<path style="fill:#FFFFFF;" d="M36,33.2l-1.9,0l0-3.3l2.5,0l0.6-3.8l-2.3,0l0-3.3l2.8,0l0.6-3.7l3.4,0l-0.6,3.7l3.7,0l0.6-3.7
|
||||
l3.4,0l-0.6,3.7l1.9,0l0,3.3l-2.5,0L47,29.9l2.3,0l0,3.3l-2.8,0L45.8,37l-3.4,0l0.7-3.8l-3.7,0L38.7,37l-3.4,0L36,33.2z
|
||||
M43.7,29.9l0.6-3.8l-3.7,0L40,29.9L43.7,29.9z"/>
|
||||
</g>
|
||||
</g>
|
||||
</svg>
|
||||
|
After Width: | Height: | Size: 3.1 KiB |
42
Logo/rider.svg
Normal file
@@ -0,0 +1,42 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!-- Generator: Adobe Illustrator 19.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
||||
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
||||
width="70px" height="70px" viewBox="0 0 70 70" style="enable-background:new 0 0 70 70;" xml:space="preserve">
|
||||
<defs>
|
||||
<linearGradient id="linear-gradient" x1="70.22612" y1="27.79912" x2="-5.13024" y2="63.12242" gradientTransform="matrix(1, 0, 0, -1, 0, 71.27997)" gradientUnits="userSpaceOnUse">
|
||||
<stop offset="0" stop-color="#c90f5e"/>
|
||||
<stop offset="0.22111" stop-color="#c90f5e"/>
|
||||
<stop offset="0.2356" stop-color="#c90f5e"/>
|
||||
<stop offset="0.35559" stop-color="#ca135c"/>
|
||||
<stop offset="0.46633" stop-color="#ce1e57"/>
|
||||
<stop offset="0.5735" stop-color="#d4314e"/>
|
||||
<stop offset="0.67844" stop-color="#dc4b41"/>
|
||||
<stop offset="0.78179" stop-color="#e66d31"/>
|
||||
<stop offset="0.88253" stop-color="#f3961d"/>
|
||||
<stop offset="0.94241" stop-color="#fcb20f"/>
|
||||
</linearGradient>
|
||||
<linearGradient id="linear-gradient-2" x1="24.65904" y1="61.99608" x2="46.04762" y2="2.93445" gradientTransform="matrix(1, 0, 0, -1, 0, 71.27997)" gradientUnits="userSpaceOnUse">
|
||||
<stop offset="0.04188" stop-color="#077cfb"/>
|
||||
<stop offset="0.44503" stop-color="#c90f5e"/>
|
||||
<stop offset="0.95812" stop-color="#077cfb"/>
|
||||
</linearGradient>
|
||||
<linearGradient id="linear-gradient-3" x1="17.39552" y1="63.34592" x2="33.19389" y2="7.20092" gradientTransform="matrix(1, 0, 0, -1, 0, 71.27997)" gradientUnits="userSpaceOnUse">
|
||||
<stop offset="0.27749" stop-color="#c90f5e"/>
|
||||
<stop offset="0.97382" stop-color="#fcb20f"/>
|
||||
</linearGradient>
|
||||
</defs>
|
||||
<title>rider</title>
|
||||
<g>
|
||||
<polygon points="70 27.237 63.391 23.75 20.926 0 3.827 17.921 21.619 41.068 60.537 44.397 70 27.237" fill="url(#linear-gradient)"/>
|
||||
<polygon points="50.423 16.132 44.271 1.107 27.643 17.471 11.768 50.194 49.411 70 70 57.98 50.423 16.132" fill="url(#linear-gradient-2)"/>
|
||||
<polygon points="20.926 0 0 14.095 7.779 62.172 27.848 69.889 53.78 48.823 20.926 0" fill="url(#linear-gradient-3)"/>
|
||||
</g>
|
||||
<g>
|
||||
<rect x="13.30219" y="13.19311" width="43.61371" height="43.61371"/>
|
||||
<g>
|
||||
<path d="M17.22741,18.86293h8.39564a7.38416,7.38416,0,0,1,5.34268,1.85358,5.86989,5.86989,0,0,1,1.52648,4.1433h0A5.74339,5.74339,0,0,1,28.567,30.5296l4.47041,6.54206H28.34891L24.42368,31.1838h-3.162v5.88785H17.22741V18.86293h0ZM25.296,27.69471c1.96262,0,3.053-1.09034,3.053-2.61682h0c0-1.74455-1.19938-2.61682-3.162-2.61682H21.15265v5.23365H25.296Z" fill="#fff"/>
|
||||
<path d="M36.09034,18.86293H43.2866c5.77882,0,9.70405,3.92523,9.70405,9.15888h0c0,5.12461-3.92523,9.15888-9.70405,9.15888H36.09034V18.86293Zm4.03427,3.59813V33.47352h3.162a5.23727,5.23727,0,0,0,5.56075-5.45171h0a5.26493,5.26493,0,0,0-5.56075-5.56075h-3.162Z" fill="#fff"/>
|
||||
</g>
|
||||
<rect x="17.22741" y="48.62925" width="16.35514" height="2.72586" fill="#fff"/>
|
||||
</g>
|
||||
</svg>
|
||||
|
After Width: | Height: | Size: 3.0 KiB |
36
Logo/webstorm.svg
Normal file
@@ -0,0 +1,36 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!-- Generator: Adobe Illustrator 19.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
||||
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
||||
width="70px" height="70px" viewBox="0 0 70 70" style="enable-background:new 0 0 70 70;" xml:space="preserve">
|
||||
<g>
|
||||
<g>
|
||||
<linearGradient id="SVGID_1_" gradientUnits="userSpaceOnUse" x1="25.0676" y1="1.4599" x2="43.1829" y2="66.675">
|
||||
<stop offset="0.2849" style="stop-color:#00CDD7"/>
|
||||
<stop offset="0.9409" style="stop-color:#2086D7"/>
|
||||
</linearGradient>
|
||||
<polygon style="fill:url(#SVGID_1_);" points="9.4,63.3 0,7.3 17.5,0.1 28.6,6.7 38.8,1.2 60.1,9.4 48.1,70 "/>
|
||||
<linearGradient id="SVGID_2_" gradientUnits="userSpaceOnUse" x1="30.7199" y1="9.7343" x2="61.365" y2="54.6713">
|
||||
<stop offset="0.1398" style="stop-color:#FFF045"/>
|
||||
<stop offset="0.3656" style="stop-color:#00CDD7"/>
|
||||
</linearGradient>
|
||||
<polygon style="fill:url(#SVGID_2_);" points="70,23.7 61,1.4 44.6,0 19.3,24.3 26.1,55.6 38.8,64.6 70,46 62.3,31.7 "/>
|
||||
<linearGradient id="SVGID_3_" gradientUnits="userSpaceOnUse" x1="61.0819" y1="15.2899" x2="65.1065" y2="29.5436">
|
||||
<stop offset="0.2849" style="stop-color:#00CDD7"/>
|
||||
<stop offset="0.9409" style="stop-color:#2086D7"/>
|
||||
</linearGradient>
|
||||
<polygon style="fill:url(#SVGID_3_);" points="56,20.4 62.3,31.7 70,23.7 64.4,9.8 "/>
|
||||
</g>
|
||||
<g>
|
||||
<g>
|
||||
<rect x="13.4" y="13.4" style="fill:#000000;" width="43.2" height="43.2"/>
|
||||
<rect x="17.5" y="48.5" style="fill:#FFFFFF;" width="16.2" height="2.7"/>
|
||||
<path style="fill:#FFFFFF;" d="M38.7,34.3l2.3-2.8c1.6,1.3,3.3,2.2,5.3,2.2c1.6,0,2.5-0.6,2.5-1.7v-0.1c0-1-0.6-1.5-3.6-2.3
|
||||
c-3.6-0.9-5.8-1.9-5.8-5.5v-0.1c0-3.3,2.6-5.4,6.2-5.4c2.6,0,4.8,0.8,6.6,2.3l-2,3c-1.6-1.1-3.1-1.8-4.6-1.8
|
||||
c-1.5,0-2.3,0.7-2.3,1.6v0.1c0,1.2,0.8,1.6,3.8,2.4c3.6,1,5.6,2.3,5.6,5.4v0.1c0,3.6-2.7,5.6-6.5,5.6
|
||||
C43.5,37.2,40.8,36.2,38.7,34.3"/>
|
||||
</g>
|
||||
<polygon style="fill:#FFFFFF;" points="35.2,19 32.5,29.4 29.5,19 26.5,19 23.4,29.4 20.7,19 16.6,19 21.7,36.9 25,36.9 28,26.5
|
||||
30.9,36.9 34.3,36.9 39.4,19 "/>
|
||||
</g>
|
||||
</g>
|
||||
</svg>
|
||||
|
After Width: | Height: | Size: 2.1 KiB |
56
README.md
@@ -6,6 +6,8 @@ Radarr is an __independent__ fork of [Sonarr](https://github.com/Sonarr/Sonarr)
|
||||
|
||||
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.
|
||||
|
||||
## Getting Started
|
||||
|
||||
[](https://github.com/Radarr/Radarr/wiki/Installation)
|
||||
@@ -20,16 +22,19 @@ The project was inspired by other Usenet/BitTorrent movie downloaders such as Co
|
||||
|
||||
## Downloads
|
||||
|
||||
[](https://github.com/Radarr/Radarr/releases)
|
||||
[](https://ci.appveyor.com/project/galli-leo/radarr-usby1/branch/develop/artifacts)
|
||||
Branch | develop (stable) | nightly (semi-unstable) |
|
||||
---|---|---
|
||||
Binary Releases | [](https://github.com/Radarr/Radarr/releases) | [](https://ci.appveyor.com/project/galli-leo/radarr-usby1/branch/develop/artifacts)
|
||||
Docker (linuxserver.io, x86_64, arm64, armhf) | [](https://store.docker.com/community/images/linuxserver/radarr) | [](https://store.docker.com/community/images/linuxserver/radarr)
|
||||
Docker (hotio, see [here](https://github.com/hotio/docker-radarr) for more information) | [](https://hub.docker.com/r/hotio/radarr) | [](https://hub.docker.com/r/hotio/radarr)
|
||||
|
||||
[](https://store.docker.com/community/images/linuxserver/radarr)
|
||||
[](https://store.docker.com/community/images/hotio/suitarr)
|
||||
[](https://store.docker.com/community/images/lsioarmhf/radarr)
|
||||
[](https://store.docker.com/community/images/lsioarmhf/radarr-aarch64)
|
||||
|
||||
## Support
|
||||
|
||||
[](#backers)
|
||||
[](#flexible-sponsors)
|
||||
[](#sponsors)
|
||||
|
||||
[](https://discord.gg/AD3UP37)
|
||||
[](https://www.reddit.com/r/radarr)
|
||||
[](http://feathub.com/Radarr/Radarr)
|
||||
@@ -42,8 +47,9 @@ The project was inspired by other Usenet/BitTorrent movie downloaders such as Co
|
||||
[](https://github.com/Radarr/Radarr/pulls)
|
||||
[](http://www.gnu.org/licenses/gpl.html)
|
||||
[](https://github.com/Radarr/Radarr)
|
||||
[](https://github.com/Radar/Radarr/releases/latest)
|
||||
[](https://github.com/Radarr/Radarr/releases/)
|
||||
[](https://hub.docker.com/r/linuxserver/radarr/)
|
||||
[](/CHANGELOG.md#unreleased)
|
||||
|
||||
| Service | Master | Develop |
|
||||
|----------|:---------------------------:|:----------------------------:|
|
||||
@@ -84,15 +90,11 @@ Radarr is currently undergoing rapid development and pull requests are actively
|
||||
* 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
|
||||
|
||||
* Dynamically renaming folders with quality info, etc. (Currently working partially.) (\*)
|
||||
* Supporting custom folder structures, such as all movie files in one folder (\*)
|
||||
* Supporting multiple editions per movies (\*)
|
||||
* Supporting collections of movies, such as James Bond (\*)
|
||||
|
||||
**Note:** All features marked with (\*) are set to be in the first release of Radarr.
|
||||
See the [Roadmap blogpost](https://blog.radarr.video/development/update/2018/11/11/roadmap-update.html) for an overview of planned features.
|
||||
|
||||
#### [Feature Requests](http://feathub.com/Radarr/Radarr)
|
||||
|
||||
@@ -100,7 +102,7 @@ Radarr is currently undergoing rapid development and pull requests are actively
|
||||
|
||||
### Requirements
|
||||
|
||||
* [Visual Studio Community](https://www.visualstudio.com/vs/community/) or [MonoDevelop](http://www.monodevelop.com)
|
||||
* [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/)
|
||||
|
||||
@@ -119,11 +121,11 @@ Radarr is currently undergoing rapid development and pull requests are actively
|
||||
|
||||
* To build run `sh build.sh`
|
||||
|
||||
**Note:** Windows users must have bash available to do this. [cmder](http://cmder.net/) which is a console emulator for windows has bash as part of it's default installation.
|
||||
**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 or run the build.sh script, if Mono is installed
|
||||
* 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
|
||||
|
||||
@@ -131,17 +133,27 @@ Radarr is currently undergoing rapid development and pull requests are actively
|
||||
|
||||
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!
|
||||
|
||||
[](https://opencollective.com/radarr/order/3851)
|
||||
### Sponsors
|
||||
|
||||
---
|
||||
[](https://opencollective.com/radarr/order/3851)
|
||||
|
||||
[](https://opencollective.com/radarr/order/3856)
|
||||
### Flexible Sponsors
|
||||
|
||||
---
|
||||
[](https://opencollective.com/radarr/order/3856)
|
||||
|
||||
[](https://opencollective.com/radarr/order/3850)
|
||||
### Backers
|
||||
|
||||
[](https://opencollective.com/radarr/order/3850)
|
||||
|
||||
### JetBrains
|
||||
|
||||
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
|
||||
* [<img src="/Logo/resharper.svg" alt="ReSharper" width="32"> ReSharper](http://www.jetbrains.com/resharper/)
|
||||
* [<img src="/Logo/webstorm.svg" alt="WebStorm" width="32"> WebStorm](http://www.jetbrains.com/webstorm/)
|
||||
* [<img src="/Logo/rider.svg" alt="Rider" width="32"> Rider](http://www.jetbrains.com/rider/)
|
||||
* [<img src="/Logo/dottrace.svg" alt="dotTrace" width="32"> dotTrace](http://www.jetbrains.com/dottrace/)
|
||||
|
||||
## License
|
||||
|
||||
* [GNU GPL v3](http://www.gnu.org/licenses/gpl.html)
|
||||
* Copyright 2010-2017
|
||||
* Copyright 2010-2018
|
||||
|
||||
53
appveyor.yml
@@ -1,53 +0,0 @@
|
||||
version: '0.2.0.{build}'
|
||||
|
||||
assembly_info:
|
||||
patch: true
|
||||
file: 'src\NzbDrone.Common\Properties\SharedAssemblyInfo.cs'
|
||||
assembly_version: '{version}'
|
||||
assembly_file_version: '{version}'
|
||||
assembly_informational_version: '{version}-rc1'
|
||||
|
||||
environment:
|
||||
DOTNET_CLI_TELEMETRY_OPTOUT: 1
|
||||
|
||||
install:
|
||||
- git submodule update --init --recursive
|
||||
|
||||
build_script:
|
||||
- ps: ./build-appveyor.ps1
|
||||
|
||||
test: off
|
||||
#test:
|
||||
# assemblies:
|
||||
# - '_tests\*Test.dll'
|
||||
# categories:
|
||||
# except:
|
||||
# - IntegrationTest
|
||||
# - AutomationTest
|
||||
|
||||
artifacts:
|
||||
- path: '_artifacts\*.zip'
|
||||
- path: '_artifacts\*.exe'
|
||||
- path: '_artifacts\*.tar.gz'
|
||||
|
||||
cache:
|
||||
- '%USERPROFILE%\.nuget\packages'
|
||||
- node_modules -> package.json
|
||||
|
||||
pull_requests:
|
||||
do_not_increment_build_number: true
|
||||
|
||||
on_failure:
|
||||
- ps: Get-ChildItem .\_artifacts\*.zip | % { Push-AppveyorArtifact $_.FullName -FileName $_.Name }
|
||||
- ps: Get-ChildItem .\_artifacts\*.exe | % { Push-AppveyorArtifact $_.FullName -FileName $_.Name }
|
||||
- ps: Get-ChildItem .\_artifacts\*.tar.gz | % { Push-AppveyorArtifact $_.FullName -FileName $_.Name }
|
||||
|
||||
only_commits:
|
||||
files:
|
||||
- src/
|
||||
- osx/
|
||||
- gulp/
|
||||
- logo/
|
||||
- setup/
|
||||
- appveyor.yml
|
||||
- build-appveyor.cake
|
||||
431
azure-pipelines.yml
Normal file
@@ -0,0 +1,431 @@
|
||||
# Starter pipeline
|
||||
# Start with a minimal pipeline that you can customize to build and deploy your code.
|
||||
# Add steps that build, run tests, deploy, and more:
|
||||
# https://aka.ms/yaml
|
||||
|
||||
variables:
|
||||
outputFolder: './_output'
|
||||
artifactsFolder: './_artifacts'
|
||||
testsFolder: './_tests'
|
||||
majorVersion: '0.2.0'
|
||||
minorVersion: $[counter('minorVersionOld', 1510)]
|
||||
radarrVersion: '$(majorVersion).$(minorVersion)'
|
||||
buildName: '$(Build.SourceBranchName).$(radarrVersion)'
|
||||
windowsInstaller: 'Radarr.$(buildName).windows-installer.exe'
|
||||
windowsZip: 'Radarr.$(buildName).windows.zip'
|
||||
macOsApp: 'Radarr.$(buildName).osx-app.zip'
|
||||
macOsTar: 'Radarr.$(buildName).osx.tar.gz'
|
||||
linuxTar: 'Radarr.$(buildName).linux.tar.gz'
|
||||
|
||||
trigger:
|
||||
branches:
|
||||
include:
|
||||
- develop
|
||||
- aphrodite
|
||||
|
||||
pr:
|
||||
- develop
|
||||
- aphrodite
|
||||
|
||||
stages:
|
||||
- stage: Build_Backend
|
||||
displayName: Build Backend
|
||||
|
||||
jobs:
|
||||
- job: Backend
|
||||
strategy:
|
||||
matrix:
|
||||
Linux:
|
||||
osName: 'Linux'
|
||||
imageName: 'ubuntu-18.04'
|
||||
Mac:
|
||||
osName: 'Mac'
|
||||
imageName: 'macos-10.14'
|
||||
Windows:
|
||||
osName: 'Windows'
|
||||
imageName: 'windows-2019'
|
||||
|
||||
pool:
|
||||
vmImage: $(imageName)
|
||||
steps:
|
||||
# Set the build name properly. The 'name' property won't recursively expand so hack here:
|
||||
- powershell: Write-Host "##vso[build.updatebuildnumber]$($env:RADARRVERSION)"
|
||||
displayName: Set Build Name
|
||||
- checkout: self
|
||||
submodules: true
|
||||
fetchDepth: 1
|
||||
- task: Assembly-Info-NetFramework@2
|
||||
displayName: Patch AssemblyInfo
|
||||
inputs:
|
||||
Path: '$(Build.SourcesDirectory)'
|
||||
FileNames: 'src/NzbDrone.Common/Properties/SharedAssemblyInfo.cs'
|
||||
InsertAttributes: false
|
||||
FileEncoding: 'auto'
|
||||
WriteBOM: false
|
||||
Configuration: 'debug'
|
||||
VersionNumber: '$(radarrVersion)'
|
||||
FileVersionNumber: '$(radarrVersion)'
|
||||
InformationalVersion: '$(radarrVersion)-rc1'
|
||||
- bash: ./build.sh --only-backend
|
||||
displayName: Build Radarr Backend
|
||||
- publish: $(outputFolder)
|
||||
artifact: '$(osName)Backend'
|
||||
displayName: Publish Backend
|
||||
condition: and(succeeded(), eq(variables['osName'], 'Windows'))
|
||||
- publish: $(testsFolder)
|
||||
artifact: '$(osName)Tests'
|
||||
displayName: Publish Test Package
|
||||
condition: and(succeeded(), eq(variables['osName'], 'Windows'))
|
||||
|
||||
- stage: Build_Frontend
|
||||
displayName: Build Frontend
|
||||
dependsOn: []
|
||||
|
||||
jobs:
|
||||
- job: Frontend
|
||||
strategy:
|
||||
matrix:
|
||||
Linux:
|
||||
osName: 'Linux'
|
||||
imageName: 'ubuntu-18.04'
|
||||
Mac:
|
||||
osName: 'Mac'
|
||||
imageName: 'macos-10.14'
|
||||
Windows:
|
||||
osName: 'Windows'
|
||||
imageName: 'windows-2019'
|
||||
pool:
|
||||
vmImage: $(imageName)
|
||||
steps:
|
||||
- task: NodeTool@0
|
||||
displayName: Set Node.js version
|
||||
inputs:
|
||||
versionSpec: '10.x'
|
||||
- checkout: self
|
||||
submodules: true
|
||||
fetchDepth: 1
|
||||
- bash: ./build.sh --only-frontend
|
||||
displayName: Build Radarr Frontend
|
||||
env:
|
||||
FORCE_COLOR: 0
|
||||
- publish: $(outputFolder)
|
||||
artifact: '$(osName)Frontend'
|
||||
displayName: Publish Frontend
|
||||
condition: and(succeeded(), eq(variables['osName'], 'Windows'))
|
||||
|
||||
- stage: Package
|
||||
dependsOn:
|
||||
- Build_Backend
|
||||
- Build_Frontend
|
||||
jobs:
|
||||
- job: Windows_Installer
|
||||
displayName: Create Installer
|
||||
pool:
|
||||
vmImage: 'windows-2019'
|
||||
steps:
|
||||
- checkout: self
|
||||
fetchDepth: 1
|
||||
- task: DownloadPipelineArtifact@2
|
||||
inputs:
|
||||
buildType: 'current'
|
||||
artifactName: WindowsBackend
|
||||
targetPath: _output
|
||||
displayName: Fetch Backend
|
||||
- task: DownloadPipelineArtifact@2
|
||||
inputs:
|
||||
buildType: 'current'
|
||||
artifactName: WindowsFrontend
|
||||
targetPath: _output
|
||||
displayName: Fetch Frontend
|
||||
- bash: ./build.sh --only-packages
|
||||
displayName: Create Packages
|
||||
- bash: |
|
||||
./setup/inno/ISCC.exe "./setup/radarr.iss"
|
||||
cp ./setup/output/Radarr.*windows.exe ${BUILD_ARTIFACTSTAGINGDIRECTORY}/${WINDOWSINSTALLER}
|
||||
displayName: Create Windows installer
|
||||
- publish: $(Build.ArtifactStagingDirectory)
|
||||
artifact: 'WindowsInstaller'
|
||||
displayName: Publish Installer
|
||||
|
||||
- job: Other_Packages
|
||||
displayName: Create Standard Packages
|
||||
pool:
|
||||
vmImage: 'ubuntu-18.04'
|
||||
steps:
|
||||
- checkout: self
|
||||
fetchDepth: 1
|
||||
- task: DownloadPipelineArtifact@2
|
||||
inputs:
|
||||
buildType: 'current'
|
||||
artifactName: WindowsBackend
|
||||
targetPath: _output
|
||||
displayName: Fetch Backend
|
||||
- task: DownloadPipelineArtifact@2
|
||||
inputs:
|
||||
buildType: 'current'
|
||||
artifactName: WindowsFrontend
|
||||
targetPath: _output
|
||||
displayName: Fetch Frontend
|
||||
- bash: ./build.sh --only-packages
|
||||
displayName: Create Packages
|
||||
- bash: |
|
||||
chmod a+x $(artifactsFolder)/macos/Radarr/Radarr
|
||||
chmod a+x $(artifactsFolder)/macos-app/Radarr.app/Contents/MacOS/Radarr
|
||||
displayName: Set Mac executable bits
|
||||
- task: ArchiveFiles@2
|
||||
displayName: Create Windows zip
|
||||
inputs:
|
||||
archiveFile: '$(Build.ArtifactStagingDirectory)/$(windowsZip)'
|
||||
archiveType: 'zip'
|
||||
includeRootFolder: false
|
||||
rootFolderOrFile: $(artifactsFolder)/windows
|
||||
- task: ArchiveFiles@2
|
||||
displayName: Create MacOS app
|
||||
inputs:
|
||||
archiveFile: '$(Build.ArtifactStagingDirectory)/$(macOsApp)'
|
||||
archiveType: 'zip'
|
||||
includeRootFolder: false
|
||||
rootFolderOrFile: $(artifactsFolder)/macos-app
|
||||
- task: ArchiveFiles@2
|
||||
displayName: Create MacOS tar
|
||||
inputs:
|
||||
archiveFile: '$(Build.ArtifactStagingDirectory)/$(macOsTar)'
|
||||
archiveType: 'tar'
|
||||
tarCompression: 'gz'
|
||||
includeRootFolder: false
|
||||
rootFolderOrFile: $(artifactsFolder)/macos
|
||||
- task: ArchiveFiles@2
|
||||
displayName: Create Linux tar
|
||||
inputs:
|
||||
archiveFile: '$(Build.ArtifactStagingDirectory)/$(linuxTar)'
|
||||
archiveType: 'tar'
|
||||
tarCompression: 'gz'
|
||||
includeRootFolder: false
|
||||
rootFolderOrFile: $(artifactsFolder)/linux
|
||||
- publish: $(Build.ArtifactStagingDirectory)
|
||||
artifact: 'Packages'
|
||||
displayName: Publish Packages
|
||||
|
||||
- stage: Unit_Test
|
||||
displayName: Unit Tests
|
||||
dependsOn: Build_Backend
|
||||
condition: succeeded()
|
||||
jobs:
|
||||
- job: Unit
|
||||
strategy:
|
||||
matrix:
|
||||
Linux:
|
||||
osName: 'Linux'
|
||||
imageName: 'ubuntu-18.04'
|
||||
Mac:
|
||||
osName: 'Mac'
|
||||
imageName: 'macos-10.14'
|
||||
Windows:
|
||||
osName: 'Windows'
|
||||
imageName: 'windows-2019'
|
||||
|
||||
pool:
|
||||
vmImage: $(imageName)
|
||||
|
||||
steps:
|
||||
- checkout: none
|
||||
- task: DownloadPipelineArtifact@2
|
||||
displayName: Download Test Artifact
|
||||
inputs:
|
||||
buildType: 'current'
|
||||
artifactName: WindowsTests
|
||||
targetPath: $(testsFolder)
|
||||
- bash: |
|
||||
wget https://mediaarea.net/repo/deb/repo-mediaarea_1.0-11_all.deb
|
||||
sudo dpkg -i repo-mediaarea_1.0-11_all.deb
|
||||
sudo apt-get update
|
||||
sudo apt-get install -y --allow-unauthenticated libmediainfo-dev libmediainfo0v5 mediainfo
|
||||
displayName: Install mediainfo
|
||||
condition: and(succeeded(), eq(variables['osName'], 'Linux'))
|
||||
- powershell: Set-Service SCardSvr -StartupType Manual
|
||||
displayName: Enable Windows Test Service
|
||||
condition: and(succeeded(), eq(variables['osName'], 'Windows'))
|
||||
- bash: |
|
||||
chmod a+x ${TESTSFOLDER}/test.sh
|
||||
${TESTSFOLDER}/test.sh ${OSNAME} Unit Test
|
||||
displayName: Run Unit Tests
|
||||
- publish: TestResult.xml
|
||||
artifact: 'TestResult'
|
||||
displayName: Publish Test Result
|
||||
condition: and(succeeded(), eq(variables['osName'], 'Windows'))
|
||||
- task: PublishTestResults@2
|
||||
displayName: Publish Test Results
|
||||
inputs:
|
||||
testResultsFormat: 'NUnit'
|
||||
testResultsFiles: '**/TestResult.xml'
|
||||
testRunTitle: '$(osName) Unit Tests'
|
||||
failTaskOnFailedTests: true
|
||||
|
||||
- stage: Integration
|
||||
displayName: Integration
|
||||
dependsOn: Package
|
||||
|
||||
jobs:
|
||||
|
||||
- job: Integration
|
||||
strategy:
|
||||
matrix:
|
||||
Linux:
|
||||
osName: 'Linux'
|
||||
imageName: 'ubuntu-18.04'
|
||||
pattern: 'Radarr.**.linux.tar.gz'
|
||||
Mac:
|
||||
osName: 'Mac'
|
||||
imageName: 'macos-10.14'
|
||||
pattern: 'Radarr.**.osx.tar.gz'
|
||||
Windows:
|
||||
osName: 'Windows'
|
||||
imageName: 'windows-2019'
|
||||
pattern: 'Radarr.**.windows.zip'
|
||||
|
||||
pool:
|
||||
vmImage: $(imageName)
|
||||
|
||||
steps:
|
||||
- bash: |
|
||||
SYMLINK=5_18_1
|
||||
MONOPREFIX=/Library/Frameworks/Mono.framework/Versions/$SYMLINK
|
||||
echo "##vso[task.setvariable variable=MONOPREFIX;]$MONOPREFIX"
|
||||
echo "##vso[task.setvariable variable=PKG_CONFIG_PATH;]$MONOPREFIX/lib/pkgconfig:$MONOPREFIX/share/pkgconfig:$PKG_CONFIG_PATH"
|
||||
echo "##vso[task.setvariable variable=PATH;]$MONOPREFIX/bin:$PATH"
|
||||
displayName: Set Mono Version
|
||||
condition: and(succeeded(), eq(variables['osName'], 'Mac'))
|
||||
- checkout: none
|
||||
- task: DownloadPipelineArtifact@2
|
||||
displayName: Download Test Artifact
|
||||
inputs:
|
||||
buildType: 'current'
|
||||
artifactName: WindowsTests
|
||||
targetPath: $(testsFolder)
|
||||
- task: DownloadPipelineArtifact@2
|
||||
displayName: Download Build Artifact
|
||||
inputs:
|
||||
buildType: 'current'
|
||||
artifactName: Packages
|
||||
itemPattern: '**/$(pattern)'
|
||||
targetPath: $(Build.ArtifactStagingDirectory)
|
||||
- task: ExtractFiles@1
|
||||
inputs:
|
||||
archiveFilePatterns: '$(Build.ArtifactStagingDirectory)/**/$(pattern)'
|
||||
destinationFolder: '$(Build.ArtifactStagingDirectory)/bin'
|
||||
displayName: Extract Package
|
||||
- bash: |
|
||||
mkdir -p ./bin/
|
||||
cp -r -v ${BUILD_ARTIFACTSTAGINGDIRECTORY}/bin/Radarr/. ./bin/
|
||||
displayName: Move Package Contents
|
||||
- bash: |
|
||||
ls -lR
|
||||
chmod a+x ${TESTSFOLDER}/test.sh
|
||||
${TESTSFOLDER}/test.sh ${OSNAME} Integration Test
|
||||
displayName: Run Integration Tests
|
||||
- task: PublishTestResults@2
|
||||
inputs:
|
||||
testResultsFormat: 'NUnit'
|
||||
testResultsFiles: '**/TestResult.xml'
|
||||
testRunTitle: '$(osName) Integration Tests'
|
||||
failTaskOnFailedTests: true
|
||||
displayName: Publish Test Results
|
||||
|
||||
- stage: Automation
|
||||
displayName: Automation
|
||||
dependsOn: Package
|
||||
|
||||
jobs:
|
||||
- job: Automation
|
||||
strategy:
|
||||
matrix:
|
||||
Linux:
|
||||
osName: 'Linux'
|
||||
imageName: 'ubuntu-18.04'
|
||||
pattern: 'Radarr.**.linux.tar.gz'
|
||||
failBuild: true
|
||||
Mac:
|
||||
osName: 'Mac'
|
||||
imageName: 'macos-10.14' # Fails due to firefox not being installed on image
|
||||
pattern: 'Radarr.**.osx.tar.gz'
|
||||
failBuild: true
|
||||
Windows:
|
||||
osName: 'Windows'
|
||||
imageName: 'windows-2019'
|
||||
pattern: 'Radarr.**.windows.zip'
|
||||
failBuild: true
|
||||
|
||||
pool:
|
||||
vmImage: $(imageName)
|
||||
|
||||
steps:
|
||||
- checkout: none
|
||||
- task: DownloadPipelineArtifact@2
|
||||
displayName: Download Test Artifact
|
||||
inputs:
|
||||
buildType: 'current'
|
||||
artifactName: WindowsTests
|
||||
targetPath: $(testsFolder)
|
||||
- task: DownloadPipelineArtifact@2
|
||||
displayName: Download Build Artifact
|
||||
inputs:
|
||||
buildType: 'current'
|
||||
artifactName: Packages
|
||||
itemPattern: '**/$(pattern)'
|
||||
targetPath: $(Build.ArtifactStagingDirectory)
|
||||
- task: ExtractFiles@1
|
||||
inputs:
|
||||
archiveFilePatterns: '$(Build.ArtifactStagingDirectory)/**/$(pattern)'
|
||||
destinationFolder: '$(Build.ArtifactStagingDirectory)/bin'
|
||||
displayName: Extract Package
|
||||
- bash: |
|
||||
mkdir -p ./bin/
|
||||
cp -r -v ${BUILD_ARTIFACTSTAGINGDIRECTORY}/bin/Radarr/. ./bin/
|
||||
displayName: Move Package Contents
|
||||
- bash: |
|
||||
if [[ $OSNAME == "Mac" ]]; then
|
||||
url=https://github.com/mozilla/geckodriver/releases/download/v0.26.0/geckodriver-v0.26.0-macos.tar.gz
|
||||
elif [[ $OSNAME == "Linux" ]]; then
|
||||
url=https://github.com/mozilla/geckodriver/releases/download/v0.26.0/geckodriver-v0.26.0-linux64.tar.gz
|
||||
else
|
||||
echo "Unhandled OS"
|
||||
exit 1
|
||||
fi
|
||||
curl -s -L "$url" | tar -xz
|
||||
chmod +x geckodriver
|
||||
mv geckodriver _tests
|
||||
displayName: Install Gecko Driver
|
||||
condition: and(succeeded(), ne(variables['osName'], 'Windows'))
|
||||
- bash: ls -lR
|
||||
- bash: |
|
||||
chmod a+x ${TESTSFOLDER}/test.sh
|
||||
${TESTSFOLDER}/test.sh ${OSNAME} Automation
|
||||
displayName: Run Automation Tests
|
||||
- task: PublishTestResults@2
|
||||
inputs:
|
||||
testResultsFormat: 'NUnit'
|
||||
testResultsFiles: '**/TestResult.xml'
|
||||
testRunTitle: '$(osName) Automation Tests'
|
||||
failTaskOnFailedTests: $(failBuild)
|
||||
displayName: Publish Test Results
|
||||
|
||||
- stage: Report_Out
|
||||
dependsOn:
|
||||
- Unit_Test
|
||||
- Integration
|
||||
- Automation
|
||||
condition: eq(variables['system.pullrequest.isfork'], false)
|
||||
displayName: Build Status Report
|
||||
jobs:
|
||||
- job:
|
||||
displayName: Discord Notification
|
||||
pool:
|
||||
vmImage: 'ubuntu-18.04'
|
||||
steps:
|
||||
- checkout: none
|
||||
- powershell: |
|
||||
iex ((New-Object System.Net.WebClient).DownloadString('https://raw.githubusercontent.com/Servarr/AzureDiscordNotify/master/DiscordNotify.ps1'))
|
||||
env:
|
||||
SYSTEM_ACCESSTOKEN: $(System.AccessToken)
|
||||
DISCORDCHANNELID: $(discordChannelId)
|
||||
DISCORDWEBHOOKKEY: $(discordWebhookKey)
|
||||
@@ -1,319 +0,0 @@
|
||||
#addin nuget:?package=Cake.Npm&version=0.12.1
|
||||
#addin nuget:?package=SharpZipLib&version=0.86.0
|
||||
#addin nuget:?package=Cake.Compression&version=0.1.4
|
||||
|
||||
// Build variables
|
||||
var outputFolder = "./_output";
|
||||
var outputFolderMono = outputFolder + "_mono";
|
||||
var outputFolderOsx = outputFolder + "_osx";
|
||||
var outputFolderOsxApp = outputFolderOsx + "_app";
|
||||
var testPackageFolder = "./_tests";
|
||||
var testSearchPattern = "*.Test/bin/x86/Release";
|
||||
var sourceFolder = "./src";
|
||||
var solutionFile = sourceFolder + "/NzbDrone.sln";
|
||||
var updateFolder = outputFolder + "/NzbDrone.Update";
|
||||
var updateFolderMono = outputFolderMono + "/NzbDrone.Update";
|
||||
|
||||
// Artifact variables
|
||||
var artifactsFolder = "./_artifacts";
|
||||
var artifactsFolderWindows = artifactsFolder + "/windows";
|
||||
var artifactsFolderLinux = artifactsFolder + "/linux";
|
||||
var artifactsFolderOsx = artifactsFolder + "/osx";
|
||||
var artifactsFolderOsxApp = artifactsFolder + "/osx-app";
|
||||
|
||||
// Utility methods
|
||||
public void RemoveEmptyFolders(string startLocation) {
|
||||
foreach (var directory in System.IO.Directory.GetDirectories(startLocation))
|
||||
{
|
||||
RemoveEmptyFolders(directory);
|
||||
|
||||
if (System.IO.Directory.GetFiles(directory).Length == 0 &&
|
||||
System.IO.Directory.GetDirectories(directory).Length == 0)
|
||||
{
|
||||
DeleteDirectory(directory, false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void CleanFolder(string path, bool keepConfigFiles) {
|
||||
DeleteFiles(path + "/**/*.transform");
|
||||
|
||||
if (!keepConfigFiles) {
|
||||
DeleteFiles(path + "/**/*.dll.config");
|
||||
}
|
||||
|
||||
DeleteFiles(path + "/**/FluentValidation.resources.dll");
|
||||
DeleteFiles(path + "/**/App.config");
|
||||
|
||||
DeleteFiles(path + "/**/*.less");
|
||||
|
||||
DeleteFiles(path + "/**/*.vshost.exe");
|
||||
|
||||
DeleteFiles(path + "/**/*.dylib");
|
||||
|
||||
RemoveEmptyFolders(path);
|
||||
}
|
||||
|
||||
public void CreateMdbs(string path) {
|
||||
foreach (var file in System.IO.Directory.EnumerateFiles(path, "*.pdb", System.IO.SearchOption.AllDirectories)) {
|
||||
var actualFile = file.Substring(0, file.Length - 4);
|
||||
|
||||
if (FileExists(actualFile + ".exe")) {
|
||||
StartProcess("./tools/pdb2mdb/pdb2mdb.exe", new ProcessSettings()
|
||||
.WithArguments(args => args.Append(actualFile + ".exe")));
|
||||
}
|
||||
|
||||
if (FileExists(actualFile + ".dll")) {
|
||||
StartProcess("./tools/pdb2mdb/pdb2mdb.exe", new ProcessSettings()
|
||||
.WithArguments(args => args.Append(actualFile + ".dll")));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Build Tasks
|
||||
Task("Compile").Does(() => {
|
||||
// Build
|
||||
if (DirectoryExists(outputFolder)) {
|
||||
DeleteDirectory(outputFolder, true);
|
||||
}
|
||||
|
||||
MSBuild(solutionFile, config =>
|
||||
config.UseToolVersion(MSBuildToolVersion.VS2015)
|
||||
.WithTarget("Clean")
|
||||
.SetVerbosity(Verbosity.Minimal));
|
||||
|
||||
NuGetRestore(solutionFile);
|
||||
|
||||
MSBuild(solutionFile, config =>
|
||||
config.UseToolVersion(MSBuildToolVersion.VS2015)
|
||||
.SetPlatformTarget(PlatformTarget.x86)
|
||||
.SetConfiguration("Release")
|
||||
.WithProperty("AllowedReferenceRelatedFileExtensions", new string[] { ".pdb" })
|
||||
.WithTarget("Build")
|
||||
.SetVerbosity(Verbosity.Minimal));
|
||||
|
||||
CleanFolder(outputFolder, false);
|
||||
|
||||
// Add JsonNet
|
||||
DeleteFiles(outputFolder + "/Newtonsoft.Json.*");
|
||||
CopyFiles(sourceFolder + "/packages/Newtonsoft.Json.*/lib/net35/*.dll", outputFolder);
|
||||
CopyFiles(sourceFolder + "/packages/Newtonsoft.Json.*/lib/net35/*.dll", updateFolder);
|
||||
|
||||
// Remove Mono stuff
|
||||
DeleteFile(outputFolder + "/Mono.Posix.dll");
|
||||
});
|
||||
|
||||
Task("Gulp").Does(() => {
|
||||
NpmInstall(new NpmInstallSettings {
|
||||
LogLevel = NpmLogLevel.Silent,
|
||||
WorkingDirectory = "./",
|
||||
Production = true
|
||||
});
|
||||
|
||||
NpmRunScript("build");
|
||||
});
|
||||
|
||||
Task("PackageMono").Does(() => {
|
||||
// Start mono package
|
||||
if (DirectoryExists(outputFolderMono)) {
|
||||
DeleteDirectory(outputFolderMono, true);
|
||||
}
|
||||
|
||||
CopyDirectory(outputFolder, outputFolderMono);
|
||||
|
||||
// Create MDBs
|
||||
CreateMdbs(outputFolderMono);
|
||||
|
||||
// Remove PDBs
|
||||
DeleteFiles(outputFolderMono + "/**/*.pdb");
|
||||
|
||||
// Remove service helpers
|
||||
DeleteFiles(outputFolderMono + "/ServiceUninstall.*");
|
||||
DeleteFiles(outputFolderMono + "/ServiceInstall.*");
|
||||
|
||||
// Remove native windows binaries
|
||||
DeleteFiles(outputFolderMono + "/sqlite3.*");
|
||||
DeleteFiles(outputFolderMono + "/MediaInfo.*");
|
||||
|
||||
// Adding NzbDrone.Core.dll.config (for dllmap)
|
||||
CopyFile(sourceFolder + "/NzbDrone.Core/NzbDrone.Core.dll.config", outputFolderMono + "/NzbDrone.Core.dll.config");
|
||||
|
||||
// Adding CurlSharp.dll.config (for dllmap)
|
||||
CopyFile(sourceFolder + "/NzbDrone.Common/CurlSharp.dll.config", outputFolderMono + "/CurlSharp.dll.config");
|
||||
|
||||
// Renaming Radarr.Console.exe to Radarr.exe
|
||||
DeleteFiles(outputFolderMono + "/Radarr.exe*");
|
||||
MoveFile(outputFolderMono + "/Radarr.Console.exe", outputFolderMono + "/Radarr.exe");
|
||||
MoveFile(outputFolderMono + "/Radarr.Console.exe.config", outputFolderMono + "/Radarr.exe.config");
|
||||
MoveFile(outputFolderMono + "/Radarr.Console.exe.mdb", outputFolderMono + "/Radarr.exe.mdb");
|
||||
|
||||
// Remove NzbDrone.Windows.*
|
||||
DeleteFiles(outputFolderMono + "/NzbDrone.Windows.*");
|
||||
|
||||
// Adding NzbDrone.Mono to updatePackage
|
||||
CopyFiles(outputFolderMono + "/NzbDrone.Mono.*", updateFolderMono);
|
||||
});
|
||||
|
||||
Task("PackageOsx").Does(() => {
|
||||
// Start osx package
|
||||
if (DirectoryExists(outputFolderOsx)) {
|
||||
DeleteDirectory(outputFolderOsx, true);
|
||||
}
|
||||
|
||||
CopyDirectory(outputFolderMono, outputFolderOsx);
|
||||
|
||||
// Adding sqlite dylibs
|
||||
CopyFiles(sourceFolder + "/Libraries/Sqlite/*.dylib", outputFolderOsx);
|
||||
|
||||
// Adding MediaInfo dylib
|
||||
CopyFiles(sourceFolder + "/Libraries/MediaInfo/*.dylib", outputFolderOsx);
|
||||
|
||||
// Chmod as executable
|
||||
StartProcess(@"C:\cygwin64\bin\chmod.exe", new ProcessSettings()
|
||||
.WithArguments(args => args
|
||||
.Append("+x")
|
||||
.Append(outputFolderOsx + "/Radarr")));
|
||||
|
||||
// Adding Startup script
|
||||
CopyFile("./osx/Radarr", outputFolderOsx + "/Radarr");
|
||||
});
|
||||
|
||||
Task("PackageOsxApp").Does(() => {
|
||||
// Start osx app package
|
||||
if (DirectoryExists(outputFolderOsxApp)) {
|
||||
DeleteDirectory(outputFolderOsxApp, true);
|
||||
}
|
||||
|
||||
CreateDirectory(outputFolderOsxApp);
|
||||
|
||||
// Copy osx package files
|
||||
CopyDirectory("./osx/Radarr.app", outputFolderOsxApp + "/Radarr.app");
|
||||
CopyDirectory(outputFolderOsx, outputFolderOsxApp + "/Radarr.app/Contents/MacOS");
|
||||
});
|
||||
|
||||
Task("PackageTests").Does(() => {
|
||||
// Start tests package
|
||||
if (DirectoryExists(testPackageFolder)) {
|
||||
DeleteDirectory(testPackageFolder, true);
|
||||
}
|
||||
|
||||
CreateDirectory(testPackageFolder);
|
||||
|
||||
// Copy tests
|
||||
CopyFiles(sourceFolder + "/" + testSearchPattern + "/*", testPackageFolder);
|
||||
foreach (var directory in System.IO.Directory.GetDirectories(sourceFolder, "*.Test")) {
|
||||
var releaseDirectory = directory + "/bin/x86/Release";
|
||||
if (DirectoryExists(releaseDirectory)) {
|
||||
foreach (var releaseSubDirectory in System.IO.Directory.GetDirectories(releaseDirectory)) {
|
||||
Information(System.IO.Path.GetDirectoryName(releaseSubDirectory));
|
||||
CopyDirectory(releaseSubDirectory, testPackageFolder + "/" + System.IO.Path.GetFileName(releaseSubDirectory));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Install NUnit.ConsoleRunner
|
||||
NuGetInstall("NUnit.ConsoleRunner", new NuGetInstallSettings {
|
||||
Version = "3.2.0",
|
||||
OutputDirectory = testPackageFolder
|
||||
});
|
||||
|
||||
// Copy dlls
|
||||
CopyFiles(outputFolder + "/*.dll", testPackageFolder);
|
||||
|
||||
// Copy scripts
|
||||
CopyFiles("./*.sh", testPackageFolder);
|
||||
|
||||
// Create MDBs for tests
|
||||
CreateMdbs(testPackageFolder);
|
||||
|
||||
// Remove config
|
||||
DeleteFiles(testPackageFolder + "/*.log.config");
|
||||
|
||||
// Clean
|
||||
CleanFolder(testPackageFolder, true);
|
||||
|
||||
// Adding NzbDrone.Core.dll.config (for dllmap)
|
||||
CopyFile(sourceFolder + "/NzbDrone.Core/NzbDrone.Core.dll.config", testPackageFolder + "/NzbDrone.Core.dll.config");
|
||||
|
||||
// Adding CurlSharp.dll.config (for dllmap)
|
||||
CopyFile(sourceFolder + "/NzbDrone.Common/CurlSharp.dll.config", testPackageFolder + "/CurlSharp.dll.config");
|
||||
|
||||
// Adding CurlSharp libraries
|
||||
CopyFiles(sourceFolder + "/ExternalModules/CurlSharp/libs/i386/*", testPackageFolder);
|
||||
});
|
||||
|
||||
Task("CleanupWindowsPackage").Does(() => {
|
||||
// Remove mono
|
||||
DeleteFiles(outputFolder + "/NzbDrone.Mono.*");
|
||||
|
||||
// Adding NzbDrone.Windows to updatePackage
|
||||
CopyFiles(outputFolder + "/NzbDrone.Windows.*", updateFolder);
|
||||
});
|
||||
|
||||
Task("Build")
|
||||
.IsDependentOn("Compile")
|
||||
.IsDependentOn("Gulp")
|
||||
.IsDependentOn("PackageMono")
|
||||
.IsDependentOn("PackageOsx")
|
||||
.IsDependentOn("PackageOsxApp")
|
||||
.IsDependentOn("PackageTests")
|
||||
.IsDependentOn("CleanupWindowsPackage");
|
||||
|
||||
// Build Artifacts
|
||||
Task("CleanArtifacts").Does(() => {
|
||||
if (DirectoryExists(artifactsFolder)) {
|
||||
DeleteDirectory(artifactsFolder, true);
|
||||
}
|
||||
|
||||
CreateDirectory(artifactsFolder);
|
||||
});
|
||||
|
||||
Task("ArtifactsWindows").Does(() => {
|
||||
CopyDirectory(outputFolder, artifactsFolderWindows + "/Radarr");
|
||||
});
|
||||
|
||||
Task("ArtifactsWindowsInstaller").Does(() => {
|
||||
InnoSetup("./setup/nzbdrone.iss", new InnoSetupSettings {
|
||||
OutputDirectory = artifactsFolder,
|
||||
ToolPath = "./setup/inno/ISCC.exe"
|
||||
});
|
||||
});
|
||||
|
||||
Task("ArtifactsLinux").Does(() => {
|
||||
CopyDirectory(outputFolderMono, artifactsFolderLinux + "/Radarr");
|
||||
});
|
||||
|
||||
Task("ArtifactsOsx").Does(() => {
|
||||
CopyDirectory(outputFolderOsx, artifactsFolderOsx + "/Radarr");
|
||||
});
|
||||
|
||||
Task("ArtifactsOsxApp").Does(() => {
|
||||
CopyDirectory(outputFolderOsxApp, artifactsFolderOsxApp);
|
||||
});
|
||||
|
||||
Task("CompressArtifacts").Does(() => {
|
||||
var prefix = "";
|
||||
|
||||
if (AppVeyor.IsRunningOnAppVeyor) {
|
||||
prefix += AppVeyor.Environment.Repository.Branch.Replace("/", "-") + ".";
|
||||
prefix += AppVeyor.Environment.Build.Version + ".";
|
||||
}
|
||||
|
||||
Zip(artifactsFolderWindows, artifactsFolder + "/Radarr." + prefix + "windows.zip");
|
||||
GZipCompress(artifactsFolderLinux, artifactsFolder + "/Radarr." + prefix + "linux.tar.gz");
|
||||
GZipCompress(artifactsFolderOsx, artifactsFolder + "/Radarr." + prefix + "osx.tar.gz");
|
||||
Zip(artifactsFolderOsxApp, artifactsFolder + "/Radarr." + prefix + "osx-app.zip");
|
||||
});
|
||||
|
||||
Task("Artifacts")
|
||||
.IsDependentOn("CleanArtifacts")
|
||||
.IsDependentOn("ArtifactsWindows")
|
||||
.IsDependentOn("ArtifactsWindowsInstaller")
|
||||
.IsDependentOn("ArtifactsLinux")
|
||||
.IsDependentOn("ArtifactsOsx")
|
||||
.IsDependentOn("ArtifactsOsxApp")
|
||||
.IsDependentOn("CompressArtifacts");
|
||||
|
||||
// Run
|
||||
RunTarget("Build");
|
||||
RunTarget("Artifacts");
|
||||
@@ -1,189 +0,0 @@
|
||||
##########################################################################
|
||||
# This is the Cake bootstrapper script for PowerShell.
|
||||
# This file was downloaded from https://github.com/cake-build/resources
|
||||
# Feel free to change this file to fit your needs.
|
||||
##########################################################################
|
||||
|
||||
<#
|
||||
.SYNOPSIS
|
||||
This is a Powershell script to bootstrap a Cake build.
|
||||
.DESCRIPTION
|
||||
This Powershell script will download NuGet if missing, restore NuGet tools (including Cake)
|
||||
and execute your Cake build script with the parameters you provide.
|
||||
.PARAMETER Script
|
||||
The build script to execute.
|
||||
.PARAMETER Target
|
||||
The build script target to run.
|
||||
.PARAMETER Configuration
|
||||
The build configuration to use.
|
||||
.PARAMETER Verbosity
|
||||
Specifies the amount of information to be displayed.
|
||||
.PARAMETER Experimental
|
||||
Tells Cake to use the latest Roslyn release.
|
||||
.PARAMETER WhatIf
|
||||
Performs a dry run of the build script.
|
||||
No tasks will be executed.
|
||||
.PARAMETER Mono
|
||||
Tells Cake to use the Mono scripting engine.
|
||||
.PARAMETER SkipToolPackageRestore
|
||||
Skips restoring of packages.
|
||||
.PARAMETER ScriptArgs
|
||||
Remaining arguments are added here.
|
||||
.LINK
|
||||
http://cakebuild.net
|
||||
#>
|
||||
|
||||
[CmdletBinding()]
|
||||
Param(
|
||||
[string]$Script = "build-appveyor.cake",
|
||||
[string]$Target = "Default",
|
||||
[ValidateSet("Release", "Debug")]
|
||||
[string]$Configuration = "Release",
|
||||
[ValidateSet("Quiet", "Minimal", "Normal", "Verbose", "Diagnostic")]
|
||||
[string]$Verbosity = "Verbose",
|
||||
[switch]$Experimental,
|
||||
[Alias("DryRun","Noop")]
|
||||
[switch]$WhatIf,
|
||||
[switch]$Mono,
|
||||
[switch]$SkipToolPackageRestore,
|
||||
[Parameter(Position=0,Mandatory=$false,ValueFromRemainingArguments=$true)]
|
||||
[string[]]$ScriptArgs
|
||||
)
|
||||
|
||||
[Reflection.Assembly]::LoadWithPartialName("System.Security") | Out-Null
|
||||
function MD5HashFile([string] $filePath)
|
||||
{
|
||||
if ([string]::IsNullOrEmpty($filePath) -or !(Test-Path $filePath -PathType Leaf))
|
||||
{
|
||||
return $null
|
||||
}
|
||||
|
||||
[System.IO.Stream] $file = $null;
|
||||
[System.Security.Cryptography.MD5] $md5 = $null;
|
||||
try
|
||||
{
|
||||
$md5 = [System.Security.Cryptography.MD5]::Create()
|
||||
$file = [System.IO.File]::OpenRead($filePath)
|
||||
return [System.BitConverter]::ToString($md5.ComputeHash($file))
|
||||
}
|
||||
finally
|
||||
{
|
||||
if ($file -ne $null)
|
||||
{
|
||||
$file.Dispose()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Write-Host "Preparing to run build script..."
|
||||
|
||||
if(!$PSScriptRoot){
|
||||
$PSScriptRoot = Split-Path $MyInvocation.MyCommand.Path -Parent
|
||||
}
|
||||
|
||||
$TOOLS_DIR = Join-Path $PSScriptRoot "tools"
|
||||
$NUGET_EXE = Join-Path $TOOLS_DIR "nuget/nuget.exe"
|
||||
$CAKE_EXE = Join-Path $TOOLS_DIR "Cake/Cake.exe"
|
||||
$NUGET_URL = "https://dist.nuget.org/win-x86-commandline/latest/nuget.exe"
|
||||
$PACKAGES_CONFIG = Join-Path $TOOLS_DIR "packages.config"
|
||||
$PACKAGES_CONFIG_MD5 = Join-Path $TOOLS_DIR "packages.config.md5sum"
|
||||
|
||||
# Should we use mono?
|
||||
$UseMono = "";
|
||||
if($Mono.IsPresent) {
|
||||
Write-Verbose -Message "Using the Mono based scripting engine."
|
||||
$UseMono = "-mono"
|
||||
}
|
||||
|
||||
# Should we use the new Roslyn?
|
||||
$UseExperimental = "";
|
||||
if($Experimental.IsPresent -and !($Mono.IsPresent)) {
|
||||
Write-Verbose -Message "Using experimental version of Roslyn."
|
||||
$UseExperimental = "-experimental"
|
||||
}
|
||||
|
||||
# Is this a dry run?
|
||||
$UseDryRun = "";
|
||||
if($WhatIf.IsPresent) {
|
||||
$UseDryRun = "-dryrun"
|
||||
}
|
||||
|
||||
# Make sure tools folder exists
|
||||
if ((Test-Path $PSScriptRoot) -and !(Test-Path $TOOLS_DIR)) {
|
||||
Write-Verbose -Message "Creating tools directory..."
|
||||
New-Item -Path $TOOLS_DIR -Type directory | out-null
|
||||
}
|
||||
|
||||
# Make sure that packages.config exist.
|
||||
if (!(Test-Path $PACKAGES_CONFIG)) {
|
||||
Write-Verbose -Message "Downloading packages.config..."
|
||||
try { (New-Object System.Net.WebClient).DownloadFile("http://cakebuild.net/download/bootstrapper/packages", $PACKAGES_CONFIG) } catch {
|
||||
Throw "Could not download packages.config."
|
||||
}
|
||||
}
|
||||
|
||||
# Try find NuGet.exe in path if not exists
|
||||
if (!(Test-Path $NUGET_EXE)) {
|
||||
Write-Verbose -Message "Trying to find nuget.exe in PATH..."
|
||||
$existingPaths = $Env:Path -Split ';' | Where-Object { (![string]::IsNullOrEmpty($_)) -and (Test-Path $_) }
|
||||
$NUGET_EXE_IN_PATH = Get-ChildItem -Path $existingPaths -Filter "nuget.exe" | Select -First 1
|
||||
if ($NUGET_EXE_IN_PATH -ne $null -and (Test-Path $NUGET_EXE_IN_PATH.FullName)) {
|
||||
Write-Verbose -Message "Found in PATH at $($NUGET_EXE_IN_PATH.FullName)."
|
||||
$NUGET_EXE = $NUGET_EXE_IN_PATH.FullName
|
||||
}
|
||||
}
|
||||
|
||||
# Try download NuGet.exe if not exists
|
||||
if (!(Test-Path $NUGET_EXE)) {
|
||||
Write-Verbose -Message "Downloading NuGet.exe..."
|
||||
try {
|
||||
(New-Object System.Net.WebClient).DownloadFile($NUGET_URL, $NUGET_EXE)
|
||||
} catch {
|
||||
Throw "Could not download NuGet.exe."
|
||||
}
|
||||
}
|
||||
|
||||
# Save nuget.exe path to environment to be available to child processed
|
||||
$ENV:NUGET_EXE = $NUGET_EXE
|
||||
|
||||
# Restore tools from NuGet?
|
||||
if(-Not $SkipToolPackageRestore.IsPresent) {
|
||||
Push-Location
|
||||
Set-Location $TOOLS_DIR
|
||||
|
||||
# Check for changes in packages.config and remove installed tools if true.
|
||||
[string] $md5Hash = MD5HashFile($PACKAGES_CONFIG)
|
||||
if((!(Test-Path $PACKAGES_CONFIG_MD5)) -Or
|
||||
($md5Hash -ne (Get-Content $PACKAGES_CONFIG_MD5 ))) {
|
||||
Write-Verbose -Message "Missing or changed package.config hash..."
|
||||
Get-ChildItem -Path $TOOLS_DIR -Recurse -Exclude packages.config |
|
||||
Select -ExpandProperty FullName |
|
||||
Where {$_ -notlike (Join-Path $TOOLS_DIR "pdb2mdb*")} |
|
||||
Where {$_ -notlike (Join-Path $TOOLS_DIR "nuget*")} |
|
||||
sort length -Descending |
|
||||
Remove-Item -Recurse
|
||||
}
|
||||
|
||||
Write-Verbose -Message "Restoring tools from NuGet..."
|
||||
$NuGetOutput = Invoke-Expression "&`"$NUGET_EXE`" install -ExcludeVersion -OutputDirectory `"$TOOLS_DIR`""
|
||||
|
||||
if ($LASTEXITCODE -ne 0) {
|
||||
Throw "An error occured while restoring NuGet tools."
|
||||
}
|
||||
else
|
||||
{
|
||||
$md5Hash | Out-File $PACKAGES_CONFIG_MD5 -Encoding "ASCII"
|
||||
}
|
||||
Write-Verbose -Message ($NuGetOutput | out-string)
|
||||
Pop-Location
|
||||
}
|
||||
|
||||
# Make sure that Cake has been installed.
|
||||
if (!(Test-Path $CAKE_EXE)) {
|
||||
Throw "Could not find Cake.exe at $CAKE_EXE"
|
||||
}
|
||||
|
||||
# Start Cake
|
||||
Write-Host "Running build script..."
|
||||
Invoke-Expression "& `"$CAKE_EXE`" `"$Script`" -target=`"$Target`" -configuration=`"$Configuration`" -verbosity=`"$Verbosity`" $UseMono $UseDryRun $UseExperimental $ScriptArgs"
|
||||
exit $LASTEXITCODE
|
||||
329
build.sh
@@ -1,17 +1,25 @@
|
||||
#! /bin/bash
|
||||
msBuild='/c/Program Files (x86)/MSBuild/14.0/Bin'
|
||||
msBuildVersion='15.0'
|
||||
outputFolder='./_output'
|
||||
outputFolderMono='./_output_mono'
|
||||
outputFolderOsx='./_output_osx'
|
||||
outputFolderOsxApp='./_output_osx_app'
|
||||
outputFolderLinux='./_output_linux'
|
||||
outputFolderMacOS='./_output_macos'
|
||||
outputFolderMacOSApp='./_output_macos_app'
|
||||
testPackageFolder='./_tests/'
|
||||
testSearchPattern='*.Test/bin/x86/Release'
|
||||
testSearchPattern='*.Test/bin/x86/Release/*'
|
||||
sourceFolder='./src'
|
||||
slnFile=$sourceFolder/NzbDrone.sln
|
||||
updateFolder=$outputFolder/NzbDrone.Update
|
||||
updateFolderMono=$outputFolderMono/NzbDrone.Update
|
||||
updateFolderMono=$outputFolderLinux/NzbDrone.Update
|
||||
|
||||
#Artifact variables
|
||||
artifactsFolder="./_artifacts";
|
||||
artifactsFolderWindows=$artifactsFolder/windows
|
||||
artifactsFolderLinux=$artifactsFolder/linux
|
||||
artifactsFolderMacOS=$artifactsFolder/macos
|
||||
artifactsFolderMacOSApp=$artifactsFolder/macos-app
|
||||
|
||||
nuget='tools/nuget/nuget.exe';
|
||||
vswhere='tools/vswhere/vswhere.exe';
|
||||
|
||||
CheckExitCode()
|
||||
{
|
||||
"$@"
|
||||
@@ -23,12 +31,21 @@ CheckExitCode()
|
||||
return $status
|
||||
}
|
||||
|
||||
ProgressStart()
|
||||
{
|
||||
echo "Start '$1'"
|
||||
}
|
||||
|
||||
ProgressEnd()
|
||||
{
|
||||
echo "Finish '$1'"
|
||||
}
|
||||
|
||||
CleanFolder()
|
||||
{
|
||||
local path=$1
|
||||
local keepConfigFiles=$2
|
||||
|
||||
|
||||
find $path -name "*.transform" -exec rm "{}" \;
|
||||
|
||||
if [ $keepConfigFiles != true ] ; then
|
||||
@@ -39,9 +56,6 @@ CleanFolder()
|
||||
find $path -name "FluentValidation.resources.dll" -exec rm "{}" \;
|
||||
find $path -name "App.config" -exec rm "{}" \;
|
||||
|
||||
echo "Removing .less files"
|
||||
find $path -name "*.less" -exec rm "{}" \;
|
||||
|
||||
echo "Removing vshost files"
|
||||
find $path -name "*.vshost.exe" -exec rm "{}" \;
|
||||
|
||||
@@ -52,208 +66,218 @@ CleanFolder()
|
||||
find $path -depth -empty -type d -exec rm -r "{}" \;
|
||||
}
|
||||
|
||||
|
||||
|
||||
AddJsonNet()
|
||||
{
|
||||
rm $outputFolder/Newtonsoft.Json.*
|
||||
cp $sourceFolder/packages/Newtonsoft.Json.*/lib/net35/*.dll $outputFolder
|
||||
cp $sourceFolder/packages/Newtonsoft.Json.*/lib/net35/*.dll $outputFolder/NzbDrone.Update
|
||||
}
|
||||
|
||||
BuildWithMSBuild()
|
||||
{
|
||||
export PATH=$msBuild:$PATH
|
||||
CheckExitCode MSBuild.exe $slnFile //t:Clean //m
|
||||
msBuildPath=`$vswhere -latest -products \* -requires Microsoft.Component.MSBuild -find MSBuild\\\\\*\*\\\\Bin\\\\MSBuild.exe`
|
||||
msBuildPath=${msBuildPath/C:\\/\/c\/}
|
||||
msBuildPath=${msBuildPath//\\/\/}
|
||||
msBuildDir=$(dirname "$msBuildPath")
|
||||
echo $msBuildPath
|
||||
|
||||
export PATH=$msBuildDir:$PATH
|
||||
CheckExitCode MSBuild.exe $slnFile //p:Configuration=Release //p:Platform=x86 //t:Clean //m
|
||||
$nuget restore $slnFile
|
||||
CheckExitCode MSBuild.exe $slnFile //p:Configuration=Release //p:Platform=x86 //t:Build //m //p:AllowedReferenceRelatedFileExtensions=.pdb
|
||||
}
|
||||
|
||||
RestoreNuget()
|
||||
{
|
||||
export MONO_IOMAP=case
|
||||
mono $nuget restore $slnFile
|
||||
}
|
||||
|
||||
CleanWithXbuild()
|
||||
{
|
||||
export MONO_IOMAP=case
|
||||
CheckExitCode xbuild /t:Clean $slnFile
|
||||
}
|
||||
|
||||
BuildWithXbuild()
|
||||
{
|
||||
export MONO_IOMAP=case
|
||||
CheckExitCode xbuild /p:Configuration=Release /p:Platform=x86 /t:Build /p:AllowedReferenceRelatedFileExtensions=.pdb $slnFile
|
||||
CheckExitCode msbuild /p:Configuration=Debug /t:Clean $slnFile
|
||||
CheckExitCode msbuild /p:Configuration=Release /t:Clean $slnFile
|
||||
mono $nuget locals all -clear
|
||||
mono $nuget restore $slnFile
|
||||
CheckExitCode msbuild /p:Configuration=Release /p:Platform=x86 /t:Build /p:AllowedReferenceRelatedFileExtensions=.pdb $slnFile
|
||||
}
|
||||
|
||||
Build()
|
||||
{
|
||||
echo "##teamcity[progressStart 'Build']"
|
||||
ProgressStart 'Build'
|
||||
|
||||
rm -rf $outputFolder
|
||||
rm -rf $testPackageFolder
|
||||
|
||||
if [ $runtime = "dotnet" ] ; then
|
||||
BuildWithMSBuild
|
||||
else
|
||||
CleanWithXbuild
|
||||
RestoreNuget
|
||||
BuildWithXbuild
|
||||
fi
|
||||
|
||||
CleanFolder $outputFolder false
|
||||
|
||||
AddJsonNet
|
||||
|
||||
echo "Removing Mono.Posix.dll"
|
||||
rm $outputFolder/Mono.Posix.dll
|
||||
|
||||
echo "##teamcity[progressFinish 'Build']"
|
||||
echo "Adding LICENSE.md"
|
||||
cp LICENSE.md $outputFolder
|
||||
|
||||
ProgressEnd 'Build'
|
||||
}
|
||||
|
||||
RunGulp()
|
||||
{
|
||||
echo "##teamcity[progressStart 'npm install']"
|
||||
ProgressStart 'npm install'
|
||||
npm-cache install npm || CheckExitCode npm install
|
||||
echo "##teamcity[progressFinish 'npm install']"
|
||||
ProgressEnd 'npm install'
|
||||
|
||||
echo "##teamcity[progressStart 'Running gulp']"
|
||||
ProgressStart 'Running gulp'
|
||||
CheckExitCode npm run build
|
||||
echo "##teamcity[progressFinish 'Running gulp']"
|
||||
}
|
||||
|
||||
CreateMdbs()
|
||||
{
|
||||
local path=$1
|
||||
if [ $runtime = "dotnet" ] ; then
|
||||
local pdbFiles=( $(find $path -name "*.pdb") )
|
||||
for filename in "${pdbFiles[@]}"
|
||||
do
|
||||
if [ -e ${filename%.pdb}.dll ] ; then
|
||||
tools/pdb2mdb/pdb2mdb.exe ${filename%.pdb}.dll
|
||||
fi
|
||||
if [ -e ${filename%.pdb}.exe ] ; then
|
||||
tools/pdb2mdb/pdb2mdb.exe ${filename%.pdb}.exe
|
||||
fi
|
||||
done
|
||||
fi
|
||||
ProgressEnd 'Running gulp'
|
||||
}
|
||||
|
||||
PackageMono()
|
||||
{
|
||||
echo "##teamcity[progressStart 'Creating Mono Package']"
|
||||
rm -rf $outputFolderMono
|
||||
cp -r $outputFolder $outputFolderMono
|
||||
ProgressStart 'Creating Mono Package'
|
||||
|
||||
echo "Creating MDBs"
|
||||
CreateMdbs $outputFolderMono
|
||||
rm -rf $outputFolderLinux
|
||||
|
||||
echo "Removing PDBs"
|
||||
find $outputFolderMono -name "*.pdb" -exec rm "{}" \;
|
||||
echo "Copying Binaries"
|
||||
cp -r $outputFolder $outputFolderLinux
|
||||
|
||||
echo "Removing Service helpers"
|
||||
rm -f $outputFolderMono/ServiceUninstall.*
|
||||
rm -f $outputFolderMono/ServiceInstall.*
|
||||
rm -f $outputFolderLinux/ServiceUninstall.*
|
||||
rm -f $outputFolderLinux/ServiceInstall.*
|
||||
|
||||
echo "Removing native windows binaries Sqlite, MediaInfo"
|
||||
rm -f $outputFolderMono/sqlite3.*
|
||||
rm -f $outputFolderMono/MediaInfo.*
|
||||
rm -f $outputFolderLinux/sqlite3.*
|
||||
rm -f $outputFolderLinux/MediaInfo.*
|
||||
|
||||
echo "Adding NzbDrone.Core.dll.config (for dllmap)"
|
||||
cp $sourceFolder/NzbDrone.Core/NzbDrone.Core.dll.config $outputFolderMono
|
||||
cp $sourceFolder/NzbDrone.Core/NzbDrone.Core.dll.config $outputFolderLinux
|
||||
|
||||
echo "Adding CurlSharp.dll.config (for dllmap)"
|
||||
cp $sourceFolder/NzbDrone.Common/CurlSharp.dll.config $outputFolderMono
|
||||
|
||||
echo "Renaming NzbDrone.Console.exe to NzbDrone.exe"
|
||||
rm $outputFolderMono/Radarr.exe*
|
||||
for file in $outputFolderMono/Radarr.Console.exe*; do
|
||||
echo "Renaming Radarr.Console.exe to Radarr.exe"
|
||||
rm $outputFolderLinux/Radarr.exe*
|
||||
for file in $outputFolderLinux/Radarr.Console.exe*; do
|
||||
mv "$file" "${file//.Console/}"
|
||||
done
|
||||
|
||||
echo "Removing NzbDrone.Windows"
|
||||
rm $outputFolderMono/NzbDrone.Windows.*
|
||||
rm $outputFolderLinux/NzbDrone.Windows.*
|
||||
|
||||
echo "Adding NzbDrone.Mono to UpdatePackage"
|
||||
cp $outputFolderMono/NzbDrone.Mono.* $updateFolderMono
|
||||
cp $outputFolderLinux/NzbDrone.Mono.* $updateFolderMono
|
||||
|
||||
echo "##teamcity[progressFinish 'Creating Mono Package']"
|
||||
ProgressEnd 'Creating Mono Package'
|
||||
}
|
||||
|
||||
PackageOsx()
|
||||
PackageMacOS()
|
||||
{
|
||||
echo "##teamcity[progressStart 'Creating OS X Package']"
|
||||
rm -rf $outputFolderOsx
|
||||
cp -r $outputFolderMono $outputFolderOsx
|
||||
ProgressStart 'Creating MacOS Package'
|
||||
|
||||
echo "Adding sqlite dylibs"
|
||||
cp $sourceFolder/Libraries/Sqlite/*.dylib $outputFolderOsx
|
||||
|
||||
echo "Adding MediaInfo dylib"
|
||||
cp $sourceFolder/Libraries/MediaInfo/*.dylib $outputFolderOsx
|
||||
rm -rf $outputFolderMacOS
|
||||
mkdir $outputFolderMacOS
|
||||
|
||||
echo "Adding Startup script"
|
||||
cp ./osx/Radarr $outputFolderOsx
|
||||
cp ./macOS/Radarr $outputFolderMacOS
|
||||
|
||||
echo "##teamcity[progressFinish 'Creating OS X Package']"
|
||||
echo "Copying Binaries"
|
||||
cp -r $outputFolderLinux/* $outputFolderMacOS
|
||||
|
||||
echo "Adding sqlite dylibs"
|
||||
cp $sourceFolder/Libraries/Sqlite/*.dylib $outputFolderMacOS
|
||||
|
||||
echo "Adding MediaInfo dylib"
|
||||
cp $sourceFolder/Libraries/MediaInfo/*.dylib $outputFolderMacOS
|
||||
|
||||
ProgressEnd 'Creating MacOS Package'
|
||||
}
|
||||
|
||||
PackageOsxApp()
|
||||
PackageMacOSApp()
|
||||
{
|
||||
echo "##teamcity[progressStart 'Creating OS X App Package']"
|
||||
rm -rf $outputFolderOsxApp
|
||||
mkdir $outputFolderOsxApp
|
||||
ProgressStart 'Creating macOS App Package'
|
||||
|
||||
cp -r ./osx/Radarr.app $outputFolderOsxApp
|
||||
cp -r $outputFolderOsx $outputFolderOsxApp/Radarr.app/Contents/MacOS
|
||||
rm -rf $outputFolderMacOSApp
|
||||
mkdir $outputFolderMacOSApp
|
||||
cp -r ./macOS/Radarr.app $outputFolderMacOSApp
|
||||
mkdir -p $outputFolderMacOSApp/Radarr.app/Contents/MacOS
|
||||
|
||||
echo "##teamcity[progressFinish 'Creating OS X App Package']"
|
||||
echo "Adding Startup script"
|
||||
cp ./macOS/Radarr $outputFolderMacOSApp/Radarr.app/Contents/MacOS
|
||||
|
||||
echo "Copying Binaries"
|
||||
cp -r $outputFolderLinux/* $outputFolderMacOSApp/Radarr.app/Contents/MacOS
|
||||
|
||||
echo "Adding sqlite dylibs"
|
||||
cp $sourceFolder/Libraries/Sqlite/*.dylib $outputFolderMacOSApp/Radarr.app/Contents/MacOS
|
||||
|
||||
echo "Adding MediaInfo dylib"
|
||||
cp $sourceFolder/Libraries/MediaInfo/*.dylib $outputFolderMacOSApp/Radarr.app/Contents/MacOS
|
||||
|
||||
echo "Removing Update Folder"
|
||||
rm -r $outputFolderMacOSApp/Radarr.app/Contents/MacOS/NzbDrone.Update
|
||||
|
||||
ProgressEnd 'Creating macOS App Package'
|
||||
}
|
||||
|
||||
PackageTests()
|
||||
{
|
||||
echo "Packaging Tests"
|
||||
echo "##teamcity[progressStart 'Creating Test Package']"
|
||||
ProgressStart 'Creating Test Package'
|
||||
|
||||
rm -rf $testPackageFolder
|
||||
mkdir $testPackageFolder
|
||||
|
||||
find $sourceFolder -path $testSearchPattern -exec cp -r -u -T "{}" $testPackageFolder \;
|
||||
find . -maxdepth 6 -path $testSearchPattern -exec cp -r "{}" $testPackageFolder \;
|
||||
|
||||
if [ $runtime = "dotnet" ] ; then
|
||||
$nuget install NUnit.Runners -Version 3.2.1 -Output $testPackageFolder
|
||||
$nuget install NUnit.ConsoleRunner -Version 3.10.0 -Output $testPackageFolder
|
||||
else
|
||||
mono $nuget install NUnit.Runners -Version 3.2.1 -Output $testPackageFolder
|
||||
mono $nuget install NUnit.ConsoleRunner -Version 3.10.0 -Output $testPackageFolder
|
||||
fi
|
||||
|
||||
cp $outputFolder/*.dll $testPackageFolder
|
||||
cp ./*.sh $testPackageFolder
|
||||
|
||||
echo "Creating MDBs for tests"
|
||||
CreateMdbs $testPackageFolder
|
||||
cp $outputFolder/*.exe $testPackageFolder
|
||||
cp ./test.sh $testPackageFolder
|
||||
|
||||
rm -f $testPackageFolder/*.log.config
|
||||
|
||||
CleanFolder $testPackageFolder true
|
||||
|
||||
echo "Adding NzbDrone.Core.dll.config (for dllmap)"
|
||||
cp $sourceFolder/NzbDrone.Core/NzbDrone.Core.dll.config $testPackageFolder
|
||||
|
||||
echo "Adding CurlSharp.dll.config (for dllmap)"
|
||||
cp $sourceFolder/NzbDrone.Common/CurlSharp.dll.config $testPackageFolder
|
||||
|
||||
echo "Copying CurlSharp libraries"
|
||||
cp $sourceFolder/ExternalModules/CurlSharp/libs/i386/* $testPackageFolder
|
||||
|
||||
echo "##teamcity[progressFinish 'Creating Test Package']"
|
||||
echo "Adding sqlite and mediainfo dylibs"
|
||||
cp $sourceFolder/Libraries/MediaInfo/*.dylib $testPackageFolder
|
||||
cp $sourceFolder/Libraries/Sqlite/*.dylib $testPackageFolder
|
||||
|
||||
ProgressEnd 'Creating Test Package'
|
||||
}
|
||||
|
||||
CleanupWindowsPackage()
|
||||
{
|
||||
ProgressStart 'Cleaning Windows Package'
|
||||
|
||||
echo "Removing NzbDrone.Mono"
|
||||
rm -f $outputFolder/NzbDrone.Mono.*
|
||||
|
||||
echo "Adding NzbDrone.Windows to UpdatePackage"
|
||||
cp $outputFolder/NzbDrone.Windows.* $updateFolder
|
||||
|
||||
ProgressEnd 'Cleaning Windows Package'
|
||||
}
|
||||
|
||||
PackageArtifacts()
|
||||
{
|
||||
echo "Creating Artifact Directories"
|
||||
|
||||
rm -rf $artifactsFolder
|
||||
mkdir $artifactsFolder
|
||||
|
||||
mkdir $artifactsFolderWindows
|
||||
mkdir $artifactsFolderMacOS
|
||||
mkdir $artifactsFolderLinux
|
||||
mkdir $artifactsFolderWindows/Radarr
|
||||
mkdir $artifactsFolderMacOS/Radarr
|
||||
mkdir $artifactsFolderLinux/Radarr
|
||||
mkdir $artifactsFolderMacOSApp
|
||||
|
||||
cp -r $outputFolder/* $artifactsFolderWindows/Radarr
|
||||
cp -r $outputFolderMacOSApp/* $artifactsFolderMacOSApp
|
||||
cp -r $outputFolderMacOS/* $artifactsFolderMacOS/Radarr
|
||||
cp -r $outputFolderLinux/* $artifactsFolderLinux/Radarr
|
||||
}
|
||||
|
||||
# Use mono or .net depending on OS
|
||||
@@ -268,42 +292,51 @@ case "$(uname -s)" in
|
||||
;;
|
||||
esac
|
||||
|
||||
if [ $# -eq 0 ]
|
||||
then
|
||||
POSITIONAL=()
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
key="$1"
|
||||
|
||||
case $key in
|
||||
--only-backend)
|
||||
ONLY_BACKEND=YES
|
||||
shift # past argument
|
||||
;;
|
||||
--only-frontend)
|
||||
ONLY_FRONTEND=YES
|
||||
shift # past argument
|
||||
;;
|
||||
--only-packages)
|
||||
ONLY_PACKAGES=YES
|
||||
shift # past argument
|
||||
;;
|
||||
*) # unknown option
|
||||
POSITIONAL+=("$1") # save it in an array for later
|
||||
shift # past argument
|
||||
;;
|
||||
esac
|
||||
done
|
||||
set -- "${POSITIONAL[@]}" # restore positional parameters
|
||||
|
||||
# Only build backend if we haven't set only-frontend or only-packages
|
||||
if [ -z "$ONLY_FRONTEND" ] && [ -z "$ONLY_PACKAGES" ];
|
||||
then
|
||||
Build
|
||||
RunGulp
|
||||
PackageMono
|
||||
PackageOsx
|
||||
PackageOsxApp
|
||||
PackageTests
|
||||
fi
|
||||
|
||||
# Only build frontend if we haven't set only-backend or only-packages
|
||||
if [ -z "$ONLY_BACKEND" ] && [ -z "$ONLY_PACKAGES" ];
|
||||
then
|
||||
RunGulp
|
||||
fi
|
||||
|
||||
# Only package if we haven't set only-backend or only-frontend
|
||||
if [ -z "$ONLY_BACKEND" ] && [ -z "$ONLY_FRONTEND" ];
|
||||
then
|
||||
PackageMono
|
||||
PackageMacOS
|
||||
PackageMacOSApp
|
||||
CleanupWindowsPackage
|
||||
fi
|
||||
|
||||
if [ "$1" = "CleanXbuild" ]
|
||||
then rm -rf $outputFolder
|
||||
CleanWithXbuild
|
||||
fi
|
||||
|
||||
if [ "$1" = "NugetMono" ]
|
||||
then rm -rf $outputFolder
|
||||
RestoreNuget
|
||||
fi
|
||||
|
||||
if [ "$1" = "Build" ]
|
||||
then BuildWithXbuild
|
||||
CleanFolder $outputFolder false
|
||||
AddJsonNet
|
||||
rm $outputFolder/Mono.Posix.dll
|
||||
fi
|
||||
|
||||
if [ "$1" = "Gulp" ]
|
||||
then RunGulp
|
||||
fi
|
||||
|
||||
if [ "$1" = "Package" ]
|
||||
then PackageMono
|
||||
PackageOsx
|
||||
PackageOsxApp
|
||||
PackageTests
|
||||
CleanupWindowsPackage
|
||||
PackageArtifacts
|
||||
fi
|
||||
|
||||
@@ -1,14 +0,0 @@
|
||||
# Changelog
|
||||
|
||||
{{#versions}}
|
||||
## {{{label}}}
|
||||
|
||||
{{#sections}}
|
||||
### {{{label}}}
|
||||
{{#commits}}
|
||||
- {{{subject}}} [<a href="https://github.com/{{{author}}}">{{{author}}}</a>]
|
||||
{{/commits}}
|
||||
|
||||
{{/sections}}
|
||||
|
||||
{{/versions}}
|
||||
@@ -1,15 +0,0 @@
|
||||
**To receive further Pre-Release updates, please change the branch to develop. (Settings -> General (Show Advanced Settings) -> Updates -> Branch)**
|
||||
|
||||
{{#versions}}
|
||||
|
||||
{{#sections}}
|
||||
{{{label}}}
|
||||
{{#commits}}
|
||||
- {{{subject}}} [<a href="https://github.com/{{{author}}}">{{{author}}}</a>]
|
||||
{{/commits}}
|
||||
|
||||
{{/sections}}
|
||||
|
||||
{{/versions}}
|
||||
|
||||
**Note**: The OSX version does not automatically launch the browser. You have to go to http://localhost:7878 by yourself in a browser of your choice.
|
||||
@@ -1,44 +0,0 @@
|
||||
input1 = """Prometheus.Special.Edition.Fan Edit.2012..BRRip.x264.AAC-m2g
|
||||
Star Wars Episode IV - A New Hope (Despecialized) 1999.mkv
|
||||
Prometheus.(Special.Edition.Remastered).2012.[Bluray-1080p].mkv
|
||||
Prometheus Extended 2012
|
||||
Prometheus Extended Directors Cut Fan Edit 2012
|
||||
Prometheus Director's Cut 2012
|
||||
Prometheus Directors Cut 2012
|
||||
Prometheus.(Extended.Theatrical.Version.IMAX).BluRay.1080p.2012.asdf
|
||||
2001 A Space Odyssey Director's Cut (1968).mkv
|
||||
2001: A Space Odyssey (Extended Directors Cut FanEdit) Bluray 1080p 1968
|
||||
A Fake Movie 2035 Directors 2012.mkv
|
||||
Blade Runner Director's Cut 2049.mkv
|
||||
Prometheus 50th Anniversary Edition 2012.mkv
|
||||
Movie 2in1 2012.mkv
|
||||
Movie IMAX 2012.mkv"""
|
||||
|
||||
output1 = """Special.Edition.Fan Edit BRRip.x264.AAC-m2g
|
||||
Despecialized mkv
|
||||
Special.Edition.Remastered Bluray-1080p].mkv
|
||||
Extended mkv
|
||||
Extended Directors Cut Fan Edit mkv
|
||||
Director's Cut mkv
|
||||
Directors Cut mkv
|
||||
Extended.Theatrical.Version.IMAX asdf
|
||||
Director's Cut mkv
|
||||
Extended Directors Cut FanEdit mkv
|
||||
Directors mkv
|
||||
Director's Cut mkv
|
||||
50th Anniversary Edition mkv
|
||||
2in1 mkv
|
||||
IMAX mkv"""
|
||||
|
||||
inputs = input1.split("\n")
|
||||
outputs = output1.split("\n")
|
||||
real_o = []
|
||||
for output in outputs:
|
||||
real_o.append(output.split(" ")[0].replace(".", " ").strip())
|
||||
|
||||
count = 0
|
||||
|
||||
for inp in inputs:
|
||||
o = real_o[count]
|
||||
print "[TestCase(\"{0}\", \"{1}\")]".format(inp, o)
|
||||
count += 1
|
||||
48
debian/copyright
vendored
@@ -1,24 +1,24 @@
|
||||
Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
|
||||
Upstream-Name: nzbdrone
|
||||
Source: https://github.com/Sonarr/Sonarr
|
||||
|
||||
Files: *
|
||||
Copyright: 2010-2016 Sonarr <hello@sonarr.tv>
|
||||
|
||||
License: GPL-3.0+
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
.
|
||||
This package is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
.
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
.
|
||||
On Debian systems, the complete text of the GNU General
|
||||
Public License version 3 can be found in "/usr/share/common-licenses/GPL-3".
|
||||
Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
|
||||
Upstream-Name: nzbdrone
|
||||
Source: https://github.com/Sonarr/Sonarr
|
||||
|
||||
Files: *
|
||||
Copyright: 2010-2016 Sonarr <hello@sonarr.tv>
|
||||
|
||||
License: GPL-3.0+
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
.
|
||||
This package is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
.
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
.
|
||||
On Debian systems, the complete text of the GNU General
|
||||
Public License version 3 can be found in "/usr/share/common-licenses/GPL-3".
|
||||
|
||||
2
debian/install
vendored
@@ -1 +1 @@
|
||||
nzbdrone_bin/* opt/NzbDrone
|
||||
nzbdrone_bin/* opt/NzbDrone
|
||||
|
||||
0
debian/rules
vendored
Executable file → Normal file
@@ -9,7 +9,11 @@ APPNAME="Radarr"
|
||||
|
||||
#set up environment
|
||||
if [[ -x '/opt/local/bin/mono' ]]; then
|
||||
# Macports and mono-supplied installer path
|
||||
export PATH="/opt/local/bin:$PATH"
|
||||
elif [[ -x '/usr/local/bin/mono' ]]; then
|
||||
# Homebrew-supplied path to mono
|
||||
export PATH="/usr/local/bin:$PATH"
|
||||
fi
|
||||
|
||||
export DYLD_FALLBACK_LIBRARY_PATH="$DIR"
|
||||
7487
package-lock.json
generated
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "Radarr",
|
||||
"version": "2.0.0",
|
||||
"name": "radarr",
|
||||
"version": "1.0.0",
|
||||
"description": "Radarr",
|
||||
"main": "main.js",
|
||||
"scripts": {
|
||||
@@ -38,11 +38,13 @@
|
||||
"handlebars": "3.0.3",
|
||||
"jshint-loader": "0.8.3",
|
||||
"jshint-stylish": "2.0.1",
|
||||
"npm": "^6.0.1",
|
||||
"run-sequence": "1.1.1",
|
||||
"streamqueue": "1.1.0",
|
||||
"tar.gz": "0.1.1",
|
||||
"url-search-params": "^0.6.1",
|
||||
"webpack": "1.12.0",
|
||||
"webpack-stream": "2.1.0"
|
||||
"webpack-stream": "2.1.0",
|
||||
"natives": "^1.1.3"
|
||||
}
|
||||
}
|
||||
|
||||
77
package.sh
@@ -1,77 +0,0 @@
|
||||
if [ $# -eq 0 ]; then
|
||||
if [ "$TRAVIS_PULL_REQUEST" != false ]; then
|
||||
echo "Need to supply version argument" && exit;
|
||||
fi
|
||||
fi
|
||||
|
||||
# Use mono or .net depending on OS
|
||||
case "$(uname -s)" in
|
||||
CYGWIN*|MINGW32*|MINGW64*|MSYS*)
|
||||
# on windows, use dotnet
|
||||
runtime="dotnet"
|
||||
;;
|
||||
*)
|
||||
# otherwise use mono
|
||||
runtime="mono"
|
||||
;;
|
||||
esac
|
||||
|
||||
if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then
|
||||
VERSION="$(date +%H:%M:%S)"
|
||||
YEAR="$(date +%Y)"
|
||||
MONTH="$(date +%m)"
|
||||
DAY="$(date +%d)"
|
||||
else
|
||||
VERSION=$1
|
||||
BRANCH=$2
|
||||
BRANCH=${BRANCH#refs\/heads\/}
|
||||
BRANCH=${BRANCH//\//-}
|
||||
fi
|
||||
outputFolder='./_output'
|
||||
outputFolderMono='./_output_mono'
|
||||
outputFolderOsx='./_output_osx'
|
||||
outputFolderOsxApp='./_output_osx_app'
|
||||
|
||||
tr -d "\r" < $outputFolderOsxApp/Radarr.app/Contents/MacOS/Radarr > $outputFolderOsxApp/Radarr.app/Contents/MacOS/Radarr2
|
||||
rm $outputFolderOsxApp/Radarr.app/Contents/MacOS/Radarr
|
||||
chmod +x $outputFolderOsxApp/Radarr.app/Contents/MacOS/Radarr2
|
||||
mv $outputFolderOsxApp/Radarr.app/Contents/MacOS/Radarr2 $outputFolderOsxApp/Radarr.app/Contents/MacOS/Radarr >& error.log
|
||||
|
||||
if [ $runtime = "dotnet" ] ; then
|
||||
./7za.exe a Radarr_Windows_$VERSION.zip ./Radarr_Windows_$VERSION/*
|
||||
./7za.exe a -ttar -so Radarr_Mono_$VERSION.tar ./Radarr_Mono_$VERSION/* | ./7za.exe a -si Radarr_Mono_$VERSION.tar.gz
|
||||
./7za.exe a -ttar -so Radarr_OSX_$VERSION.tar ./_output_osx/* | ./7za.exe a -si Radarr_OSX_$VERSION.tar.gz
|
||||
./7za.exe a -ttar -so Radarr_OSX_App_$VERSION.tar ./_output_osx_app/* | ./7za.exe a -si Radarr_OSX_App_$VERSION.tar.gz
|
||||
else
|
||||
cp -r $outputFolder/ Radarr
|
||||
zip -r Radarr.$BRANCH.$VERSION.windows.zip Radarr
|
||||
rm -rf Radarr
|
||||
cp -r $outputFolderMono/ Radarr
|
||||
tar -zcvf Radarr.$BRANCH.$VERSION.linux.tar.gz Radarr
|
||||
rm -rf Radarr
|
||||
cp -r $outputFolderOsx/ Radarr
|
||||
tar -zcvf Radarr.$BRANCH.$VERSION.osx.tar.gz Radarr
|
||||
rm -rf Radarr
|
||||
#TODO update for tar.gz
|
||||
|
||||
cd _output_osx_app/
|
||||
zip -r ../Radarr.$BRANCH.$VERSION.osx-app.zip *
|
||||
fi
|
||||
# ftp -n ftp.leonardogalli.ch << END_SCRIPT
|
||||
# passive
|
||||
# quote USER $FTP_USER
|
||||
# quote PASS $FTP_PASS
|
||||
# mkdir builds
|
||||
# cd builds
|
||||
# mkdir $YEAR
|
||||
# cd $YEAR
|
||||
# mkdir $MONTH
|
||||
# cd $MONTH
|
||||
# mkdir $DAY
|
||||
# cd $DAY
|
||||
# binary
|
||||
# put Radarr_Windows_$VERSION.zip
|
||||
# put Radarr_Mono_$VERSION.zip
|
||||
# put Radarr_OSX_$VERSION.zip
|
||||
# quit
|
||||
# END_SCRIPT
|
||||
@@ -1,60 +0,0 @@
|
||||
; Script generated by the Inno Setup Script Wizard.
|
||||
; SEE THE DOCUMENTATION FOR DETAILS ON CREATING INNO SETUP SCRIPT FILES!
|
||||
|
||||
#define AppName "Radarr"
|
||||
#define AppPublisher "Team Radarr"
|
||||
#define AppURL "https://radarr.video/"
|
||||
#define ForumsURL "https://github.com/Radarr/Radarr/issues"
|
||||
#define AppExeName "Radarr.exe"
|
||||
#define BuildNumber "2.0"
|
||||
#define BuildVersion GetEnv('APPVEYOR_BUILD_VERSION')
|
||||
#define BranchName GetEnv('APPVEYOR_REPO_BRANCH')
|
||||
|
||||
[Setup]
|
||||
; NOTE: The value of AppId uniquely identifies this application.
|
||||
; Do not use the same AppId value in installers for other applications.
|
||||
; (To generate a new GUID, click Tools | Generate GUID inside the IDE.)
|
||||
AppId={{56C1065D-3523-4025-B76D-6F73F67F7F82}
|
||||
AppName={#AppName}
|
||||
AppVersion=0.2
|
||||
AppPublisher={#AppPublisher}
|
||||
AppPublisherURL={#AppURL}
|
||||
AppSupportURL={#ForumsURL}
|
||||
AppUpdatesURL={#AppURL}
|
||||
DefaultDirName={commonappdata}\Radarr\bin
|
||||
DisableDirPage=yes
|
||||
DefaultGroupName={#AppName}
|
||||
DisableProgramGroupPage=yes
|
||||
OutputBaseFilename=Radarr.{#BranchName}.{#BuildVersion}.installer
|
||||
SolidCompression=yes
|
||||
AppCopyright=Creative Commons 3.0 License
|
||||
AllowUNCPath=False
|
||||
UninstallDisplayIcon={app}\Radarr.exe
|
||||
DisableReadyPage=True
|
||||
CompressionThreads=2
|
||||
Compression=lzma2/normal
|
||||
AppContact={#ForumsURL}
|
||||
VersionInfoVersion={#BuildNumber}
|
||||
|
||||
[Languages]
|
||||
Name: "english"; MessagesFile: "compiler:Default.isl"
|
||||
|
||||
[Tasks]
|
||||
;Name: "desktopicon"; Description: "{cm:CreateDesktopIcon}"; GroupDescription: "{cm:AdditionalIcons}"; Flags: unchecked
|
||||
Name: "windowsService"; Description: "Install as a Windows Service"
|
||||
|
||||
[Files]
|
||||
Source: "..\_output\Radarr.exe"; DestDir: "{app}"; Flags: ignoreversion
|
||||
Source: "..\_output\*"; DestDir: "{app}"; Flags: ignoreversion recursesubdirs createallsubdirs
|
||||
; NOTE: Don't use "Flags: ignoreversion" on any shared system files
|
||||
|
||||
[Icons]
|
||||
Name: "{group}\{#AppName}"; Filename: "{app}\{#AppExeName}"; Parameters: "/icon"
|
||||
Name: "{commondesktop}\{#AppName}"; Filename: "{app}\{#AppExeName}"; Parameters: "/icon"
|
||||
|
||||
[Run]
|
||||
Filename: "{app}\radarr.console.exe"; Parameters: "/u"; Flags: waituntilterminated;
|
||||
Filename: "{app}\radarr.console.exe"; Parameters: "/i"; Flags: waituntilterminated; Tasks: windowsService
|
||||
|
||||
[UninstallRun]
|
||||
Filename: "{app}\radarr.console.exe"; Parameters: "/u"; Flags: waituntilterminated skipifdoesntexist
|
||||
75
setup/radarr.iss
Normal file
@@ -0,0 +1,75 @@
|
||||
; Script generated by the Inno Setup Script Wizard.
|
||||
; SEE THE DOCUMENTATION FOR DETAILS ON CREATING INNO SETUP SCRIPT FILES!
|
||||
|
||||
#define AppName "Radarr"
|
||||
#define AppPublisher "Team Radarr"
|
||||
#define AppURL "https://radarr.video/"
|
||||
#define ForumsURL "https://forums.radarr.video/"
|
||||
#define AppExeName "Radarr.exe"
|
||||
#define BaseVersion "0.2.0"
|
||||
#define BuildNumber GetEnv('MINORVERSION')
|
||||
#define BuildVersion GetEnv('RADARRVERSION')
|
||||
#define BranchName GetEnv('BUILD_SOURCEBRANCHNAME')
|
||||
|
||||
[Setup]
|
||||
; NOTE: The value of AppId uniquely identifies this application.
|
||||
; Do not use the same AppId value in installers for other applications.
|
||||
; (To generate a new GUID, click Tools | Generate GUID inside the IDE.)
|
||||
AppId={{56C1065D-3523-4025-B76D-6F73F67F7F82}
|
||||
AppName={#AppName}
|
||||
AppVersion={#BaseVersion}
|
||||
AppPublisher={#AppPublisher}
|
||||
AppPublisherURL={#AppURL}
|
||||
AppSupportURL={#ForumsURL}
|
||||
AppUpdatesURL={#AppURL}
|
||||
DefaultDirName={commonappdata}\Radarr\bin
|
||||
DisableDirPage=yes
|
||||
DefaultGroupName={#AppName}
|
||||
DisableProgramGroupPage=yes
|
||||
OutputBaseFilename=Radarr.{#BranchName}.{#BuildVersion}.windows
|
||||
SolidCompression=yes
|
||||
AppCopyright=Creative Commons 3.0 License
|
||||
AllowUNCPath=False
|
||||
UninstallDisplayIcon={app}\Radarr.exe
|
||||
DisableReadyPage=True
|
||||
CompressionThreads=2
|
||||
Compression=lzma2/normal
|
||||
AppContact={#ForumsURL}
|
||||
VersionInfoVersion={#BaseVersion}.{#BuildNumber}
|
||||
|
||||
[Languages]
|
||||
Name: "english"; MessagesFile: "compiler:Default.isl"
|
||||
|
||||
[Tasks]
|
||||
Name: "desktopicon"; Description: "{cm:CreateDesktopIcon}"
|
||||
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
|
||||
Name: "none"; Description: "Do not start automatically"; GroupDescription: "Start automatically"; Flags: exclusive unchecked
|
||||
|
||||
[Files]
|
||||
Source: "..\_output\Radarr.exe"; DestDir: "{app}"; Flags: ignoreversion
|
||||
Source: "..\_output\*"; DestDir: "{app}"; Flags: ignoreversion recursesubdirs createallsubdirs
|
||||
; NOTE: Don't use "Flags: ignoreversion" on any shared system files
|
||||
|
||||
[Icons]
|
||||
Name: "{group}\{#AppName}"; Filename: "{app}\{#AppExeName}"; Parameters: "/icon"
|
||||
Name: "{commondesktop}\{#AppName}"; Filename: "{app}\{#AppExeName}"; Parameters: "/icon"
|
||||
Name: "{userstartup}\{#AppName}"; Filename: "{app}\Radarr.exe"; WorkingDir: "{app}"; Tasks: startupShortcut
|
||||
|
||||
[Run]
|
||||
Filename: "{app}\Radarr.Console.exe"; StatusMsg: "Removing previous Windows Service"; Parameters: "/u"; Flags: runhidden waituntilterminated;
|
||||
Filename: "{app}\Radarr.Console.exe"; Description: "Enable Access from Other Devices"; StatusMsg: "Enabling Remote access"; Parameters: "/registerurl"; Flags: postinstall runascurrentuser runhidden waituntilterminated; Tasks: startupShortcut none;
|
||||
Filename: "{app}\Radarr.Console.exe"; StatusMsg: "Installing Windows Service"; Parameters: "/i"; Flags: runhidden waituntilterminated; Tasks: windowsService
|
||||
Filename: "{app}\Radarr.exe"; Description: "Open Radarr Web UI"; Flags: postinstall skipifsilent nowait; Tasks: windowsService;
|
||||
Filename: "{app}\Radarr.exe"; Description: "Start Radarr"; Flags: postinstall skipifsilent nowait; Tasks: startupShortcut none;
|
||||
|
||||
[UninstallRun]
|
||||
Filename: "{app}\radarr.console.exe"; Parameters: "/u"; Flags: waituntilterminated skipifdoesntexist
|
||||
|
||||
[Code]
|
||||
function PrepareToInstall(var NeedsRestart: Boolean): String;
|
||||
var
|
||||
ResultCode: Integer;
|
||||
begin
|
||||
Exec(ExpandConstant('{commonappdata}\Radarr\bin\Radarr.Console.exe'), '/u', '', 0, ewWaitUntilTerminated, ResultCode)
|
||||
end;
|
||||
BIN
sonarr.icns
3333
src/.idea/.idea.NzbDrone/.idea/contentModel.xml
generated
4
src/.idea/.idea.NzbDrone/.idea/encodings.xml
generated
Normal file
@@ -0,0 +1,4 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding" addBOMForNewFiles="with NO BOM" />
|
||||
</project>
|
||||
1
src/.idea/.idea.NzbDrone/.idea/indexLayout.xml
generated
@@ -1,6 +1,7 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ContentModelUserStore">
|
||||
<attachedFolders />
|
||||
<explicitIncludes />
|
||||
<explicitExcludes />
|
||||
</component>
|
||||
|
||||
6
src/.idea/.idea.NzbDrone/.idea/misc.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="com.jetbrains.rider.android.RiderAndroidMiscFileCreationComponent">
|
||||
<option name="ENSURE_MISC_FILE_EXISTS" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
8
src/.idea/.idea.NzbDrone/.idea/modules.xml
generated
@@ -1,8 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/.idea/.idea.NzbDrone/riderModule.iml" filepath="$PROJECT_DIR$/.idea/.idea.NzbDrone/riderModule.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
9
src/.idea/.idea.NzbDrone/riderModule.iml
generated
@@ -1,9 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="RIDER_MODULE" version="4">
|
||||
<component name="NewModuleRootManager">
|
||||
<content url="file://$MODULE_DIR$/../../../Logo/1024.png" />
|
||||
<content url="file://$MODULE_DIR$/../../../Logo/64.png" />
|
||||
<content url="file://$MODULE_DIR$/../.." />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
@@ -2,4 +2,4 @@
|
||||
|
||||
using System.Reflection;
|
||||
|
||||
[assembly: AssemblyVersion("0.1.0.*")]
|
||||
[assembly: AssemblyVersion("10.0.0.*")]
|
||||
|
||||
@@ -1,648 +0,0 @@
|
||||
using System;
|
||||
using System.Collections.Concurrent;
|
||||
using System.Configuration;
|
||||
using System.Diagnostics;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Security;
|
||||
using System.Text;
|
||||
using System.Text.RegularExpressions;
|
||||
using System.Threading;
|
||||
|
||||
namespace LogentriesCore
|
||||
{
|
||||
public class AsyncLogger
|
||||
{
|
||||
#region Constants
|
||||
|
||||
// Current version number.
|
||||
protected const String Version = "2.6.0";
|
||||
|
||||
// Size of the internal event queue.
|
||||
protected const int QueueSize = 32768;
|
||||
|
||||
// Minimal delay between attempts to reconnect in milliseconds.
|
||||
protected const int MinDelay = 100;
|
||||
|
||||
// Maximal delay between attempts to reconnect in milliseconds.
|
||||
protected const int MaxDelay = 10000;
|
||||
|
||||
// Appender signature - used for debugging messages.
|
||||
protected const String LeSignature = "LE: ";
|
||||
|
||||
// Legacy Logentries configuration names.
|
||||
protected const String LegacyConfigTokenName = "LOGENTRIES_TOKEN";
|
||||
protected const String LegacyConfigAccountKeyName = "LOGENTRIES_ACCOUNT_KEY";
|
||||
protected const String LegacyConfigLocationName = "LOGENTRIES_LOCATION";
|
||||
|
||||
// New Logentries configuration names.
|
||||
protected const String ConfigTokenName = "Logentries.Token";
|
||||
protected const String ConfigAccountKeyName = "Logentries.AccountKey";
|
||||
protected const String ConfigLocationName = "Logentries.Location";
|
||||
|
||||
// Error message displayed when invalid token is detected.
|
||||
protected const String InvalidTokenMessage = "\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.
|
||||
protected const String InvalidHttpPutCredentialsMessage = "\n\nIt appears your LOGENTRIES_ACCOUNT_KEY or LOGENTRIES_LOCATION values are invalid or missing.\n\n";
|
||||
|
||||
// Error message deisplayed when queue overflow occurs.
|
||||
protected const String QueueOverflowMessage = "\n\nLogentries buffer queue overflow. Message dropped.\n\n";
|
||||
|
||||
// Newline char to trim from message for formatting.
|
||||
protected static char[] TrimChars = { '\r', '\n' };
|
||||
|
||||
/** Non-Unix and Unix Newline */
|
||||
protected static string[] posix_newline = { "\r\n", "\n" };
|
||||
|
||||
/** Unicode line separator character */
|
||||
protected static string line_separator = "\u2028";
|
||||
|
||||
// Restricted symbols that should not appear in host name.
|
||||
// See http://support.microsoft.com/kb/228275/en-us for details.
|
||||
private static Regex ForbiddenHostNameChars = new Regex(@"[/\\\[\]\""\:\;\|\<\>\+\=\,\?\* _]{1,}", RegexOptions.Compiled);
|
||||
|
||||
/** Regex used to validate GUID in .NET3.5 */
|
||||
private static Regex isGuid = new Regex(@"^(\{){0,1}[0-9a-fA-F]{8}\-[0-9a-fA-F]{4}\-[0-9a-fA-F]{4}\-[0-9a-fA-F]{4}\-[0-9a-fA-F]{12}(\}){0,1}$", RegexOptions.Compiled);
|
||||
|
||||
#endregion
|
||||
|
||||
#region Singletons
|
||||
|
||||
// UTF-8 output character set.
|
||||
protected static readonly UTF8Encoding UTF8 = new UTF8Encoding();
|
||||
|
||||
// ASCII character set used by HTTP.
|
||||
protected static readonly ASCIIEncoding ASCII = new ASCIIEncoding();
|
||||
|
||||
//static list of all the queues the le appender might be managing.
|
||||
private static ConcurrentBag<BlockingCollection<string>> _allQueues = new ConcurrentBag<BlockingCollection<string>>();
|
||||
|
||||
/// <summary>
|
||||
/// Determines if the queue is empty after waiting the specified waitTime.
|
||||
/// Returns true or false if the underlying queues are empty.
|
||||
/// </summary>
|
||||
/// <param name="waitTime">The length of time the method should block before giving up waiting for it to empty.</param>
|
||||
/// <returns>True if the queue is empty, false if there are still items waiting to be written.</returns>
|
||||
public static bool AreAllQueuesEmpty(TimeSpan waitTime)
|
||||
{
|
||||
var start = DateTime.UtcNow;
|
||||
var then = DateTime.UtcNow;
|
||||
|
||||
while (start.Add(waitTime) > then)
|
||||
{
|
||||
if (_allQueues.All(x => x.Count == 0))
|
||||
return true;
|
||||
|
||||
Thread.Sleep(100);
|
||||
then = DateTime.UtcNow;
|
||||
}
|
||||
|
||||
return _allQueues.All(x => x.Count == 0);
|
||||
}
|
||||
#endregion
|
||||
|
||||
public AsyncLogger()
|
||||
{
|
||||
Queue = new BlockingCollection<string>(QueueSize);
|
||||
_allQueues.Add(Queue);
|
||||
|
||||
WorkerThread = new Thread(Run);
|
||||
WorkerThread.Name = "Logentries Log4net Appender";
|
||||
WorkerThread.IsBackground = true;
|
||||
}
|
||||
|
||||
#region Configuration properties
|
||||
|
||||
private String m_Token = "";
|
||||
private String m_AccountKey = "";
|
||||
private String m_Location = "";
|
||||
private bool m_ImmediateFlush = false;
|
||||
private bool m_Debug = false;
|
||||
private bool m_UseHttpPut = false;
|
||||
private bool m_UseSsl = false;
|
||||
|
||||
// Properties for defining location of DataHub instance if one is used.
|
||||
private bool m_UseDataHub = false; // By default Logentries service is used instead of DataHub instance.
|
||||
private String m_DataHubAddr = "";
|
||||
private int m_DataHubPort = 0;
|
||||
|
||||
// Properties to define host name of user's machine and define user-specified log ID.
|
||||
private bool m_UseHostName = false; // Defines whether to prefix log message with HostName or not.
|
||||
private String m_HostName = ""; // User-defined or auto-defined host name (if not set in config. file)
|
||||
private String m_LogID = ""; // User-defined log ID to be prefixed to the log message.
|
||||
|
||||
// Sets DataHub usage flag.
|
||||
public void setIsUsingDataHub(bool useDataHub)
|
||||
{
|
||||
m_UseDataHub = useDataHub;
|
||||
}
|
||||
|
||||
public bool getIsUsingDataHab()
|
||||
{
|
||||
return m_UseDataHub;
|
||||
}
|
||||
|
||||
// Sets DataHub instance address.
|
||||
public void setDataHubAddr(String dataHubAddr)
|
||||
{
|
||||
m_DataHubAddr = dataHubAddr;
|
||||
}
|
||||
|
||||
public String getDataHubAddr()
|
||||
{
|
||||
return m_DataHubAddr;
|
||||
}
|
||||
|
||||
// Sets the port on which DataHub instance is waiting for log messages.
|
||||
public void setDataHubPort(int port)
|
||||
{
|
||||
m_DataHubPort = port;
|
||||
}
|
||||
|
||||
public int getDataHubPort()
|
||||
{
|
||||
return m_DataHubPort;
|
||||
}
|
||||
|
||||
public void setToken(String token)
|
||||
{
|
||||
m_Token = token;
|
||||
}
|
||||
|
||||
public String getToken()
|
||||
{
|
||||
return m_Token;
|
||||
}
|
||||
|
||||
public void setAccountKey(String accountKey)
|
||||
{
|
||||
m_AccountKey = accountKey;
|
||||
}
|
||||
|
||||
public string getAccountKey()
|
||||
{
|
||||
return m_AccountKey;
|
||||
}
|
||||
|
||||
public void setLocation(String location)
|
||||
{
|
||||
m_Location = location;
|
||||
}
|
||||
|
||||
public String getLocation()
|
||||
{
|
||||
return m_Location;
|
||||
}
|
||||
|
||||
public void setImmediateFlush(bool immediateFlush)
|
||||
{
|
||||
m_ImmediateFlush = immediateFlush;
|
||||
}
|
||||
|
||||
public bool getImmediateFlush()
|
||||
{
|
||||
return m_ImmediateFlush;
|
||||
}
|
||||
|
||||
public void setDebug(bool debug)
|
||||
{
|
||||
m_Debug = debug;
|
||||
}
|
||||
|
||||
public bool getDebug()
|
||||
{
|
||||
return m_Debug;
|
||||
}
|
||||
|
||||
public void setUseHttpPut(bool useHttpPut)
|
||||
{
|
||||
m_UseHttpPut = useHttpPut;
|
||||
}
|
||||
|
||||
public bool getUseHttpPut()
|
||||
{
|
||||
return m_UseHttpPut;
|
||||
}
|
||||
|
||||
public void setUseSsl(bool useSsl)
|
||||
{
|
||||
m_UseSsl = useSsl;
|
||||
}
|
||||
|
||||
public bool getUseSsl()
|
||||
{
|
||||
return m_UseSsl;
|
||||
}
|
||||
|
||||
public void setUseHostName(bool useHostName)
|
||||
{
|
||||
m_UseHostName = useHostName;
|
||||
}
|
||||
|
||||
public bool getUseHostName()
|
||||
{
|
||||
return m_UseHostName;
|
||||
}
|
||||
|
||||
public void setHostName(String hostName)
|
||||
{
|
||||
m_HostName = hostName;
|
||||
}
|
||||
|
||||
public String getHostName()
|
||||
{
|
||||
return m_HostName;
|
||||
}
|
||||
|
||||
public void setLogID(String logID)
|
||||
{
|
||||
m_LogID = logID;
|
||||
}
|
||||
|
||||
public String getLogID()
|
||||
{
|
||||
return m_LogID;
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
protected readonly BlockingCollection<string> Queue;
|
||||
protected readonly Thread WorkerThread;
|
||||
protected readonly Random Random = new Random();
|
||||
|
||||
private LeClient LeClient = null;
|
||||
protected bool IsRunning = false;
|
||||
|
||||
#region Protected methods
|
||||
|
||||
protected virtual void Run()
|
||||
{
|
||||
try
|
||||
{
|
||||
// Open connection.
|
||||
ReopenConnection();
|
||||
|
||||
string logMessagePrefix = String.Empty;
|
||||
|
||||
if (m_UseHostName)
|
||||
{
|
||||
// If LogHostName is set to "true", but HostName is not defined -
|
||||
// try to get host name from Environment.
|
||||
if (m_HostName == String.Empty)
|
||||
{
|
||||
try
|
||||
{
|
||||
WriteDebugMessages("HostName parameter is not defined - trying to get it from System.Environment.MachineName");
|
||||
m_HostName = "HostName=" + System.Environment.MachineName + " ";
|
||||
}
|
||||
catch (InvalidOperationException)
|
||||
{
|
||||
// Cannot get host name automatically, so assume that HostName is not used
|
||||
// and log message is sent without it.
|
||||
m_UseHostName = false;
|
||||
WriteDebugMessages("Failed to get HostName parameter using System.Environment.MachineName. Log messages will not be prefixed by HostName");
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (!CheckIfHostNameValid(m_HostName))
|
||||
{
|
||||
// If user-defined host name is incorrect - we cannot use it
|
||||
// and log message is sent without it.
|
||||
m_UseHostName = false;
|
||||
WriteDebugMessages("HostName parameter contains prohibited characters. Log messages will not be prefixed by HostName");
|
||||
}
|
||||
else
|
||||
{
|
||||
m_HostName = "HostName=" + m_HostName + " ";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (m_LogID != String.Empty)
|
||||
{
|
||||
logMessagePrefix = m_LogID + " ";
|
||||
}
|
||||
|
||||
if (m_UseHostName)
|
||||
{
|
||||
logMessagePrefix += m_HostName;
|
||||
}
|
||||
|
||||
// Flag that is set if logMessagePrefix is empty.
|
||||
bool isPrefixEmpty = (logMessagePrefix == String.Empty);
|
||||
|
||||
// Send data in queue.
|
||||
while (true)
|
||||
{
|
||||
// Take data from queue.
|
||||
var line = Queue.Take();
|
||||
|
||||
// Replace newline chars with line separator to format multi-line events nicely.
|
||||
foreach (String newline in posix_newline)
|
||||
{
|
||||
line = line.Replace(newline, line_separator);
|
||||
}
|
||||
|
||||
// If m_UseDataHub == true (logs are sent to DataHub instance) then m_Token is not
|
||||
// appended to the message.
|
||||
string finalLine = ((!m_UseHttpPut && !m_UseDataHub) ? this.m_Token + line : line) + '\n';
|
||||
|
||||
// Add prefixes: LogID and HostName if they are defined.
|
||||
if (!isPrefixEmpty)
|
||||
{
|
||||
finalLine = logMessagePrefix + finalLine;
|
||||
}
|
||||
|
||||
byte[] data = UTF8.GetBytes(finalLine);
|
||||
|
||||
// Send data, reconnect if needed.
|
||||
while (true)
|
||||
{
|
||||
try
|
||||
{
|
||||
this.LeClient.Write(data, 0, data.Length);
|
||||
|
||||
if (m_ImmediateFlush)
|
||||
this.LeClient.Flush();
|
||||
}
|
||||
catch (IOException)
|
||||
{
|
||||
// Reopen the lost connection.
|
||||
ReopenConnection();
|
||||
continue;
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (ThreadInterruptedException ex)
|
||||
{
|
||||
WriteDebugMessages("Logentries asynchronous socket client was interrupted.", ex);
|
||||
}
|
||||
}
|
||||
|
||||
protected virtual void OpenConnection()
|
||||
{
|
||||
try
|
||||
{
|
||||
if (LeClient == null)
|
||||
{
|
||||
// Create LeClient instance providing all needed parameters. If DataHub-related properties
|
||||
// have not been overridden by log4net or NLog configurators, then DataHub is not used,
|
||||
// because m_UseDataHub == false by default.
|
||||
LeClient = new LeClient(m_UseHttpPut, m_UseSsl, m_UseDataHub, m_DataHubAddr, m_DataHubPort);
|
||||
}
|
||||
|
||||
LeClient.Connect();
|
||||
|
||||
if (m_UseHttpPut)
|
||||
{
|
||||
var header = String.Format("PUT /{0}/hosts/{1}/?realtime=1 HTTP/1.1\r\n\r\n", m_AccountKey, m_Location);
|
||||
LeClient.Write(ASCII.GetBytes(header), 0, header.Length);
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
throw new IOException("An error occurred while opening the connection.", ex);
|
||||
}
|
||||
}
|
||||
|
||||
protected virtual void ReopenConnection()
|
||||
{
|
||||
CloseConnection();
|
||||
|
||||
var rootDelay = MinDelay;
|
||||
while (true)
|
||||
{
|
||||
try
|
||||
{
|
||||
OpenConnection();
|
||||
|
||||
return;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
if (m_Debug)
|
||||
{
|
||||
WriteDebugMessages("Unable to connect to Logentries API.", ex);
|
||||
}
|
||||
}
|
||||
|
||||
rootDelay *= 2;
|
||||
if (rootDelay > MaxDelay)
|
||||
rootDelay = MaxDelay;
|
||||
|
||||
var waitFor = rootDelay + Random.Next(rootDelay);
|
||||
|
||||
try
|
||||
{
|
||||
Thread.Sleep(waitFor);
|
||||
}
|
||||
catch
|
||||
{
|
||||
throw new ThreadInterruptedException();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
protected virtual void CloseConnection()
|
||||
{
|
||||
if (LeClient != null)
|
||||
LeClient.Close();
|
||||
}
|
||||
|
||||
public static bool IsNullOrWhiteSpace(String value)
|
||||
{
|
||||
if (value == null) return true;
|
||||
|
||||
for (int i = 0; i < value.Length; i++)
|
||||
{
|
||||
if (!Char.IsWhiteSpace(value[i])) return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
private string retrieveSetting(String name)
|
||||
{
|
||||
string value;
|
||||
|
||||
|
||||
value = ConfigurationManager.AppSettings[name];
|
||||
|
||||
if (IsNullOrWhiteSpace(value))
|
||||
{
|
||||
try
|
||||
{
|
||||
value = Environment.GetEnvironmentVariable(name);
|
||||
}
|
||||
catch (SecurityException)
|
||||
{
|
||||
}
|
||||
}
|
||||
|
||||
return value;
|
||||
}
|
||||
|
||||
/*
|
||||
* Use CloudConfigurationManager with .NET4.0 and fallback to System.Configuration for previous frameworks.
|
||||
*
|
||||
* NOTE: This is not entirely clear with regards to the above comment, but this block of code uses a compiler directive NET4_0
|
||||
* which is not set by default anywhere, so most uses of this code will default back to the "pre-.Net4.0" code branch, even
|
||||
* if you are using .Net4.0 or .Net4.5.
|
||||
*
|
||||
* The second issue is that there are two appsetting keys for each setting - the "legacy" key, such as "LOGENTRIES_TOKEN"
|
||||
* and the "non-legacy" key, such as "Logentries.Token". Again, I'm not sure of the reasons behind this, so the code below checks
|
||||
* both the legacy and non-legacy keys, defaulting to the legacy keys if they are found.
|
||||
*
|
||||
* It probably should be investigated whether the fallback to ConfigurationManager is needed at all, as CloudConfigurationManager
|
||||
* will retrieve settings from appSettings in a non-Azure environment.
|
||||
*/
|
||||
protected virtual bool LoadCredentials()
|
||||
{
|
||||
if (!m_UseHttpPut)
|
||||
{
|
||||
if (GetIsValidGuid(m_Token))
|
||||
return true;
|
||||
|
||||
var configToken = retrieveSetting(LegacyConfigTokenName) ?? retrieveSetting(ConfigTokenName);
|
||||
|
||||
if (!String.IsNullOrEmpty(configToken) && GetIsValidGuid(configToken))
|
||||
{
|
||||
m_Token = configToken;
|
||||
return true;
|
||||
}
|
||||
|
||||
WriteDebugMessages(InvalidTokenMessage);
|
||||
return false;
|
||||
}
|
||||
|
||||
if (m_AccountKey != "" && GetIsValidGuid(m_AccountKey) && m_Location != "")
|
||||
return true;
|
||||
|
||||
var configAccountKey = ConfigurationManager.AppSettings[LegacyConfigAccountKeyName] ?? ConfigurationManager.AppSettings[ConfigAccountKeyName];
|
||||
if (!String.IsNullOrEmpty(configAccountKey) && GetIsValidGuid(configAccountKey))
|
||||
{
|
||||
m_AccountKey = configAccountKey;
|
||||
|
||||
var configLocation = ConfigurationManager.AppSettings[LegacyConfigLocationName] ?? ConfigurationManager.AppSettings[ConfigLocationName];
|
||||
if (!String.IsNullOrEmpty(configLocation))
|
||||
{
|
||||
m_Location = configLocation;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
WriteDebugMessages(InvalidHttpPutCredentialsMessage);
|
||||
return false;
|
||||
}
|
||||
|
||||
private bool CheckIfHostNameValid(String hostName)
|
||||
{
|
||||
return !ForbiddenHostNameChars.IsMatch(hostName); // Returns false if reg.ex. matches any of forbidden chars.
|
||||
}
|
||||
|
||||
static bool IsGuid(string candidate, out Guid output)
|
||||
{
|
||||
bool isValid = false;
|
||||
output = Guid.Empty;
|
||||
|
||||
if (isGuid.IsMatch(candidate))
|
||||
{
|
||||
output = new Guid(candidate);
|
||||
isValid = true;
|
||||
}
|
||||
return isValid;
|
||||
}
|
||||
|
||||
protected virtual bool GetIsValidGuid(string guidString)
|
||||
{
|
||||
if (String.IsNullOrEmpty(guidString))
|
||||
return false;
|
||||
|
||||
System.Guid newGuid = System.Guid.NewGuid();
|
||||
return IsGuid(guidString, out newGuid);
|
||||
}
|
||||
|
||||
protected virtual void WriteDebugMessages(string message, Exception ex)
|
||||
{
|
||||
if (!m_Debug)
|
||||
return;
|
||||
|
||||
message = LeSignature + message;
|
||||
string[] messages = { message, ex.ToString() };
|
||||
foreach (var msg in messages)
|
||||
{
|
||||
// Use below line instead when compiling with log4net1.2.10.
|
||||
//LogLog.Debug(msg);
|
||||
|
||||
//LogLog.Debug(typeof(LogentriesAppender), msg);
|
||||
|
||||
Debug.WriteLine(message);
|
||||
}
|
||||
}
|
||||
|
||||
protected virtual void WriteDebugMessages(string message)
|
||||
{
|
||||
if (!m_Debug)
|
||||
return;
|
||||
|
||||
message = LeSignature + message;
|
||||
|
||||
// Use below line instead when compiling with log4net1.2.10.
|
||||
//LogLog.Debug(message);
|
||||
|
||||
//LogLog.Debug(typeof(LogentriesAppender), message);
|
||||
Debug.WriteLine(message);
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region publicMethods
|
||||
|
||||
public virtual void AddLine(string line)
|
||||
{
|
||||
if (!IsRunning)
|
||||
{
|
||||
// We need to load user credentials only
|
||||
// if the configuration does not state that DataHub is used;
|
||||
// credentials needed only if logs are sent to LE service directly.
|
||||
bool credentialsLoaded = false;
|
||||
if(!m_UseDataHub)
|
||||
{
|
||||
credentialsLoaded = LoadCredentials();
|
||||
}
|
||||
|
||||
// If in DataHub mode credentials are ignored.
|
||||
if (credentialsLoaded || m_UseDataHub)
|
||||
{
|
||||
WriteDebugMessages("Starting Logentries asynchronous socket client.");
|
||||
WorkerThread.Start();
|
||||
IsRunning = true;
|
||||
}
|
||||
}
|
||||
|
||||
WriteDebugMessages("Queueing: " + line);
|
||||
|
||||
String trimmedEvent = line.TrimEnd(TrimChars);
|
||||
|
||||
// Try to append data to queue.
|
||||
if (!Queue.TryAdd(trimmedEvent))
|
||||
{
|
||||
Queue.Take();
|
||||
if (!Queue.TryAdd(trimmedEvent))
|
||||
WriteDebugMessages(QueueOverflowMessage);
|
||||
}
|
||||
}
|
||||
|
||||
public void interruptWorker()
|
||||
{
|
||||
WorkerThread.Interrupt();
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
@@ -1,103 +0,0 @@
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Net.Security;
|
||||
using System.Net.Sockets;
|
||||
|
||||
namespace LogentriesCore
|
||||
{
|
||||
class LeClient
|
||||
{
|
||||
// Logentries API server address.
|
||||
protected const String LeApiUrl = "api.logentries.com";
|
||||
|
||||
// Port number for token logging on Logentries API server.
|
||||
protected const int LeApiTokenPort = 10000;
|
||||
|
||||
// Port number for TLS encrypted token logging on Logentries API server
|
||||
protected const int LeApiTokenTlsPort = 20000;
|
||||
|
||||
// Port number for HTTP PUT logging on Logentries API server.
|
||||
protected const int LeApiHttpPort = 80;
|
||||
|
||||
// Port number for SSL HTTP PUT logging on Logentries API server.
|
||||
protected const int LeApiHttpsPort = 443;
|
||||
|
||||
// Creates LeClient instance. If do not define useServerUrl and/or useOverrideProt during call
|
||||
// LeClient will be configured to work with api.logentries.com server; otherwise - with
|
||||
// defined server on defined port.
|
||||
public LeClient(bool useHttpPut, bool useSsl, bool useDataHub, String serverAddr, int port)
|
||||
{
|
||||
|
||||
// Override port number and server address to send logs to DataHub instance.
|
||||
if (useDataHub)
|
||||
{
|
||||
m_UseSsl = false; // DataHub does not support receiving log messages over SSL for now.
|
||||
m_TcpPort = port;
|
||||
m_ServerAddr = serverAddr;
|
||||
}
|
||||
else
|
||||
{
|
||||
m_UseSsl = useSsl;
|
||||
|
||||
if (!m_UseSsl)
|
||||
m_TcpPort = useHttpPut ? LeApiHttpPort : LeApiTokenPort;
|
||||
else
|
||||
m_TcpPort = useHttpPut ? LeApiHttpsPort : LeApiTokenTlsPort;
|
||||
}
|
||||
}
|
||||
|
||||
private bool m_UseSsl = false;
|
||||
private int m_TcpPort;
|
||||
private TcpClient m_Client = null;
|
||||
private Stream m_Stream = null;
|
||||
private SslStream m_SslStream = null;
|
||||
private String m_ServerAddr = LeApiUrl; // By default m_ServerAddr points to api.logentries.com if useDataHub is not set to true.
|
||||
|
||||
private Stream ActiveStream
|
||||
{
|
||||
get
|
||||
{
|
||||
return m_UseSsl ? m_SslStream : m_Stream;
|
||||
}
|
||||
}
|
||||
|
||||
public void Connect()
|
||||
{
|
||||
m_Client = new TcpClient(m_ServerAddr, m_TcpPort);
|
||||
m_Client.NoDelay = true;
|
||||
|
||||
m_Stream = m_Client.GetStream();
|
||||
|
||||
if (m_UseSsl)
|
||||
{
|
||||
m_SslStream = new SslStream(m_Stream);
|
||||
m_SslStream.AuthenticateAsClient(m_ServerAddr);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
public void Write(byte[] buffer, int offset, int count)
|
||||
{
|
||||
ActiveStream.Write(buffer, offset, count);
|
||||
}
|
||||
|
||||
public void Flush()
|
||||
{
|
||||
ActiveStream.Flush();
|
||||
}
|
||||
|
||||
public void Close()
|
||||
{
|
||||
if (m_Client != null)
|
||||
{
|
||||
try
|
||||
{
|
||||
m_Client.Close();
|
||||
}
|
||||
catch
|
||||
{
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,83 +0,0 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
||||
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
||||
<ProductVersion>8.0.30703</ProductVersion>
|
||||
<SchemaVersion>2.0</SchemaVersion>
|
||||
<ProjectGuid>{90D6E9FC-7B88-4E1B-B018-8FA742274558}</ProjectGuid>
|
||||
<OutputType>Library</OutputType>
|
||||
<AppDesignerFolder>Properties</AppDesignerFolder>
|
||||
<RootNamespace>LogentriesCore</RootNamespace>
|
||||
<AssemblyName>LogentriesCore</AssemblyName>
|
||||
<TargetFrameworkVersion>v4.0</TargetFrameworkVersion>
|
||||
<FileAlignment>512</FileAlignment>
|
||||
<SolutionDir Condition="$(SolutionDir) == '' Or $(SolutionDir) == '*Undefined*'">..\</SolutionDir>
|
||||
<RestorePackages>true</RestorePackages>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
||||
<DebugSymbols>true</DebugSymbols>
|
||||
<DebugType>full</DebugType>
|
||||
<Optimize>false</Optimize>
|
||||
<OutputPath>bin\Debug\</OutputPath>
|
||||
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
||||
<DebugType>pdbonly</DebugType>
|
||||
<Optimize>true</Optimize>
|
||||
<OutputPath>bin\Release\</OutputPath>
|
||||
<DefineConstants>TRACE</DefineConstants>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'">
|
||||
<DebugSymbols>true</DebugSymbols>
|
||||
<OutputPath>bin\x86\Debug\</OutputPath>
|
||||
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
||||
<DebugType>full</DebugType>
|
||||
<PlatformTarget>x86</PlatformTarget>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x86'">
|
||||
<OutputPath>bin\x86\Release\</OutputPath>
|
||||
<DefineConstants>TRACE</DefineConstants>
|
||||
<Optimize>true</Optimize>
|
||||
<DebugType>pdbonly</DebugType>
|
||||
<PlatformTarget>x86</PlatformTarget>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
||||
</PropertyGroup>
|
||||
<ItemGroup>
|
||||
<Reference Include="System" />
|
||||
<Reference Include="System.configuration" />
|
||||
<Reference Include="System.Core" />
|
||||
<Reference Include="System.Xml.Linq" />
|
||||
<Reference Include="System.Data.DataSetExtensions" />
|
||||
<Reference Include="Microsoft.CSharp" />
|
||||
<Reference Include="System.Data" />
|
||||
<Reference Include="System.Xml" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Compile Include="AsyncLogger.cs" />
|
||||
<Compile Include="LeClient.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<None Include="packages.config" />
|
||||
</ItemGroup>
|
||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
||||
<PropertyGroup>
|
||||
<PostBuildEvent>
|
||||
</PostBuildEvent>
|
||||
</PropertyGroup>
|
||||
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.
|
||||
Other similar extension points exist, see Microsoft.Common.targets.
|
||||
<Target Name="BeforeBuild">
|
||||
</Target>
|
||||
<Target Name="AfterBuild">
|
||||
</Target>
|
||||
-->
|
||||
</Project>
|
||||
@@ -1,35 +0,0 @@
|
||||
using System.Reflection;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
// General Information about an assembly is controlled through the following
|
||||
// set of attributes. Change these attribute values to modify the information
|
||||
// associated with an assembly.
|
||||
[assembly: AssemblyTitle("LogentriesCore")]
|
||||
[assembly: AssemblyDescription("")]
|
||||
[assembly: AssemblyConfiguration("")]
|
||||
[assembly: AssemblyCompany("")]
|
||||
[assembly: AssemblyProduct("LogentriesCore")]
|
||||
[assembly: AssemblyCopyright("Copyright © 2013")]
|
||||
[assembly: AssemblyTrademark("")]
|
||||
[assembly: AssemblyCulture("")]
|
||||
|
||||
// Setting ComVisible to false makes the types in this assembly not visible
|
||||
// to COM components. If you need to access a type in this assembly from
|
||||
// COM, set the ComVisible attribute to true on that type.
|
||||
[assembly: ComVisible(false)]
|
||||
|
||||
// The following GUID is for the ID of the typelib if this project is exposed to COM
|
||||
[assembly: Guid("14055980-6937-4745-9449-dabf47c1d892")]
|
||||
|
||||
// Version information for an assembly consists of the following four values:
|
||||
//
|
||||
// Major Version
|
||||
// Minor Version
|
||||
// Build Number
|
||||
// Revision
|
||||
//
|
||||
// You can specify all the values or you can default the Build and Revision Numbers
|
||||
// by using the '*' as shown below:
|
||||
// [assembly: AssemblyVersion("1.0.*")]
|
||||
[assembly: AssemblyVersion("2.6.0.0")]
|
||||
[assembly: AssemblyFileVersion("2.6.0.0")]
|
||||
@@ -1,4 +0,0 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<packages>
|
||||
<package id="Microsoft.WindowsAzure.ConfigurationManager" version="2.0.1.0" targetFramework="net40" />
|
||||
</packages>
|
||||
@@ -1,100 +0,0 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
||||
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
||||
<ProductVersion>8.0.30703</ProductVersion>
|
||||
<SchemaVersion>2.0</SchemaVersion>
|
||||
<ProjectGuid>{9DC31DE3-79FF-47A8-96B4-6BA18F6BB1CB}</ProjectGuid>
|
||||
<OutputType>Library</OutputType>
|
||||
<AppDesignerFolder>Properties</AppDesignerFolder>
|
||||
<RootNamespace>LogentriesNLog</RootNamespace>
|
||||
<AssemblyName>LogentriesNLog</AssemblyName>
|
||||
<TargetFrameworkVersion>v4.0</TargetFrameworkVersion>
|
||||
<FileAlignment>512</FileAlignment>
|
||||
<SolutionDir Condition="$(SolutionDir) == '' Or $(SolutionDir) == '*Undefined*'">..\</SolutionDir>
|
||||
<RestorePackages>true</RestorePackages>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
||||
<DebugSymbols>true</DebugSymbols>
|
||||
<DebugType>full</DebugType>
|
||||
<Optimize>false</Optimize>
|
||||
<OutputPath>bin\Debug\</OutputPath>
|
||||
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
||||
<DebugType>pdbonly</DebugType>
|
||||
<Optimize>true</Optimize>
|
||||
<OutputPath>bin\Release\</OutputPath>
|
||||
<DefineConstants>TRACE</DefineConstants>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'">
|
||||
<DebugSymbols>true</DebugSymbols>
|
||||
<OutputPath>bin\x86\Debug\</OutputPath>
|
||||
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
||||
<DebugType>full</DebugType>
|
||||
<PlatformTarget>x86</PlatformTarget>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x86'">
|
||||
<OutputPath>bin\x86\Release\</OutputPath>
|
||||
<DefineConstants>TRACE</DefineConstants>
|
||||
<Optimize>true</Optimize>
|
||||
<DebugType>pdbonly</DebugType>
|
||||
<PlatformTarget>x86</PlatformTarget>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
||||
</PropertyGroup>
|
||||
<ItemGroup>
|
||||
<Reference Include="NLog, Version=4.0.0.0, Culture=neutral, PublicKeyToken=5120e14c03d0593c, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\NLog.4.5.0-rc06\lib\net40-client\NLog.dll</HintPath>
|
||||
</Reference>
|
||||
<Reference Include="System" />
|
||||
<Reference Include="System.Configuration" />
|
||||
<Reference Include="System.Core" />
|
||||
<Reference Include="System.Runtime.Serialization" />
|
||||
<Reference Include="System.ServiceModel" />
|
||||
<Reference Include="System.Transactions" />
|
||||
<Reference Include="System.Xml.Linq" />
|
||||
<Reference Include="System.Data.DataSetExtensions" />
|
||||
<Reference Include="Microsoft.CSharp" />
|
||||
<Reference Include="System.Data" />
|
||||
<Reference Include="System.Xml" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Compile Include="fastJSON\Getters.cs" />
|
||||
<Compile Include="fastJSON\JSON.cs" />
|
||||
<Compile Include="fastJSON\JsonParser.cs" />
|
||||
<Compile Include="fastJSON\JsonSerializer.cs" />
|
||||
<Compile Include="fastJSON\SafeDictionary.cs" />
|
||||
<Compile Include="LogentriesTarget.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\LogentriesCore\LogentriesCore.csproj">
|
||||
<Project>{90D6E9FC-7B88-4E1B-B018-8FA742274558}</Project>
|
||||
<Name>LogentriesCore</Name>
|
||||
</ProjectReference>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<None Include="fastJSON\license.txt" />
|
||||
<None Include="packages.config" />
|
||||
</ItemGroup>
|
||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
||||
<PropertyGroup>
|
||||
<PostBuildEvent>
|
||||
</PostBuildEvent>
|
||||
</PropertyGroup>
|
||||
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.
|
||||
Other similar extension points exist, see Microsoft.Common.targets.
|
||||
<Target Name="BeforeBuild">
|
||||
</Target>
|
||||
<Target Name="AfterBuild">
|
||||
</Target>
|
||||
-->
|
||||
</Project>
|
||||
@@ -1,150 +0,0 @@
|
||||
using System;
|
||||
using LogentriesCore;
|
||||
using LogentriesNLog.fastJSON;
|
||||
using NLog;
|
||||
using NLog.Targets;
|
||||
|
||||
namespace LogentriesNLog
|
||||
{
|
||||
[Target("Logentries")]
|
||||
public sealed class LogentriesTarget : TargetWithLayout
|
||||
{
|
||||
private AsyncLogger logentriesAsync;
|
||||
|
||||
public LogentriesTarget()
|
||||
{
|
||||
logentriesAsync = new AsyncLogger();
|
||||
logentriesAsync.setImmediateFlush(true);
|
||||
}
|
||||
|
||||
|
||||
/** Debug flag. */
|
||||
public bool Debug
|
||||
{
|
||||
get { return logentriesAsync.getDebug(); }
|
||||
set { logentriesAsync.setDebug(value); }
|
||||
}
|
||||
|
||||
/** Is using DataHub parameter flag. - ste to true if it is needed to send messages to DataHub instance. */
|
||||
public bool IsUsingDataHub
|
||||
{
|
||||
get { return logentriesAsync.getIsUsingDataHab(); }
|
||||
set { logentriesAsync.setIsUsingDataHub(value); }
|
||||
}
|
||||
|
||||
/** DataHub server address */
|
||||
public String DataHubAddr
|
||||
{
|
||||
get { return logentriesAsync.getDataHubAddr(); }
|
||||
set { logentriesAsync.setDataHubAddr(value); }
|
||||
}
|
||||
|
||||
/** DataHub server port */
|
||||
public int DataHubPort
|
||||
{
|
||||
get { return logentriesAsync.getDataHubPort(); }
|
||||
set { logentriesAsync.setDataHubPort(value); }
|
||||
}
|
||||
|
||||
/** Option to set Token programmatically or in Appender Definition */
|
||||
public string Token
|
||||
{
|
||||
get { return logentriesAsync.getToken(); }
|
||||
set { logentriesAsync.setToken(value); }
|
||||
}
|
||||
|
||||
/** HTTP PUT Flag */
|
||||
public bool HttpPut
|
||||
{
|
||||
get { return logentriesAsync.getUseHttpPut(); }
|
||||
set { logentriesAsync.setUseHttpPut(value); }
|
||||
}
|
||||
|
||||
/** SSL/TLS parameter flag */
|
||||
public bool Ssl
|
||||
{
|
||||
get { return logentriesAsync.getUseSsl(); }
|
||||
set { logentriesAsync.setUseSsl(value); }
|
||||
}
|
||||
|
||||
/** ACCOUNT_KEY parameter for HTTP PUT logging */
|
||||
public String Key
|
||||
{
|
||||
get { return logentriesAsync.getAccountKey(); }
|
||||
set { logentriesAsync.setAccountKey(value); }
|
||||
}
|
||||
|
||||
/** LOCATION parameter for HTTP PUT logging */
|
||||
public String Location
|
||||
{
|
||||
get { return logentriesAsync.getLocation(); }
|
||||
set { logentriesAsync.setLocation(value); }
|
||||
}
|
||||
|
||||
/* LogHostname - switch that defines whether add host name to the log message */
|
||||
public bool LogHostname
|
||||
{
|
||||
get { return logentriesAsync.getUseHostName(); }
|
||||
set { logentriesAsync.setUseHostName(value); }
|
||||
}
|
||||
|
||||
/* HostName - user-defined host name. If empty the library will try to obtain it automatically */
|
||||
public String HostName
|
||||
{
|
||||
get { return logentriesAsync.getHostName(); }
|
||||
set { logentriesAsync.setHostName(value); }
|
||||
}
|
||||
|
||||
/* User-defined log message ID */
|
||||
public String LogID
|
||||
{
|
||||
get { return logentriesAsync.getLogID(); }
|
||||
set { logentriesAsync.setLogID(value); }
|
||||
}
|
||||
|
||||
public bool KeepConnection { get; set; }
|
||||
|
||||
protected override void Write(LogEventInfo logEvent)
|
||||
{
|
||||
//Render message content
|
||||
var log = new Log
|
||||
{
|
||||
Level = logEvent.Level.ToString(),
|
||||
Logger = logEvent.LoggerName,
|
||||
Message = logEvent.FormattedMessage,
|
||||
Time = logEvent.TimeStamp,
|
||||
};
|
||||
|
||||
//NLog can pass null references of Exception
|
||||
if (logEvent.Exception != null)
|
||||
{
|
||||
log.Exception = logEvent.Exception.ToString();
|
||||
log.ExceptionType = logEvent.Exception.GetType().ToString();
|
||||
}
|
||||
|
||||
logentriesAsync.AddLine(JSON.Instance.ToJSON(log));
|
||||
}
|
||||
|
||||
protected override void CloseTarget()
|
||||
{
|
||||
base.CloseTarget();
|
||||
|
||||
logentriesAsync.interruptWorker();
|
||||
}
|
||||
}
|
||||
|
||||
public class Log
|
||||
{
|
||||
public string Message { get; set; }
|
||||
|
||||
public DateTime Time { get; set; }
|
||||
|
||||
public string Logger { get; set; }
|
||||
|
||||
public string Exception { get; set; }
|
||||
|
||||
public string ExceptionType { get; set; }
|
||||
|
||||
public String Level { get; set; }
|
||||
}
|
||||
}
|
||||
@@ -1,35 +0,0 @@
|
||||
using System.Reflection;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
// General Information about an assembly is controlled through the following
|
||||
// set of attributes. Change these attribute values to modify the information
|
||||
// associated with an assembly.
|
||||
[assembly: AssemblyTitle("LogentriesNLog")]
|
||||
[assembly: AssemblyDescription("")]
|
||||
[assembly: AssemblyConfiguration("")]
|
||||
[assembly: AssemblyCompany("")]
|
||||
[assembly: AssemblyProduct("LogentriesNLog")]
|
||||
[assembly: AssemblyCopyright("Copyright © 2013")]
|
||||
[assembly: AssemblyTrademark("")]
|
||||
[assembly: AssemblyCulture("")]
|
||||
|
||||
// Setting ComVisible to false makes the types in this assembly not visible
|
||||
// to COM components. If you need to access a type in this assembly from
|
||||
// COM, set the ComVisible attribute to true on that type.
|
||||
[assembly: ComVisible(false)]
|
||||
|
||||
// The following GUID is for the ID of the typelib if this project is exposed to COM
|
||||
[assembly: Guid("7e04ff2d-ea59-4b62-969d-72bd3e37c684")]
|
||||
|
||||
// Version information for an assembly consists of the following four values:
|
||||
//
|
||||
// Major Version
|
||||
// Minor Version
|
||||
// Build Number
|
||||
// Revision
|
||||
//
|
||||
// You can specify all the values or you can default the Build and Revision Numbers
|
||||
// by using the '*' as shown below:
|
||||
// [assembly: AssemblyVersion("1.0.*")]
|
||||
[assembly: AssemblyVersion("2.4.0.0")]
|
||||
[assembly: AssemblyFileVersion("2.4.0.0")]
|
||||
@@ -1,21 +0,0 @@
|
||||
//http://fastjson.codeplex.com/
|
||||
//http://fastjson.codeplex.com/license
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace LogentriesNLog.fastJSON
|
||||
{
|
||||
internal class Getters
|
||||
{
|
||||
public string Name;
|
||||
public JSON.GenericGetter Getter;
|
||||
public Type propertyType;
|
||||
}
|
||||
|
||||
internal class DatasetSchema
|
||||
{
|
||||
public List<string> Info { get; set; }
|
||||
public string Name { get; set; }
|
||||
}
|
||||
}
|
||||
@@ -1,821 +0,0 @@
|
||||
//http://fastjson.codeplex.com/
|
||||
//http://fastjson.codeplex.com/license
|
||||
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Data;
|
||||
using System.Globalization;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using System.Reflection.Emit;
|
||||
using System.Xml.Serialization;
|
||||
|
||||
namespace LogentriesNLog.fastJSON
|
||||
{
|
||||
|
||||
internal class JSON
|
||||
{
|
||||
public readonly static JSON Instance = new JSON();
|
||||
|
||||
private JSON()
|
||||
{
|
||||
UseSerializerExtension = false;
|
||||
SerializeNullValues = false;
|
||||
UseOptimizedDatasetSchema = false;
|
||||
UsingGlobalTypes = false;
|
||||
UseUTCDateTime = true;
|
||||
}
|
||||
public bool UseOptimizedDatasetSchema = true;
|
||||
public bool UseFastGuid = true;
|
||||
public bool UseSerializerExtension = true;
|
||||
public bool IndentOutput = false;
|
||||
public bool SerializeNullValues = true;
|
||||
public bool UseUTCDateTime = false;
|
||||
public bool ShowReadOnlyProperties = false;
|
||||
public bool UsingGlobalTypes = true;
|
||||
|
||||
public string ToJSON(object obj)
|
||||
{
|
||||
return ToJSON(obj, UseSerializerExtension, UseFastGuid, UseOptimizedDatasetSchema, SerializeNullValues);
|
||||
}
|
||||
|
||||
|
||||
public string ToJSON(object obj,
|
||||
bool enableSerializerExtensions,
|
||||
bool enableFastGuid,
|
||||
bool enableOptimizedDatasetSchema,
|
||||
bool serializeNullValues)
|
||||
{
|
||||
return new JSONSerializer(enableOptimizedDatasetSchema, enableFastGuid, enableSerializerExtensions, serializeNullValues, IndentOutput).ConvertToJSON(obj);
|
||||
}
|
||||
|
||||
|
||||
public T ToObject<T>(string json)
|
||||
{
|
||||
return (T)ToObject(json, typeof(T));
|
||||
}
|
||||
|
||||
|
||||
public object ToObject(string json, Type type)
|
||||
{
|
||||
var ht = new JsonParser(json).Decode() as Dictionary<string, object>;
|
||||
if (ht == null) return null;
|
||||
return ParseDictionary(ht, null, type);
|
||||
}
|
||||
|
||||
#if CUSTOMTYPE
|
||||
internal SafeDictionary<Type, Serialize> _customSerializer = new SafeDictionary<Type, Serialize>();
|
||||
internal SafeDictionary<Type, Deserialize> _customDeserializer = new SafeDictionary<Type, Deserialize>();
|
||||
|
||||
public void RegisterCustomType(Type type, Serialize serializer, Deserialize deserializer)
|
||||
{
|
||||
if (type != null && serializer != null && deserializer != null)
|
||||
{
|
||||
_customSerializer.Add(type, serializer);
|
||||
_customDeserializer.Add(type, deserializer);
|
||||
// reset property cache
|
||||
_propertycache = new SafeDictionary<string, SafeDictionary<string, myPropInfo>>();
|
||||
}
|
||||
}
|
||||
|
||||
internal bool IsTypeRegistered(Type t)
|
||||
{
|
||||
Serialize s;
|
||||
return _customSerializer.TryGetValue(t, out s);
|
||||
}
|
||||
#endif
|
||||
|
||||
#region [ PROPERTY GET SET CACHE ]
|
||||
|
||||
readonly SafeDictionary<Type, string> _tyname = new SafeDictionary<Type, string>();
|
||||
internal string GetTypeAssemblyName(Type t)
|
||||
{
|
||||
string val = "";
|
||||
if (_tyname.TryGetValue(t, out val))
|
||||
return val;
|
||||
string s = t.AssemblyQualifiedName;
|
||||
_tyname.Add(t, s);
|
||||
return s;
|
||||
}
|
||||
|
||||
readonly SafeDictionary<string, Type> _typecache = new SafeDictionary<string, Type>();
|
||||
private Type GetTypeFromCache(string typename)
|
||||
{
|
||||
Type val = null;
|
||||
if (_typecache.TryGetValue(typename, out val))
|
||||
return val;
|
||||
Type t = Type.GetType(typename);
|
||||
_typecache.Add(typename, t);
|
||||
return t;
|
||||
}
|
||||
|
||||
readonly SafeDictionary<Type, CreateObject> _constrcache = new SafeDictionary<Type, CreateObject>();
|
||||
private delegate object CreateObject();
|
||||
private object FastCreateInstance(Type objtype)
|
||||
{
|
||||
try
|
||||
{
|
||||
CreateObject c = null;
|
||||
if (_constrcache.TryGetValue(objtype, out c))
|
||||
{
|
||||
return c();
|
||||
}
|
||||
DynamicMethod dynMethod = new DynamicMethod("_", objtype, null, true);
|
||||
ILGenerator ilGen = dynMethod.GetILGenerator();
|
||||
|
||||
ilGen.Emit(OpCodes.Newobj, objtype.GetConstructor(Type.EmptyTypes));
|
||||
ilGen.Emit(OpCodes.Ret);
|
||||
c = (CreateObject)dynMethod.CreateDelegate(typeof(CreateObject));
|
||||
_constrcache.Add(objtype, c);
|
||||
return c();
|
||||
}
|
||||
catch (Exception exc)
|
||||
{
|
||||
throw new Exception(string.Format("Failed to fast create instance for type '{0}' from assemebly '{1}'",
|
||||
objtype.FullName, objtype.AssemblyQualifiedName), exc);
|
||||
}
|
||||
}
|
||||
|
||||
private struct myPropInfo
|
||||
{
|
||||
public bool filled;
|
||||
public Type pt;
|
||||
public Type bt;
|
||||
public Type changeType;
|
||||
public bool isDictionary;
|
||||
public bool isValueType;
|
||||
public bool isGenericType;
|
||||
public bool isArray;
|
||||
public bool isByteArray;
|
||||
public bool isGuid;
|
||||
#if !SILVERLIGHT
|
||||
public bool isDataSet;
|
||||
public bool isDataTable;
|
||||
public bool isHashtable;
|
||||
#endif
|
||||
public GenericSetter setter;
|
||||
public bool isEnum;
|
||||
public bool isDateTime;
|
||||
public Type[] GenericTypes;
|
||||
public bool isInt;
|
||||
public bool isLong;
|
||||
public bool isString;
|
||||
public bool isBool;
|
||||
public bool isClass;
|
||||
public GenericGetter getter;
|
||||
public bool isStringDictionary;
|
||||
public string Name;
|
||||
#if CUSTOMTYPE
|
||||
public bool isCustomType;
|
||||
#endif
|
||||
public bool CanWrite;
|
||||
}
|
||||
|
||||
readonly SafeDictionary<string, SafeDictionary<string, myPropInfo>> _propertycache = new SafeDictionary<string, SafeDictionary<string, myPropInfo>>();
|
||||
private SafeDictionary<string, myPropInfo> Getproperties(Type type, string typename)
|
||||
{
|
||||
SafeDictionary<string, myPropInfo> sd = null;
|
||||
if (_propertycache.TryGetValue(typename, out sd))
|
||||
{
|
||||
return sd;
|
||||
}
|
||||
sd = new SafeDictionary<string, myPropInfo>();
|
||||
var pr = type.GetProperties(BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Instance);
|
||||
foreach (var p in pr)
|
||||
{
|
||||
myPropInfo d = CreateMyProp(p.PropertyType, p.Name);
|
||||
d.CanWrite = p.CanWrite;
|
||||
d.setter = CreateSetMethod(p);
|
||||
d.getter = CreateGetMethod(p);
|
||||
sd.Add(p.Name, d);
|
||||
}
|
||||
|
||||
_propertycache.Add(typename, sd);
|
||||
return sd;
|
||||
}
|
||||
|
||||
private myPropInfo CreateMyProp(Type t, string name)
|
||||
{
|
||||
myPropInfo d = new myPropInfo();
|
||||
d.filled = true;
|
||||
d.CanWrite = true;
|
||||
d.pt = t;
|
||||
d.Name = name;
|
||||
d.isDictionary = t.Name.Contains("Dictionary");
|
||||
if (d.isDictionary)
|
||||
d.GenericTypes = t.GetGenericArguments();
|
||||
d.isValueType = t.IsValueType;
|
||||
d.isGenericType = t.IsGenericType;
|
||||
d.isArray = t.IsArray;
|
||||
if (d.isArray)
|
||||
d.bt = t.GetElementType();
|
||||
if (d.isGenericType)
|
||||
d.bt = t.GetGenericArguments()[0];
|
||||
d.isByteArray = t == typeof(byte[]);
|
||||
d.isGuid = (t == typeof(Guid) || t == typeof(Guid?));
|
||||
#if !SILVERLIGHT
|
||||
d.isHashtable = t == typeof(Hashtable);
|
||||
d.isDataSet = t == typeof(DataSet);
|
||||
d.isDataTable = t == typeof(DataTable);
|
||||
#endif
|
||||
|
||||
d.changeType = GetChangeType(t);
|
||||
d.isEnum = t.IsEnum;
|
||||
d.isDateTime = t == typeof(DateTime) || t == typeof(DateTime?);
|
||||
d.isInt = t == typeof(int) || t == typeof(int?);
|
||||
d.isLong = t == typeof(long) || t == typeof(long?);
|
||||
d.isString = t == typeof(string);
|
||||
d.isBool = t == typeof(bool) || t == typeof(bool?);
|
||||
d.isClass = t.IsClass;
|
||||
|
||||
if (d.isDictionary && d.GenericTypes.Length > 0 && d.GenericTypes[0] == typeof(string))
|
||||
d.isStringDictionary = true;
|
||||
|
||||
#if CUSTOMTYPE
|
||||
if (IsTypeRegistered(t))
|
||||
d.isCustomType = true;
|
||||
#endif
|
||||
return d;
|
||||
}
|
||||
|
||||
private delegate void GenericSetter(object target, object value);
|
||||
|
||||
private static GenericSetter CreateSetMethod(PropertyInfo propertyInfo)
|
||||
{
|
||||
MethodInfo setMethod = propertyInfo.GetSetMethod(nonPublic: true);
|
||||
if (setMethod == null)
|
||||
return null;
|
||||
|
||||
var arguments = new Type[2];
|
||||
arguments[0] = arguments[1] = typeof(object);
|
||||
|
||||
DynamicMethod setter = new DynamicMethod("_", typeof(void), arguments, true);
|
||||
ILGenerator il = setter.GetILGenerator();
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
il.Emit(OpCodes.Castclass, propertyInfo.DeclaringType);
|
||||
il.Emit(OpCodes.Ldarg_1);
|
||||
|
||||
if (propertyInfo.PropertyType.IsClass)
|
||||
il.Emit(OpCodes.Castclass, propertyInfo.PropertyType);
|
||||
else
|
||||
il.Emit(OpCodes.Unbox_Any, propertyInfo.PropertyType);
|
||||
|
||||
il.EmitCall(OpCodes.Callvirt, setMethod, null);
|
||||
il.Emit(OpCodes.Ret);
|
||||
|
||||
return (GenericSetter)setter.CreateDelegate(typeof(GenericSetter));
|
||||
}
|
||||
|
||||
internal delegate object GenericGetter(object obj);
|
||||
|
||||
|
||||
private GenericGetter CreateGetMethod(PropertyInfo propertyInfo)
|
||||
{
|
||||
MethodInfo getMethod = propertyInfo.GetGetMethod();
|
||||
if (getMethod == null)
|
||||
return null;
|
||||
|
||||
var arguments = new Type[1];
|
||||
arguments[0] = typeof(object);
|
||||
|
||||
DynamicMethod getter = new DynamicMethod("_", typeof(object), arguments, true);
|
||||
ILGenerator il = getter.GetILGenerator();
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
il.Emit(OpCodes.Castclass, propertyInfo.DeclaringType);
|
||||
il.EmitCall(OpCodes.Callvirt, getMethod, null);
|
||||
|
||||
if (!propertyInfo.PropertyType.IsClass)
|
||||
il.Emit(OpCodes.Box, propertyInfo.PropertyType);
|
||||
|
||||
il.Emit(OpCodes.Ret);
|
||||
|
||||
return (GenericGetter)getter.CreateDelegate(typeof(GenericGetter));
|
||||
}
|
||||
|
||||
readonly SafeDictionary<Type, List<Getters>> _getterscache = new SafeDictionary<Type, List<Getters>>();
|
||||
internal List<Getters> GetGetters(Type type)
|
||||
{
|
||||
List<Getters> val = null;
|
||||
if (_getterscache.TryGetValue(type, out val))
|
||||
return val;
|
||||
|
||||
var props = type.GetProperties(BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Instance);
|
||||
var getters = new List<Getters>();
|
||||
foreach (var p in props)
|
||||
{
|
||||
if (!p.CanWrite && ShowReadOnlyProperties == false) continue;
|
||||
|
||||
var att = p.GetCustomAttributes(typeof(XmlIgnoreAttribute), false);
|
||||
if (att != null && att.Length > 0)
|
||||
continue;
|
||||
|
||||
GenericGetter g = CreateGetMethod(p);
|
||||
if (g != null)
|
||||
{
|
||||
Getters gg = new Getters();
|
||||
gg.Name = p.Name;
|
||||
gg.Getter = g;
|
||||
gg.propertyType = p.PropertyType;
|
||||
getters.Add(gg);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
_getterscache.Add(type, getters);
|
||||
return getters;
|
||||
}
|
||||
|
||||
private object ChangeType(object value, Type conversionType)
|
||||
{
|
||||
if (conversionType == typeof(int))
|
||||
return (int)CreateLong((string)value);
|
||||
|
||||
if (conversionType == typeof(long))
|
||||
return CreateLong((string)value);
|
||||
|
||||
if (conversionType == typeof(string))
|
||||
return value;
|
||||
|
||||
if (conversionType == typeof(Guid))
|
||||
return CreateGuid((string)value);
|
||||
|
||||
if (conversionType.IsEnum)
|
||||
return CreateEnum(conversionType, (string)value);
|
||||
|
||||
return Convert.ChangeType(value, conversionType, CultureInfo.InvariantCulture);
|
||||
}
|
||||
#endregion
|
||||
|
||||
|
||||
private object ParseDictionary(Dictionary<string, object> d, Dictionary<string, object> globaltypes, Type type)
|
||||
{
|
||||
object tn = "";
|
||||
if (d.TryGetValue("$types", out tn))
|
||||
{
|
||||
UsingGlobalTypes = true;
|
||||
globaltypes = new Dictionary<string, object>();
|
||||
foreach (var kv in (Dictionary<string, object>)tn)
|
||||
{
|
||||
globaltypes.Add((string)kv.Value, kv.Key);
|
||||
}
|
||||
}
|
||||
|
||||
bool found = d.TryGetValue("$type", out tn);
|
||||
#if !SILVERLIGHT
|
||||
if (found == false && type == typeof(Object))
|
||||
{
|
||||
return CreateDataset(d, globaltypes);
|
||||
}
|
||||
#endif
|
||||
if (found)
|
||||
{
|
||||
if (UsingGlobalTypes)
|
||||
{
|
||||
object tname = "";
|
||||
if (globaltypes.TryGetValue((string)tn, out tname))
|
||||
tn = tname;
|
||||
}
|
||||
type = GetTypeFromCache((string)tn);
|
||||
}
|
||||
|
||||
if (type == null)
|
||||
throw new Exception("Cannot determine type");
|
||||
|
||||
string typename = type.FullName;
|
||||
object o = FastCreateInstance(type);
|
||||
var props = Getproperties(type, typename);
|
||||
foreach (var name in d.Keys)
|
||||
{
|
||||
if (name == "$map")
|
||||
{
|
||||
ProcessMap(o, props, (Dictionary<string, object>)d[name]);
|
||||
continue;
|
||||
}
|
||||
myPropInfo pi;
|
||||
if (props.TryGetValue(name, out pi) == false)
|
||||
continue;
|
||||
if (pi.filled)
|
||||
{
|
||||
object v = d[name];
|
||||
|
||||
if (v != null)
|
||||
{
|
||||
object oset = null;
|
||||
|
||||
if (pi.isInt)
|
||||
oset = (int)CreateLong((string)v);
|
||||
#if CUSTOMTYPE
|
||||
else if (pi.isCustomType)
|
||||
oset = CreateCustom((string)v, pi.pt);
|
||||
#endif
|
||||
else if (pi.isLong)
|
||||
oset = CreateLong((string)v);
|
||||
|
||||
else if (pi.isString)
|
||||
oset = v;
|
||||
|
||||
else if (pi.isBool)
|
||||
oset = (bool)v;
|
||||
|
||||
else if (pi.isGenericType && pi.isValueType == false && pi.isDictionary == false)
|
||||
#if SILVERLIGHT
|
||||
oset = CreateGenericList((List<object>)v, pi.pt, pi.bt, globaltypes);
|
||||
#else
|
||||
oset = CreateGenericList((ArrayList)v, pi.pt, pi.bt, globaltypes);
|
||||
#endif
|
||||
else if (pi.isByteArray)
|
||||
oset = Convert.FromBase64String((string)v);
|
||||
|
||||
else if (pi.isArray && pi.isValueType == false)
|
||||
#if SILVERLIGHT
|
||||
oset = CreateArray((List<object>)v, pi.pt, pi.bt, globaltypes);
|
||||
#else
|
||||
oset = CreateArray((ArrayList)v, pi.pt, pi.bt, globaltypes);
|
||||
#endif
|
||||
else if (pi.isGuid)
|
||||
oset = CreateGuid((string)v);
|
||||
#if !SILVERLIGHT
|
||||
else if (pi.isDataSet)
|
||||
oset = CreateDataset((Dictionary<string, object>)v, globaltypes);
|
||||
|
||||
else if (pi.isDataTable)
|
||||
oset = CreateDataTable((Dictionary<string, object>)v, globaltypes);
|
||||
#endif
|
||||
|
||||
else if (pi.isStringDictionary)
|
||||
oset = CreateStringKeyDictionary((Dictionary<string, object>)v, pi.pt, pi.GenericTypes, globaltypes);
|
||||
|
||||
#if !SILVERLIGHT
|
||||
else if (pi.isDictionary || pi.isHashtable)
|
||||
oset = CreateDictionary((ArrayList)v, pi.pt, pi.GenericTypes, globaltypes);
|
||||
#else
|
||||
else if (pi.isDictionary)
|
||||
oset = CreateDictionary((List<object>)v, pi.pt, pi.GenericTypes, globaltypes);
|
||||
#endif
|
||||
|
||||
else if (pi.isEnum)
|
||||
oset = CreateEnum(pi.pt, (string)v);
|
||||
|
||||
else if (pi.isDateTime)
|
||||
oset = CreateDateTime((string)v);
|
||||
|
||||
else if (pi.isClass && v is Dictionary<string, object>)
|
||||
oset = ParseDictionary((Dictionary<string, object>)v, globaltypes, pi.pt);
|
||||
|
||||
else if (pi.isValueType)
|
||||
oset = ChangeType(v, pi.changeType);
|
||||
|
||||
#if SILVERLIGHT
|
||||
else if (v is List<object>)
|
||||
oset = CreateArray((List<object>)v, pi.pt, typeof(object), globaltypes);
|
||||
#else
|
||||
else if (v is ArrayList)
|
||||
oset = CreateArray((ArrayList)v, pi.pt, typeof(object), globaltypes);
|
||||
#endif
|
||||
else
|
||||
oset = v;
|
||||
|
||||
if (pi.CanWrite)
|
||||
pi.setter(o, oset);
|
||||
}
|
||||
}
|
||||
}
|
||||
return o;
|
||||
}
|
||||
|
||||
#if CUSTOMTYPE
|
||||
private object CreateCustom(string v, Type type)
|
||||
{
|
||||
Deserialize d;
|
||||
_customDeserializer.TryGetValue(type, out d);
|
||||
return d(v);
|
||||
}
|
||||
#endif
|
||||
|
||||
private void ProcessMap(object obj, SafeDictionary<string, myPropInfo> props, Dictionary<string, object> dic)
|
||||
{
|
||||
foreach (var kv in dic)
|
||||
{
|
||||
myPropInfo p = props[kv.Key];
|
||||
object o = p.getter(obj);
|
||||
Type t = Type.GetType((string)kv.Value);
|
||||
if (t == typeof(Guid))
|
||||
p.setter(obj, CreateGuid((string)o));
|
||||
}
|
||||
}
|
||||
|
||||
private long CreateLong(string s)
|
||||
{
|
||||
long num = 0;
|
||||
bool neg = false;
|
||||
foreach (var cc in s)
|
||||
{
|
||||
if (cc == '-')
|
||||
neg = true;
|
||||
else if (cc == '+')
|
||||
neg = false;
|
||||
else
|
||||
{
|
||||
num *= 10;
|
||||
num += (cc - '0');
|
||||
}
|
||||
}
|
||||
|
||||
return neg ? -num : num;
|
||||
}
|
||||
|
||||
private object CreateEnum(Type pt, string v)
|
||||
{
|
||||
// TODO : optimize create enum
|
||||
#if !SILVERLIGHT
|
||||
return Enum.Parse(pt, v);
|
||||
#else
|
||||
return Enum.Parse(pt, v, true);
|
||||
#endif
|
||||
}
|
||||
|
||||
private Guid CreateGuid(string s)
|
||||
{
|
||||
if (s.Length > 30)
|
||||
return new Guid(s);
|
||||
return new Guid(Convert.FromBase64String(s));
|
||||
}
|
||||
|
||||
private DateTime CreateDateTime(string value)
|
||||
{
|
||||
bool utc = false;
|
||||
// 0123456789012345678
|
||||
// datetime format = yyyy-MM-dd HH:mm:ss
|
||||
int year = (int)CreateLong(value.Substring(0, 4));
|
||||
int month = (int)CreateLong(value.Substring(5, 2));
|
||||
int day = (int)CreateLong(value.Substring(8, 2));
|
||||
int hour = (int)CreateLong(value.Substring(11, 2));
|
||||
int min = (int)CreateLong(value.Substring(14, 2));
|
||||
int sec = (int)CreateLong(value.Substring(17, 2));
|
||||
|
||||
if (value.EndsWith("Z"))
|
||||
utc = true;
|
||||
|
||||
if (UseUTCDateTime == false && utc == false)
|
||||
return new DateTime(year, month, day, hour, min, sec);
|
||||
return new DateTime(year, month, day, hour, min, sec, DateTimeKind.Utc).ToLocalTime();
|
||||
}
|
||||
|
||||
#if SILVERLIGHT
|
||||
private object CreateArray(List<object> data, Type pt, Type bt, Dictionary<string, object> globalTypes)
|
||||
{
|
||||
Array col = Array.CreateInstance(bt, data.Count);
|
||||
// create an array of objects
|
||||
for (int i = 0; i < data.Count; i++)// each (object ob in data)
|
||||
{
|
||||
object ob = data[i];
|
||||
if (ob is IDictionary)
|
||||
col.SetValue(ParseDictionary((Dictionary<string, object>)ob, globalTypes, bt), i);
|
||||
else
|
||||
col.SetValue(ChangeType(ob, bt), i);
|
||||
}
|
||||
|
||||
return col;
|
||||
}
|
||||
#else
|
||||
private object CreateArray(ArrayList data, Type pt, Type bt, Dictionary<string, object> globalTypes)
|
||||
{
|
||||
ArrayList col = new ArrayList();
|
||||
// create an array of objects
|
||||
foreach (var ob in data)
|
||||
{
|
||||
if (ob is IDictionary)
|
||||
col.Add(ParseDictionary((Dictionary<string, object>)ob, globalTypes, bt));
|
||||
else
|
||||
col.Add(ChangeType(ob, bt));
|
||||
}
|
||||
return col.ToArray(bt);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
#if SILVERLIGHT
|
||||
private object CreateGenericList(List<object> data, Type pt, Type bt, Dictionary<string, object> globalTypes)
|
||||
#else
|
||||
private object CreateGenericList(ArrayList data, Type pt, Type bt, Dictionary<string, object> globalTypes)
|
||||
#endif
|
||||
{
|
||||
IList col = (IList)FastCreateInstance(pt);
|
||||
// create an array of objects
|
||||
foreach (var ob in data)
|
||||
{
|
||||
if (ob is IDictionary)
|
||||
col.Add(ParseDictionary((Dictionary<string, object>)ob, globalTypes, bt));
|
||||
#if SILVERLIGHT
|
||||
else if (ob is List<object>)
|
||||
col.Add(((List<object>)ob).ToArray());
|
||||
#else
|
||||
else if (ob is ArrayList)
|
||||
col.Add(((ArrayList)ob).ToArray());
|
||||
#endif
|
||||
else
|
||||
col.Add(ChangeType(ob, bt));
|
||||
}
|
||||
return col;
|
||||
}
|
||||
|
||||
private object CreateStringKeyDictionary(Dictionary<string, object> reader, Type pt, Type[] types, Dictionary<string, object> globalTypes)
|
||||
{
|
||||
var col = (IDictionary)FastCreateInstance(pt);
|
||||
Type t1 = null;
|
||||
Type t2 = null;
|
||||
if (types != null)
|
||||
{
|
||||
t1 = types[0];
|
||||
t2 = types[1];
|
||||
}
|
||||
|
||||
foreach (var values in reader)
|
||||
{
|
||||
var key = values.Key;//ChangeType(values.Key, t1);
|
||||
object val = null;
|
||||
if (values.Value is Dictionary<string, object>)
|
||||
val = ParseDictionary((Dictionary<string, object>)values.Value, globalTypes, t2);
|
||||
else
|
||||
val = ChangeType(values.Value, t2);
|
||||
col.Add(key, val);
|
||||
}
|
||||
|
||||
return col;
|
||||
}
|
||||
|
||||
#if SILVERLIGHT
|
||||
private object CreateDictionary(List<object> reader, Type pt, Type[] types, Dictionary<string, object> globalTypes)
|
||||
#else
|
||||
private object CreateDictionary(ArrayList reader, Type pt, Type[] types, Dictionary<string, object> globalTypes)
|
||||
#endif
|
||||
{
|
||||
IDictionary col = (IDictionary)FastCreateInstance(pt);
|
||||
Type t1 = null;
|
||||
Type t2 = null;
|
||||
if (types != null)
|
||||
{
|
||||
t1 = types[0];
|
||||
t2 = types[1];
|
||||
}
|
||||
|
||||
foreach (Dictionary<string, object> values in reader)
|
||||
{
|
||||
object key = values["k"];
|
||||
object val = values["v"];
|
||||
|
||||
if (key is Dictionary<string, object>)
|
||||
key = ParseDictionary((Dictionary<string, object>)key, globalTypes, t1);
|
||||
else
|
||||
key = ChangeType(key, t1);
|
||||
|
||||
if (val is Dictionary<string, object>)
|
||||
val = ParseDictionary((Dictionary<string, object>)val, globalTypes, t2);
|
||||
else
|
||||
val = ChangeType(val, t2);
|
||||
|
||||
col.Add(key, val);
|
||||
}
|
||||
|
||||
return col;
|
||||
}
|
||||
|
||||
private Type GetChangeType(Type conversionType)
|
||||
{
|
||||
if (conversionType.IsGenericType && conversionType.GetGenericTypeDefinition().Equals(typeof(Nullable<>)))
|
||||
return conversionType.GetGenericArguments()[0];
|
||||
|
||||
return conversionType;
|
||||
}
|
||||
#if !SILVERLIGHT
|
||||
private DataSet CreateDataset(Dictionary<string, object> reader, Dictionary<string, object> globalTypes)
|
||||
{
|
||||
DataSet ds = new DataSet();
|
||||
ds.EnforceConstraints = false;
|
||||
ds.BeginInit();
|
||||
|
||||
// read dataset schema here
|
||||
ReadSchema(reader, ds, globalTypes);
|
||||
|
||||
foreach (var pair in reader)
|
||||
{
|
||||
if (pair.Key == "$type" || pair.Key == "$schema") continue;
|
||||
|
||||
ArrayList rows = (ArrayList)pair.Value;
|
||||
if (rows == null) continue;
|
||||
|
||||
DataTable dt = ds.Tables[pair.Key];
|
||||
ReadDataTable(rows, dt);
|
||||
}
|
||||
|
||||
ds.EndInit();
|
||||
|
||||
return ds;
|
||||
}
|
||||
|
||||
private void ReadSchema(Dictionary<string, object> reader, DataSet ds, Dictionary<string, object> globalTypes)
|
||||
{
|
||||
var schema = reader["$schema"];
|
||||
|
||||
if (schema is string)
|
||||
{
|
||||
TextReader tr = new StringReader((string)schema);
|
||||
ds.ReadXmlSchema(tr);
|
||||
}
|
||||
else
|
||||
{
|
||||
DatasetSchema ms = (DatasetSchema)ParseDictionary((Dictionary<string, object>)schema, globalTypes, typeof(DatasetSchema));
|
||||
ds.DataSetName = ms.Name;
|
||||
for (int i = 0; i < ms.Info.Count; i += 3)
|
||||
{
|
||||
if (ds.Tables.Contains(ms.Info[i]) == false)
|
||||
ds.Tables.Add(ms.Info[i]);
|
||||
ds.Tables[ms.Info[i]].Columns.Add(ms.Info[i + 1], Type.GetType(ms.Info[i + 2]));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void ReadDataTable(ArrayList rows, DataTable dt)
|
||||
{
|
||||
dt.BeginInit();
|
||||
dt.BeginLoadData();
|
||||
var guidcols = new List<int>();
|
||||
var datecol = new List<int>();
|
||||
|
||||
foreach (DataColumn c in dt.Columns)
|
||||
{
|
||||
if (c.DataType == typeof(Guid) || c.DataType == typeof(Guid?))
|
||||
guidcols.Add(c.Ordinal);
|
||||
if (UseUTCDateTime && (c.DataType == typeof(DateTime) || c.DataType == typeof(DateTime?)))
|
||||
datecol.Add(c.Ordinal);
|
||||
}
|
||||
|
||||
foreach (ArrayList row in rows)
|
||||
{
|
||||
var v = new object[row.Count];
|
||||
row.CopyTo(v, 0);
|
||||
foreach (var i in guidcols)
|
||||
{
|
||||
string s = (string)v[i];
|
||||
if (s != null && s.Length < 36)
|
||||
v[i] = new Guid(Convert.FromBase64String(s));
|
||||
}
|
||||
if (UseUTCDateTime)
|
||||
{
|
||||
foreach (var i in datecol)
|
||||
{
|
||||
string s = (string)v[i];
|
||||
if (s != null)
|
||||
v[i] = CreateDateTime(s);
|
||||
}
|
||||
}
|
||||
dt.Rows.Add(v);
|
||||
}
|
||||
|
||||
dt.EndLoadData();
|
||||
dt.EndInit();
|
||||
}
|
||||
|
||||
DataTable CreateDataTable(Dictionary<string, object> reader, Dictionary<string, object> globalTypes)
|
||||
{
|
||||
var dt = new DataTable();
|
||||
|
||||
// read dataset schema here
|
||||
var schema = reader["$schema"];
|
||||
|
||||
if (schema is string)
|
||||
{
|
||||
TextReader tr = new StringReader((string)schema);
|
||||
dt.ReadXmlSchema(tr);
|
||||
}
|
||||
else
|
||||
{
|
||||
var ms = (DatasetSchema)ParseDictionary((Dictionary<string, object>)schema, globalTypes, typeof(DatasetSchema));
|
||||
dt.TableName = ms.Info[0];
|
||||
for (int i = 0; i < ms.Info.Count; i += 3)
|
||||
{
|
||||
dt.Columns.Add(ms.Info[i + 1], Type.GetType(ms.Info[i + 2]));
|
||||
}
|
||||
}
|
||||
|
||||
foreach (var pair in reader)
|
||||
{
|
||||
if (pair.Key == "$type" || pair.Key == "$schema")
|
||||
continue;
|
||||
|
||||
var rows = (ArrayList)pair.Value;
|
||||
if (rows == null)
|
||||
continue;
|
||||
|
||||
if (!dt.TableName.Equals(pair.Key, StringComparison.InvariantCultureIgnoreCase))
|
||||
continue;
|
||||
|
||||
ReadDataTable(rows, dt);
|
||||
}
|
||||
|
||||
return dt;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
}
|
||||
@@ -1,409 +0,0 @@
|
||||
//http://fastjson.codeplex.com/
|
||||
//http://fastjson.codeplex.com/license
|
||||
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Text;
|
||||
|
||||
namespace LogentriesNLog.fastJSON
|
||||
{
|
||||
/// <summary>
|
||||
/// This class encodes and decodes JSON strings.
|
||||
/// Spec. details, see http://www.json.org/
|
||||
///
|
||||
/// JSON uses Arrays and Objects. These correspond here to the datatypes ArrayList and Hashtable.
|
||||
/// All numbers are parsed to doubles.
|
||||
/// </summary>
|
||||
internal class JsonParser
|
||||
{
|
||||
enum Token
|
||||
{
|
||||
None = -1, // Used to denote no Lookahead available
|
||||
Curly_Open,
|
||||
Curly_Close,
|
||||
Squared_Open,
|
||||
Squared_Close,
|
||||
Colon,
|
||||
Comma,
|
||||
String,
|
||||
Number,
|
||||
True,
|
||||
False,
|
||||
Null
|
||||
}
|
||||
|
||||
readonly char[] json;
|
||||
readonly StringBuilder s = new StringBuilder();
|
||||
Token lookAheadToken = Token.None;
|
||||
int index;
|
||||
|
||||
internal JsonParser(string json)
|
||||
{
|
||||
this.json = json.ToCharArray();
|
||||
}
|
||||
|
||||
public object Decode()
|
||||
{
|
||||
return ParseValue();
|
||||
}
|
||||
|
||||
private Dictionary<string, object> ParseObject()
|
||||
{
|
||||
var table = new Dictionary<string, object>();
|
||||
|
||||
ConsumeToken(); // {
|
||||
|
||||
while (true)
|
||||
{
|
||||
switch (LookAhead())
|
||||
{
|
||||
|
||||
case Token.Comma:
|
||||
ConsumeToken();
|
||||
break;
|
||||
|
||||
case Token.Curly_Close:
|
||||
ConsumeToken();
|
||||
return table;
|
||||
|
||||
default:
|
||||
{
|
||||
|
||||
// name
|
||||
string name = ParseString();
|
||||
|
||||
// :
|
||||
if (NextToken() != Token.Colon)
|
||||
{
|
||||
throw new Exception("Expected colon at index " + index);
|
||||
}
|
||||
|
||||
// value
|
||||
object value = ParseValue();
|
||||
|
||||
table[name] = value;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#if SILVERLIGHT
|
||||
private List<object> ParseArray()
|
||||
{
|
||||
List<object> array = new List<object>();
|
||||
#else
|
||||
private ArrayList ParseArray()
|
||||
{
|
||||
ArrayList array = new ArrayList();
|
||||
#endif
|
||||
ConsumeToken(); // [
|
||||
|
||||
while (true)
|
||||
{
|
||||
switch (LookAhead())
|
||||
{
|
||||
|
||||
case Token.Comma:
|
||||
ConsumeToken();
|
||||
break;
|
||||
|
||||
case Token.Squared_Close:
|
||||
ConsumeToken();
|
||||
return array;
|
||||
|
||||
default:
|
||||
{
|
||||
array.Add(ParseValue());
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private object ParseValue()
|
||||
{
|
||||
switch (LookAhead())
|
||||
{
|
||||
case Token.Number:
|
||||
return ParseNumber();
|
||||
|
||||
case Token.String:
|
||||
return ParseString();
|
||||
|
||||
case Token.Curly_Open:
|
||||
return ParseObject();
|
||||
|
||||
case Token.Squared_Open:
|
||||
return ParseArray();
|
||||
|
||||
case Token.True:
|
||||
ConsumeToken();
|
||||
return true;
|
||||
|
||||
case Token.False:
|
||||
ConsumeToken();
|
||||
return false;
|
||||
|
||||
case Token.Null:
|
||||
ConsumeToken();
|
||||
return null;
|
||||
}
|
||||
|
||||
throw new Exception("Unrecognized token at index" + index);
|
||||
}
|
||||
|
||||
private string ParseString()
|
||||
{
|
||||
ConsumeToken(); // "
|
||||
|
||||
s.Length = 0;
|
||||
|
||||
int runIndex = -1;
|
||||
|
||||
while (index < json.Length)
|
||||
{
|
||||
var c = json[index++];
|
||||
|
||||
if (c == '"')
|
||||
{
|
||||
if (runIndex != -1)
|
||||
{
|
||||
if (s.Length == 0)
|
||||
return new string(json, runIndex, index - runIndex - 1);
|
||||
|
||||
s.Append(json, runIndex, index - runIndex - 1);
|
||||
}
|
||||
return s.ToString();
|
||||
}
|
||||
|
||||
if (c != '\\')
|
||||
{
|
||||
if (runIndex == -1)
|
||||
runIndex = index - 1;
|
||||
|
||||
continue;
|
||||
}
|
||||
|
||||
if (index == json.Length) break;
|
||||
|
||||
if (runIndex != -1)
|
||||
{
|
||||
s.Append(json, runIndex, index - runIndex - 1);
|
||||
runIndex = -1;
|
||||
}
|
||||
|
||||
switch (json[index++])
|
||||
{
|
||||
case '"':
|
||||
s.Append('"');
|
||||
break;
|
||||
|
||||
case '\\':
|
||||
s.Append('\\');
|
||||
break;
|
||||
|
||||
case '/':
|
||||
s.Append('/');
|
||||
break;
|
||||
|
||||
case 'b':
|
||||
s.Append('\b');
|
||||
break;
|
||||
|
||||
case 'f':
|
||||
s.Append('\f');
|
||||
break;
|
||||
|
||||
case 'n':
|
||||
s.Append('\n');
|
||||
break;
|
||||
|
||||
case 'r':
|
||||
s.Append('\r');
|
||||
break;
|
||||
|
||||
case 't':
|
||||
s.Append('\t');
|
||||
break;
|
||||
|
||||
case 'u':
|
||||
{
|
||||
int remainingLength = json.Length - index;
|
||||
if (remainingLength < 4) break;
|
||||
|
||||
// parse the 32 bit hex into an integer codepoint
|
||||
uint codePoint = ParseUnicode(json[index], json[index + 1], json[index + 2], json[index + 3]);
|
||||
s.Append((char)codePoint);
|
||||
|
||||
// skip 4 chars
|
||||
index += 4;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
throw new Exception("Unexpectedly reached end of string");
|
||||
}
|
||||
|
||||
private uint ParseSingleChar(char c1, uint multipliyer)
|
||||
{
|
||||
uint p1 = 0;
|
||||
if (c1 >= '0' && c1 <= '9')
|
||||
p1 = (uint)(c1 - '0') * multipliyer;
|
||||
else if (c1 >= 'A' && c1 <= 'F')
|
||||
p1 = (uint)((c1 - 'A') + 10) * multipliyer;
|
||||
else if (c1 >= 'a' && c1 <= 'f')
|
||||
p1 = (uint)((c1 - 'a') + 10) * multipliyer;
|
||||
return p1;
|
||||
}
|
||||
|
||||
private uint ParseUnicode(char c1, char c2, char c3, char c4)
|
||||
{
|
||||
uint p1 = ParseSingleChar(c1, 0x1000);
|
||||
uint p2 = ParseSingleChar(c2, 0x100);
|
||||
uint p3 = ParseSingleChar(c3, 0x10);
|
||||
uint p4 = ParseSingleChar(c4, 1);
|
||||
|
||||
return p1 + p2 + p3 + p4;
|
||||
}
|
||||
|
||||
private string ParseNumber()
|
||||
{
|
||||
ConsumeToken();
|
||||
|
||||
// Need to start back one place because the first digit is also a token and would have been consumed
|
||||
var startIndex = index - 1;
|
||||
|
||||
do
|
||||
{
|
||||
var c = json[index];
|
||||
|
||||
if ((c >= '0' && c <= '9') || c == '.' || c == '-' || c == '+' || c == 'e' || c == 'E')
|
||||
{
|
||||
if (++index == json.Length) throw new Exception("Unexpected end of string whilst parsing number");
|
||||
continue;
|
||||
}
|
||||
|
||||
break;
|
||||
} while (true);
|
||||
|
||||
return new string(json, startIndex, index - startIndex);
|
||||
}
|
||||
|
||||
private Token LookAhead()
|
||||
{
|
||||
if (lookAheadToken != Token.None) return lookAheadToken;
|
||||
|
||||
return lookAheadToken = NextTokenCore();
|
||||
}
|
||||
|
||||
private void ConsumeToken()
|
||||
{
|
||||
lookAheadToken = Token.None;
|
||||
}
|
||||
|
||||
private Token NextToken()
|
||||
{
|
||||
var result = lookAheadToken != Token.None ? lookAheadToken : NextTokenCore();
|
||||
|
||||
lookAheadToken = Token.None;
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
private Token NextTokenCore()
|
||||
{
|
||||
char c;
|
||||
|
||||
// Skip past whitespace
|
||||
do
|
||||
{
|
||||
c = json[index];
|
||||
|
||||
if (c > ' ') break;
|
||||
if (c != ' ' && c != '\t' && c != '\n' && c != '\r') break;
|
||||
|
||||
} while (++index < json.Length);
|
||||
|
||||
if (index == json.Length)
|
||||
{
|
||||
throw new Exception("Reached end of string unexpectedly");
|
||||
}
|
||||
|
||||
c = json[index];
|
||||
|
||||
index++;
|
||||
|
||||
//if (c >= '0' && c <= '9')
|
||||
// return Token.Number;
|
||||
|
||||
switch (c)
|
||||
{
|
||||
case '{':
|
||||
return Token.Curly_Open;
|
||||
|
||||
case '}':
|
||||
return Token.Curly_Close;
|
||||
|
||||
case '[':
|
||||
return Token.Squared_Open;
|
||||
|
||||
case ']':
|
||||
return Token.Squared_Close;
|
||||
|
||||
case ',':
|
||||
return Token.Comma;
|
||||
|
||||
case '"':
|
||||
return Token.String;
|
||||
|
||||
case '0': case '1': case '2': case '3': case '4':
|
||||
case '5': case '6': case '7': case '8': case '9':
|
||||
case '-': case '+': case '.':
|
||||
return Token.Number;
|
||||
|
||||
case ':':
|
||||
return Token.Colon;
|
||||
|
||||
case 'f':
|
||||
if (json.Length - index >= 4 &&
|
||||
json[index + 0] == 'a' &&
|
||||
json[index + 1] == 'l' &&
|
||||
json[index + 2] == 's' &&
|
||||
json[index + 3] == 'e')
|
||||
{
|
||||
index += 4;
|
||||
return Token.False;
|
||||
}
|
||||
break;
|
||||
|
||||
case 't':
|
||||
if (json.Length - index >= 3 &&
|
||||
json[index + 0] == 'r' &&
|
||||
json[index + 1] == 'u' &&
|
||||
json[index + 2] == 'e')
|
||||
{
|
||||
index += 3;
|
||||
return Token.True;
|
||||
}
|
||||
break;
|
||||
|
||||
case 'n':
|
||||
if (json.Length - index >= 3 &&
|
||||
json[index + 0] == 'u' &&
|
||||
json[index + 1] == 'l' &&
|
||||
json[index + 2] == 'l')
|
||||
{
|
||||
index += 3;
|
||||
return Token.Null;
|
||||
}
|
||||
break;
|
||||
|
||||
}
|
||||
|
||||
throw new Exception("Could not find token at index " + --index);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,521 +0,0 @@
|
||||
//http://fastjson.codeplex.com/
|
||||
//http://fastjson.codeplex.com/license
|
||||
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Data;
|
||||
using System.Globalization;
|
||||
using System.IO;
|
||||
using System.Text;
|
||||
|
||||
namespace LogentriesNLog.fastJSON
|
||||
{
|
||||
internal class JSONSerializer
|
||||
{
|
||||
private readonly StringBuilder _output = new StringBuilder();
|
||||
readonly bool useMinimalDataSetSchema;
|
||||
readonly bool fastguid = true;
|
||||
readonly bool useExtension = true;
|
||||
readonly bool serializeNulls = true;
|
||||
readonly int _MAX_DEPTH = 10;
|
||||
readonly bool _Indent;
|
||||
readonly bool _useGlobalTypes = true;
|
||||
int _current_depth;
|
||||
private readonly Dictionary<string, int> _globalTypes = new Dictionary<string, int>();
|
||||
|
||||
internal JSONSerializer(bool UseMinimalDataSetSchema, bool UseFastGuid, bool UseExtensions, bool SerializeNulls, bool IndentOutput)
|
||||
{
|
||||
useMinimalDataSetSchema = UseMinimalDataSetSchema;
|
||||
fastguid = UseFastGuid;
|
||||
useExtension = UseExtensions;
|
||||
_Indent = IndentOutput;
|
||||
serializeNulls = SerializeNulls;
|
||||
if (useExtension == false)
|
||||
_useGlobalTypes = false;
|
||||
}
|
||||
|
||||
internal string ConvertToJSON(object obj)
|
||||
{
|
||||
WriteValue(obj);
|
||||
|
||||
string str = "";
|
||||
if (_useGlobalTypes)
|
||||
{
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sb.Append("{\"$types\":{");
|
||||
bool pendingSeparator = false;
|
||||
foreach (var kv in _globalTypes)
|
||||
{
|
||||
if (pendingSeparator) sb.Append(',');
|
||||
pendingSeparator = true;
|
||||
sb.Append("\"");
|
||||
sb.Append(kv.Key);
|
||||
sb.Append("\":\"");
|
||||
sb.Append(kv.Value);
|
||||
sb.Append("\"");
|
||||
}
|
||||
sb.Append("},");
|
||||
str = sb + _output.ToString();
|
||||
}
|
||||
else
|
||||
str = _output.ToString();
|
||||
|
||||
return str;
|
||||
}
|
||||
|
||||
private void WriteValue(object obj)
|
||||
{
|
||||
if (obj == null || obj is DBNull)
|
||||
_output.Append("null");
|
||||
|
||||
else if (obj is string || obj is char)
|
||||
WriteString((string)obj);
|
||||
|
||||
else if (obj is Guid)
|
||||
WriteGuid((Guid)obj);
|
||||
|
||||
else if (obj is bool)
|
||||
_output.Append(((bool)obj) ? "true" : "false"); // conform to standard
|
||||
|
||||
else if (
|
||||
obj is int || obj is long || obj is double ||
|
||||
obj is decimal || obj is float ||
|
||||
obj is byte || obj is short ||
|
||||
obj is sbyte || obj is ushort ||
|
||||
obj is uint || obj is ulong
|
||||
)
|
||||
_output.Append(((IConvertible)obj).ToString(NumberFormatInfo.InvariantInfo));
|
||||
|
||||
else if (obj is DateTime)
|
||||
WriteDateTime((DateTime)obj);
|
||||
|
||||
else if (obj is IDictionary && obj.GetType().IsGenericType && obj.GetType().GetGenericArguments()[0] == typeof(string))
|
||||
WriteStringDictionary((IDictionary)obj);
|
||||
|
||||
else if (obj is IDictionary)
|
||||
WriteDictionary((IDictionary)obj);
|
||||
#if !SILVERLIGHT
|
||||
else if (obj is DataSet)
|
||||
WriteDataset((DataSet)obj);
|
||||
|
||||
else if (obj is DataTable)
|
||||
WriteDataTable((DataTable)obj);
|
||||
#endif
|
||||
else if (obj is byte[])
|
||||
WriteBytes((byte[])obj);
|
||||
|
||||
else if (obj is Array || obj is IList || obj is ICollection)
|
||||
WriteArray((IEnumerable)obj);
|
||||
|
||||
else if (obj is Enum)
|
||||
WriteEnum((Enum)obj);
|
||||
|
||||
#if CUSTOMTYPE
|
||||
else if (JSON.Instance.IsTypeRegistered(obj.GetType()))
|
||||
WriteCustom(obj);
|
||||
#endif
|
||||
else
|
||||
WriteObject(obj);
|
||||
}
|
||||
|
||||
#if CUSTOMTYPE
|
||||
private void WriteCustom(object obj)
|
||||
{
|
||||
Serialize s;
|
||||
JSON.Instance._customSerializer.TryGetValue(obj.GetType(), out s);
|
||||
WriteStringFast(s(obj));
|
||||
}
|
||||
#endif
|
||||
|
||||
private void WriteEnum(Enum e)
|
||||
{
|
||||
// TODO : optimize enum write
|
||||
WriteStringFast(e.ToString());
|
||||
}
|
||||
|
||||
private void WriteGuid(Guid g)
|
||||
{
|
||||
if (fastguid == false)
|
||||
WriteStringFast(g.ToString());
|
||||
else
|
||||
WriteBytes(g.ToByteArray());
|
||||
}
|
||||
|
||||
private void WriteBytes(byte[] bytes)
|
||||
{
|
||||
#if !SILVERLIGHT
|
||||
WriteStringFast(Convert.ToBase64String(bytes, 0, bytes.Length, Base64FormattingOptions.None));
|
||||
#else
|
||||
WriteStringFast(Convert.ToBase64String(bytes, 0, bytes.Length));
|
||||
#endif
|
||||
}
|
||||
|
||||
private void WriteDateTime(DateTime dateTime)
|
||||
{
|
||||
// datetime format standard : yyyy-MM-dd HH:mm:ss
|
||||
DateTime dt = dateTime;
|
||||
if (JSON.Instance.UseUTCDateTime)
|
||||
dt = dateTime.ToUniversalTime();
|
||||
|
||||
_output.Append("\"");
|
||||
_output.Append(dt.Year.ToString("0000", NumberFormatInfo.InvariantInfo));
|
||||
_output.Append("-");
|
||||
_output.Append(dt.Month.ToString("00", NumberFormatInfo.InvariantInfo));
|
||||
_output.Append("-");
|
||||
_output.Append(dt.Day.ToString("00", NumberFormatInfo.InvariantInfo));
|
||||
_output.Append(" ");
|
||||
_output.Append(dt.Hour.ToString("00", NumberFormatInfo.InvariantInfo));
|
||||
_output.Append(":");
|
||||
_output.Append(dt.Minute.ToString("00", NumberFormatInfo.InvariantInfo));
|
||||
_output.Append(":");
|
||||
_output.Append(dt.Second.ToString("00", NumberFormatInfo.InvariantInfo));
|
||||
_output.Append(".");
|
||||
_output.Append(dt.Millisecond.ToString("000", NumberFormatInfo.InvariantInfo));
|
||||
|
||||
if (JSON.Instance.UseUTCDateTime)
|
||||
_output.Append("Z");
|
||||
|
||||
_output.Append("\"");
|
||||
}
|
||||
#if !SILVERLIGHT
|
||||
private DatasetSchema GetSchema(DataTable ds)
|
||||
{
|
||||
if (ds == null) return null;
|
||||
|
||||
DatasetSchema m = new DatasetSchema();
|
||||
m.Info = new List<string>();
|
||||
m.Name = ds.TableName;
|
||||
|
||||
foreach (DataColumn c in ds.Columns)
|
||||
{
|
||||
m.Info.Add(ds.TableName);
|
||||
m.Info.Add(c.ColumnName);
|
||||
m.Info.Add(c.DataType.ToString());
|
||||
}
|
||||
// TODO : serialize relations and constraints here
|
||||
|
||||
return m;
|
||||
}
|
||||
|
||||
private DatasetSchema GetSchema(DataSet ds)
|
||||
{
|
||||
if (ds == null) return null;
|
||||
|
||||
DatasetSchema m = new DatasetSchema();
|
||||
m.Info = new List<string>();
|
||||
m.Name = ds.DataSetName;
|
||||
|
||||
foreach (DataTable t in ds.Tables)
|
||||
{
|
||||
foreach (DataColumn c in t.Columns)
|
||||
{
|
||||
m.Info.Add(t.TableName);
|
||||
m.Info.Add(c.ColumnName);
|
||||
m.Info.Add(c.DataType.ToString());
|
||||
}
|
||||
}
|
||||
// TODO : serialize relations and constraints here
|
||||
|
||||
return m;
|
||||
}
|
||||
|
||||
private string GetXmlSchema(DataTable dt)
|
||||
{
|
||||
using (var writer = new StringWriter())
|
||||
{
|
||||
dt.WriteXmlSchema(writer);
|
||||
return dt.ToString();
|
||||
}
|
||||
}
|
||||
|
||||
private void WriteDataset(DataSet ds)
|
||||
{
|
||||
_output.Append('{');
|
||||
if (useExtension)
|
||||
{
|
||||
WritePair("$schema", useMinimalDataSetSchema ? (object)GetSchema(ds) : ds.GetXmlSchema());
|
||||
_output.Append(',');
|
||||
}
|
||||
bool tablesep = false;
|
||||
foreach (DataTable table in ds.Tables)
|
||||
{
|
||||
if (tablesep) _output.Append(",");
|
||||
tablesep = true;
|
||||
WriteDataTableData(table);
|
||||
}
|
||||
// end dataset
|
||||
_output.Append('}');
|
||||
}
|
||||
|
||||
private void WriteDataTableData(DataTable table)
|
||||
{
|
||||
_output.Append('\"');
|
||||
_output.Append(table.TableName);
|
||||
_output.Append("\":[");
|
||||
DataColumnCollection cols = table.Columns;
|
||||
bool rowseparator = false;
|
||||
foreach (DataRow row in table.Rows)
|
||||
{
|
||||
if (rowseparator) _output.Append(",");
|
||||
rowseparator = true;
|
||||
_output.Append('[');
|
||||
|
||||
bool pendingSeperator = false;
|
||||
foreach (DataColumn column in cols)
|
||||
{
|
||||
if (pendingSeperator) _output.Append(',');
|
||||
WriteValue(row[column]);
|
||||
pendingSeperator = true;
|
||||
}
|
||||
_output.Append(']');
|
||||
}
|
||||
|
||||
_output.Append(']');
|
||||
}
|
||||
|
||||
void WriteDataTable(DataTable dt)
|
||||
{
|
||||
_output.Append('{');
|
||||
if (useExtension)
|
||||
{
|
||||
WritePair("$schema", useMinimalDataSetSchema ? (object)GetSchema(dt) : GetXmlSchema(dt));
|
||||
_output.Append(',');
|
||||
}
|
||||
|
||||
WriteDataTableData(dt);
|
||||
|
||||
// end datatable
|
||||
_output.Append('}');
|
||||
}
|
||||
#endif
|
||||
bool _firstWritten;
|
||||
private void WriteObject(object obj)
|
||||
{
|
||||
Indent();
|
||||
if (_useGlobalTypes == false)
|
||||
_output.Append('{');
|
||||
else
|
||||
{
|
||||
if (_firstWritten)
|
||||
_output.Append("{");
|
||||
}
|
||||
_firstWritten = true;
|
||||
_current_depth++;
|
||||
if (_current_depth > _MAX_DEPTH)
|
||||
throw new Exception("Serializer encountered maximum depth of " + _MAX_DEPTH);
|
||||
|
||||
|
||||
var map = new Dictionary<string, string>();
|
||||
Type t = obj.GetType();
|
||||
bool append = false;
|
||||
if (useExtension)
|
||||
{
|
||||
if (_useGlobalTypes == false)
|
||||
WritePairFast("$type", JSON.Instance.GetTypeAssemblyName(t));
|
||||
else
|
||||
{
|
||||
int dt = 0;
|
||||
string ct = JSON.Instance.GetTypeAssemblyName(t);
|
||||
if (_globalTypes.TryGetValue(ct, out dt) == false)
|
||||
{
|
||||
dt = _globalTypes.Count + 1;
|
||||
_globalTypes.Add(ct, dt);
|
||||
}
|
||||
WritePairFast("$type", dt.ToString());
|
||||
}
|
||||
append = true;
|
||||
}
|
||||
|
||||
var g = JSON.Instance.GetGetters(t);
|
||||
foreach (var p in g)
|
||||
{
|
||||
if (append)
|
||||
_output.Append(',');
|
||||
object o = p.Getter(obj);
|
||||
if ((o == null || o is DBNull) && serializeNulls == false)
|
||||
append = false;
|
||||
else
|
||||
{
|
||||
WritePair(p.Name, o);
|
||||
if (o != null && useExtension)
|
||||
{
|
||||
Type tt = o.GetType();
|
||||
if (tt == typeof(Object))
|
||||
map.Add(p.Name, tt.ToString());
|
||||
}
|
||||
append = true;
|
||||
}
|
||||
}
|
||||
if (map.Count > 0 && useExtension)
|
||||
{
|
||||
_output.Append(",\"$map\":");
|
||||
WriteStringDictionary(map);
|
||||
}
|
||||
_current_depth--;
|
||||
Indent();
|
||||
_output.Append('}');
|
||||
_current_depth--;
|
||||
|
||||
}
|
||||
|
||||
private void Indent()
|
||||
{
|
||||
Indent(false);
|
||||
}
|
||||
|
||||
private void Indent(bool dec)
|
||||
{
|
||||
if (_Indent)
|
||||
{
|
||||
_output.Append("\r\n");
|
||||
for (int i = 0; i < _current_depth - (dec ? 1 : 0); i++)
|
||||
_output.Append("\t");
|
||||
}
|
||||
}
|
||||
|
||||
private void WritePairFast(string name, string value)
|
||||
{
|
||||
if ((value == null) && serializeNulls == false)
|
||||
return;
|
||||
Indent();
|
||||
WriteStringFast(name);
|
||||
|
||||
_output.Append(':');
|
||||
|
||||
WriteStringFast(value);
|
||||
}
|
||||
|
||||
private void WritePair(string name, object value)
|
||||
{
|
||||
if ((value == null || value is DBNull) && serializeNulls == false)
|
||||
return;
|
||||
Indent();
|
||||
WriteStringFast(name);
|
||||
|
||||
_output.Append(':');
|
||||
|
||||
WriteValue(value);
|
||||
}
|
||||
|
||||
private void WriteArray(IEnumerable array)
|
||||
{
|
||||
Indent();
|
||||
_output.Append('[');
|
||||
|
||||
bool pendingSeperator = false;
|
||||
|
||||
foreach (var obj in array)
|
||||
{
|
||||
Indent();
|
||||
if (pendingSeperator) _output.Append(',');
|
||||
|
||||
WriteValue(obj);
|
||||
|
||||
pendingSeperator = true;
|
||||
}
|
||||
Indent();
|
||||
_output.Append(']');
|
||||
}
|
||||
|
||||
private void WriteStringDictionary(IDictionary dic)
|
||||
{
|
||||
Indent();
|
||||
_output.Append('{');
|
||||
|
||||
bool pendingSeparator = false;
|
||||
|
||||
foreach (DictionaryEntry entry in dic)
|
||||
{
|
||||
if (pendingSeparator) _output.Append(',');
|
||||
|
||||
WritePair((string)entry.Key, entry.Value);
|
||||
|
||||
pendingSeparator = true;
|
||||
}
|
||||
Indent();
|
||||
_output.Append('}');
|
||||
}
|
||||
|
||||
private void WriteDictionary(IDictionary dic)
|
||||
{
|
||||
Indent();
|
||||
_output.Append('[');
|
||||
|
||||
bool pendingSeparator = false;
|
||||
|
||||
foreach (DictionaryEntry entry in dic)
|
||||
{
|
||||
if (pendingSeparator) _output.Append(',');
|
||||
Indent();
|
||||
_output.Append('{');
|
||||
WritePair("k", entry.Key);
|
||||
_output.Append(",");
|
||||
WritePair("v", entry.Value);
|
||||
Indent();
|
||||
_output.Append('}');
|
||||
|
||||
pendingSeparator = true;
|
||||
}
|
||||
Indent();
|
||||
_output.Append(']');
|
||||
}
|
||||
|
||||
private void WriteStringFast(string s)
|
||||
{
|
||||
//Indent();
|
||||
_output.Append('\"');
|
||||
_output.Append(s);
|
||||
_output.Append('\"');
|
||||
}
|
||||
|
||||
private void WriteString(string s)
|
||||
{
|
||||
//Indent();
|
||||
_output.Append('\"');
|
||||
|
||||
int runIndex = -1;
|
||||
|
||||
for (var index = 0; index < s.Length; ++index)
|
||||
{
|
||||
var c = s[index];
|
||||
|
||||
if (c >= ' ' && c < 128 && c != '\"' && c != '\\')
|
||||
{
|
||||
if (runIndex == -1)
|
||||
{
|
||||
runIndex = index;
|
||||
}
|
||||
|
||||
continue;
|
||||
}
|
||||
|
||||
if (runIndex != -1)
|
||||
{
|
||||
_output.Append(s, runIndex, index - runIndex);
|
||||
runIndex = -1;
|
||||
}
|
||||
|
||||
switch (c)
|
||||
{
|
||||
case '\t': _output.Append("\\t"); break;
|
||||
case '\r': _output.Append("\\r"); break;
|
||||
case '\n': _output.Append("\\n"); break;
|
||||
case '"':
|
||||
case '\\': _output.Append('\\'); _output.Append(c); break;
|
||||
default:
|
||||
_output.Append("\\u");
|
||||
_output.Append(((int)c).ToString("X4", NumberFormatInfo.InvariantInfo));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (runIndex != -1)
|
||||
{
|
||||
_output.Append(s, runIndex, s.Length - runIndex);
|
||||
}
|
||||
|
||||
_output.Append('\"');
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,36 +0,0 @@
|
||||
//http://fastjson.codeplex.com/
|
||||
//http://fastjson.codeplex.com/license
|
||||
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace LogentriesNLog.fastJSON
|
||||
{
|
||||
internal class SafeDictionary<TKey, TValue>
|
||||
{
|
||||
private readonly object _Padlock = new object();
|
||||
private readonly Dictionary<TKey, TValue> _Dictionary = new Dictionary<TKey, TValue>();
|
||||
|
||||
|
||||
internal bool TryGetValue(TKey key, out TValue value)
|
||||
{
|
||||
return _Dictionary.TryGetValue(key, out value);
|
||||
}
|
||||
|
||||
internal TValue this[TKey key]
|
||||
{
|
||||
get
|
||||
{
|
||||
return _Dictionary[key];
|
||||
}
|
||||
}
|
||||
|
||||
internal void Add(TKey key, TValue value)
|
||||
{
|
||||
lock (_Padlock)
|
||||
{
|
||||
if (_Dictionary.ContainsKey(key) == false)
|
||||
_Dictionary.Add(key, value);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,87 +0,0 @@
|
||||
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.
|
||||
@@ -1,4 +0,0 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<packages>
|
||||
<package id="NLog" version="4.5.0-rc06" targetFramework="net40" />
|
||||
</packages>
|
||||
@@ -941,21 +941,21 @@ namespace Marr.Data
|
||||
{
|
||||
if (disposing)
|
||||
{
|
||||
if (Command.Transaction != null)
|
||||
if (_command != null)
|
||||
{
|
||||
Command.Transaction.Dispose();
|
||||
Command.Transaction = null;
|
||||
}
|
||||
if (_command.Transaction != null)
|
||||
{
|
||||
_command.Transaction.Dispose();
|
||||
_command.Transaction = null;
|
||||
}
|
||||
|
||||
if (Command.Connection != null)
|
||||
{
|
||||
Command.Connection.Dispose();
|
||||
Command.Connection = null;
|
||||
}
|
||||
if (_command.Connection != null)
|
||||
{
|
||||
_command.Connection.Dispose();
|
||||
_command.Connection = null;
|
||||
}
|
||||
|
||||
if (Command != null)
|
||||
{
|
||||
Command.Dispose();
|
||||
_command.Dispose();
|
||||
_command = null;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
using System;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Data.Common;
|
||||
@@ -91,9 +91,11 @@ namespace Marr.Data.Mapping
|
||||
Type entType = ent.GetType();
|
||||
if (_repos.Relationships.ContainsKey(entType))
|
||||
{
|
||||
var provider = _db.ProviderFactory;
|
||||
var connectionString = _db.ConnectionString;
|
||||
Func<IDataMapper> dbCreate = () =>
|
||||
{
|
||||
var db = new DataMapper(_db.ProviderFactory, _db.ConnectionString);
|
||||
var db = new DataMapper(provider, connectionString);
|
||||
db.SqlMode = SqlModes.Text;
|
||||
return db;
|
||||
};
|
||||
|
||||
@@ -22,7 +22,7 @@ namespace Marr.Data.QGen
|
||||
if (this.Any(t => t.EntityType == table.EntityType))
|
||||
{
|
||||
// Already exists -- don't add
|
||||
return;
|
||||
//return; This prevents joining on the same table!
|
||||
}
|
||||
|
||||
// Create an alias (ex: "t0", "t1", "t2", etc...)
|
||||
@@ -37,7 +37,7 @@ namespace Marr.Data.QGen
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Tries to find a table for a given member.
|
||||
/// Tries to find a table for a given member.
|
||||
/// </summary>
|
||||
public Table FindTable(Type declaringType)
|
||||
{
|
||||
|
||||
@@ -7,6 +7,7 @@ using NzbDrone.Common.EnsureThat;
|
||||
using NzbDrone.Common.Extensions;
|
||||
using NzbDrone.Common.Reflection;
|
||||
using NzbDrone.Core.Annotations;
|
||||
using NzbDrone.Core.Download.Clients.Nzbget;
|
||||
using NzbDrone.Core.Qualities;
|
||||
using NzbDrone.Core.Profiles;
|
||||
|
||||
@@ -41,7 +42,7 @@ namespace NzbDrone.Api.ClientSchema
|
||||
};
|
||||
|
||||
var value = propertyInfo.GetValue(model, null);
|
||||
|
||||
|
||||
if (propertyInfo.PropertyType.HasAttribute<FlagsAttribute>())
|
||||
{
|
||||
int intVal = (int)value;
|
||||
@@ -50,7 +51,7 @@ namespace NzbDrone.Api.ClientSchema
|
||||
.Where(f=> (f & intVal) == f)
|
||||
.ToList();
|
||||
}
|
||||
|
||||
|
||||
if (value != null)
|
||||
{
|
||||
field.Value = value;
|
||||
@@ -112,14 +113,14 @@ namespace NzbDrone.Api.ClientSchema
|
||||
{
|
||||
IEnumerable<int> value;
|
||||
|
||||
if (field.Value.GetType() == typeof(JArray))
|
||||
if (field.Value?.GetType() == typeof(JArray))
|
||||
{
|
||||
value = ((JArray)field.Value).Select(s => s.Value<int>());
|
||||
}
|
||||
|
||||
else
|
||||
{
|
||||
value = field.Value.ToString().Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).Select(s => Convert.ToInt32(s));
|
||||
value = field.Value?.ToString().Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).Select(s => Convert.ToInt32(s));
|
||||
}
|
||||
|
||||
propertyInfo.SetValue(target, value, null);
|
||||
@@ -141,7 +142,7 @@ namespace NzbDrone.Api.ClientSchema
|
||||
|
||||
propertyInfo.SetValue(target, value, null);
|
||||
}
|
||||
|
||||
|
||||
else if (propertyInfo.PropertyType.HasAttribute<FlagsAttribute>())
|
||||
{
|
||||
int value = field.Value.ToString().Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).Select(s => Convert.ToInt32(s)).Sum();
|
||||
@@ -181,6 +182,11 @@ namespace NzbDrone.Api.ClientSchema
|
||||
var options = from Enum e in Enum.GetValues(selectOptions)
|
||||
select new SelectOption { Value = Convert.ToInt32(e), Name = e.ToString() };
|
||||
|
||||
if (selectOptions == typeof(NzbgetPriority))
|
||||
{
|
||||
return options.OrderBy(o => o.Value).ToList();
|
||||
}
|
||||
|
||||
return options.OrderBy(o => o.Name).ToList();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
using NzbDrone.Api.REST;
|
||||
using NzbDrone.Api.REST;
|
||||
using NzbDrone.Core.Configuration;
|
||||
|
||||
namespace NzbDrone.Api.Config
|
||||
@@ -11,6 +11,7 @@ namespace NzbDrone.Api.Config
|
||||
|
||||
public bool EnableCompletedDownloadHandling { get; set; }
|
||||
public bool RemoveCompletedDownloads { get; set; }
|
||||
public int CheckForFinishedDownloadInterval { get; set; }
|
||||
|
||||
public bool AutoRedownloadFailed { get; set; }
|
||||
public bool RemoveFailedDownloads { get; set; }
|
||||
@@ -28,6 +29,7 @@ namespace NzbDrone.Api.Config
|
||||
|
||||
EnableCompletedDownloadHandling = model.EnableCompletedDownloadHandling,
|
||||
RemoveCompletedDownloads = model.RemoveCompletedDownloads,
|
||||
CheckForFinishedDownloadInterval = model.CheckForFinishedDownloadInterval,
|
||||
|
||||
AutoRedownloadFailed = model.AutoRedownloadFailed,
|
||||
RemoveFailedDownloads = model.RemoveFailedDownloads
|
||||
|
||||
@@ -1,10 +1,11 @@
|
||||
using System;
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.IO.Compression;
|
||||
using System.Linq;
|
||||
using Nancy;
|
||||
using Nancy.Bootstrapper;
|
||||
using NLog;
|
||||
using NzbDrone.Common.EnvironmentInfo;
|
||||
using NzbDrone.Common.Extensions;
|
||||
|
||||
namespace NzbDrone.Api.Extensions.Pipelines
|
||||
@@ -15,9 +16,14 @@ namespace NzbDrone.Api.Extensions.Pipelines
|
||||
|
||||
public int Order => 0;
|
||||
|
||||
private readonly Action<Action<Stream>, Stream> _writeGZipStream;
|
||||
|
||||
public GzipCompressionPipeline(Logger logger)
|
||||
{
|
||||
_logger = logger;
|
||||
|
||||
// On Mono GZipStream/DeflateStream leaks memory if an exception is thrown, use an intermediate buffer in that case.
|
||||
_writeGZipStream = PlatformInfo.IsMono ? WriteGZipStreamMono : (Action<Action<Stream>, Stream>)WriteGZipStream;
|
||||
}
|
||||
|
||||
public void Register(IPipelines pipelines)
|
||||
@@ -43,14 +49,7 @@ namespace NzbDrone.Api.Extensions.Pipelines
|
||||
var contents = response.Contents;
|
||||
|
||||
response.Headers["Content-Encoding"] = "gzip";
|
||||
response.Contents = responseStream =>
|
||||
{
|
||||
using (var gzip = new GZipStream(responseStream, CompressionMode.Compress, true))
|
||||
using (var buffered = new BufferedStream(gzip, 8192))
|
||||
{
|
||||
contents.Invoke(buffered);
|
||||
}
|
||||
};
|
||||
response.Contents = responseStream => _writeGZipStream(contents, responseStream);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -61,6 +60,25 @@ namespace NzbDrone.Api.Extensions.Pipelines
|
||||
}
|
||||
}
|
||||
|
||||
private static void WriteGZipStreamMono(Action<Stream> innerContent, Stream targetStream)
|
||||
{
|
||||
using (var membuffer = new MemoryStream())
|
||||
{
|
||||
WriteGZipStream(innerContent, membuffer);
|
||||
membuffer.Position = 0;
|
||||
membuffer.CopyTo(targetStream);
|
||||
}
|
||||
}
|
||||
|
||||
private static void WriteGZipStream(Action<Stream> innerContent, Stream targetStream)
|
||||
{
|
||||
using (var gzip = new GZipStream(targetStream, CompressionMode.Compress, true))
|
||||
using (var buffered = new BufferedStream(gzip, 8192))
|
||||
{
|
||||
innerContent.Invoke(buffered);
|
||||
}
|
||||
}
|
||||
|
||||
private static bool ContentLengthIsTooSmall(Response response)
|
||||
{
|
||||
var contentLength = response.Headers.GetValueOrDefault("Content-Length");
|
||||
|
||||
@@ -1,84 +1,84 @@
|
||||
using System;
|
||||
using System.Threading;
|
||||
using Nancy;
|
||||
using Nancy.Bootstrapper;
|
||||
using NLog;
|
||||
using NzbDrone.Api.ErrorManagement;
|
||||
using NzbDrone.Common.Extensions;
|
||||
|
||||
namespace NzbDrone.Api.Extensions.Pipelines
|
||||
{
|
||||
public class RequestLoggingPipeline : IRegisterNancyPipeline
|
||||
{
|
||||
private static readonly Logger _loggerHttp = LogManager.GetLogger("Http");
|
||||
private static readonly Logger _loggerApi = LogManager.GetLogger("Api");
|
||||
|
||||
private static int _requestSequenceID;
|
||||
|
||||
private readonly NzbDroneErrorPipeline _errorPipeline;
|
||||
|
||||
public RequestLoggingPipeline(NzbDroneErrorPipeline errorPipeline)
|
||||
{
|
||||
_errorPipeline = errorPipeline;
|
||||
}
|
||||
|
||||
public int Order => 100;
|
||||
|
||||
public void Register(IPipelines pipelines)
|
||||
{
|
||||
pipelines.BeforeRequest.AddItemToStartOfPipeline(LogStart);
|
||||
pipelines.AfterRequest.AddItemToEndOfPipeline(LogEnd);
|
||||
pipelines.OnError.AddItemToEndOfPipeline(LogError);
|
||||
}
|
||||
|
||||
private Response LogStart(NancyContext context)
|
||||
{
|
||||
var id = Interlocked.Increment(ref _requestSequenceID);
|
||||
|
||||
context.Items["ApiRequestSequenceID"] = id;
|
||||
context.Items["ApiRequestStartTime"] = DateTime.UtcNow;
|
||||
|
||||
var reqPath = GetRequestPathAndQuery(context.Request);
|
||||
|
||||
_loggerHttp.Trace("Req: {0} [{1}] {2}", id, context.Request.Method, reqPath);
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
private void LogEnd(NancyContext context)
|
||||
{
|
||||
var id = (int)context.Items["ApiRequestSequenceID"];
|
||||
var startTime = (DateTime)context.Items["ApiRequestStartTime"];
|
||||
|
||||
var endTime = DateTime.UtcNow;
|
||||
var duration = endTime - startTime;
|
||||
|
||||
var reqPath = GetRequestPathAndQuery(context.Request);
|
||||
|
||||
_loggerHttp.Trace("Res: {0} [{1}] {2}: {3}.{4} ({5} ms)", id, context.Request.Method, reqPath, (int)context.Response.StatusCode, context.Response.StatusCode, (int)duration.TotalMilliseconds);
|
||||
|
||||
if (context.Request.IsApiRequest())
|
||||
{
|
||||
_loggerApi.Debug("[{0}] {1}: {2}.{3} ({4} ms)", context.Request.Method, reqPath, (int)context.Response.StatusCode, context.Response.StatusCode, (int)duration.TotalMilliseconds);
|
||||
}
|
||||
}
|
||||
|
||||
private Response LogError(NancyContext context, Exception exception)
|
||||
{
|
||||
var response = _errorPipeline.HandleException(context, exception);
|
||||
context.Response = response;
|
||||
LogEnd(context);
|
||||
context.Response = null;
|
||||
return response;
|
||||
}
|
||||
|
||||
private static string GetRequestPathAndQuery(Request request)
|
||||
{
|
||||
if (request.Url.Query.IsNotNullOrWhiteSpace())
|
||||
{
|
||||
return string.Concat(request.Url.Path, request.Url.Query);
|
||||
}
|
||||
return request.Url.Path;
|
||||
}
|
||||
}
|
||||
using System;
|
||||
using System.Threading;
|
||||
using Nancy;
|
||||
using Nancy.Bootstrapper;
|
||||
using NLog;
|
||||
using NzbDrone.Api.ErrorManagement;
|
||||
using NzbDrone.Common.Extensions;
|
||||
|
||||
namespace NzbDrone.Api.Extensions.Pipelines
|
||||
{
|
||||
public class RequestLoggingPipeline : IRegisterNancyPipeline
|
||||
{
|
||||
private static readonly Logger _loggerHttp = LogManager.GetLogger("Http");
|
||||
private static readonly Logger _loggerApi = LogManager.GetLogger("Api");
|
||||
|
||||
private static int _requestSequenceID;
|
||||
|
||||
private readonly NzbDroneErrorPipeline _errorPipeline;
|
||||
|
||||
public RequestLoggingPipeline(NzbDroneErrorPipeline errorPipeline)
|
||||
{
|
||||
_errorPipeline = errorPipeline;
|
||||
}
|
||||
|
||||
public int Order => 100;
|
||||
|
||||
public void Register(IPipelines pipelines)
|
||||
{
|
||||
pipelines.BeforeRequest.AddItemToStartOfPipeline(LogStart);
|
||||
pipelines.AfterRequest.AddItemToEndOfPipeline(LogEnd);
|
||||
pipelines.OnError.AddItemToEndOfPipeline(LogError);
|
||||
}
|
||||
|
||||
private Response LogStart(NancyContext context)
|
||||
{
|
||||
var id = Interlocked.Increment(ref _requestSequenceID);
|
||||
|
||||
context.Items["ApiRequestSequenceID"] = id;
|
||||
context.Items["ApiRequestStartTime"] = DateTime.UtcNow;
|
||||
|
||||
var reqPath = GetRequestPathAndQuery(context.Request);
|
||||
|
||||
_loggerHttp.Trace("Req: {0} [{1}] {2}", id, context.Request.Method, reqPath);
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
private void LogEnd(NancyContext context)
|
||||
{
|
||||
var id = (int)context.Items["ApiRequestSequenceID"];
|
||||
var startTime = (DateTime)context.Items["ApiRequestStartTime"];
|
||||
|
||||
var endTime = DateTime.UtcNow;
|
||||
var duration = endTime - startTime;
|
||||
|
||||
var reqPath = GetRequestPathAndQuery(context.Request);
|
||||
|
||||
_loggerHttp.Trace("Res: {0} [{1}] {2}: {3}.{4} ({5} ms)", id, context.Request.Method, reqPath, (int)context.Response.StatusCode, context.Response.StatusCode, (int)duration.TotalMilliseconds);
|
||||
|
||||
if (context.Request.IsApiRequest())
|
||||
{
|
||||
_loggerApi.Debug("[{0}] {1}: {2}.{3} ({4} ms)", context.Request.Method, reqPath, (int)context.Response.StatusCode, context.Response.StatusCode, (int)duration.TotalMilliseconds);
|
||||
}
|
||||
}
|
||||
|
||||
private Response LogError(NancyContext context, Exception exception)
|
||||
{
|
||||
var response = _errorPipeline.HandleException(context, exception);
|
||||
context.Response = response;
|
||||
LogEnd(context);
|
||||
context.Response = null;
|
||||
return response;
|
||||
}
|
||||
|
||||
private static string GetRequestPathAndQuery(Request request)
|
||||
{
|
||||
if (request.Url.Query.IsNotNullOrWhiteSpace())
|
||||
{
|
||||
return string.Concat(request.Url.Path, request.Url.Query);
|
||||
}
|
||||
return request.Url.Path;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -14,7 +14,7 @@ namespace NzbDrone.Api.Frontend
|
||||
{
|
||||
public bool IsCacheable(NancyContext context)
|
||||
{
|
||||
if (!RuntimeInfoBase.IsProduction)
|
||||
if (!RuntimeInfo.IsProduction)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
@@ -46,4 +46,4 @@ namespace NzbDrone.Api.Frontend
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -79,7 +79,7 @@ namespace NzbDrone.Api.Frontend.Mappers
|
||||
|
||||
private string GetIndexText()
|
||||
{
|
||||
if (RuntimeInfoBase.IsProduction && _generatedContent != null)
|
||||
if (RuntimeInfo.IsProduction && _generatedContent != null)
|
||||
{
|
||||
return _generatedContent;
|
||||
}
|
||||
@@ -111,7 +111,7 @@ namespace NzbDrone.Api.Frontend.Mappers
|
||||
text = text.Replace("APP_BRANCH", _configFileProvider.Branch.ToLower());
|
||||
text = text.Replace("APP_ANALYTICS", _analyticsService.IsEnabled.ToString().ToLowerInvariant());
|
||||
text = text.Replace("URL_BASE", URL_BASE);
|
||||
text = text.Replace("PRODUCTION", RuntimeInfoBase.IsProduction.ToString().ToLowerInvariant());
|
||||
text = text.Replace("PRODUCTION", RuntimeInfo.IsProduction.ToString().ToLowerInvariant());
|
||||
|
||||
_generatedContent = text;
|
||||
|
||||
|
||||
@@ -67,7 +67,7 @@ namespace NzbDrone.Api.Frontend.Mappers
|
||||
|
||||
private string GetLoginText()
|
||||
{
|
||||
if (RuntimeInfoBase.IsProduction && _generatedContent != null)
|
||||
if (RuntimeInfo.IsProduction && _generatedContent != null)
|
||||
{
|
||||
return _generatedContent;
|
||||
}
|
||||
|
||||
@@ -21,10 +21,7 @@ namespace NzbDrone.Api.Frontend.Mappers
|
||||
_diskProvider = diskProvider;
|
||||
_logger = logger;
|
||||
|
||||
if (!RuntimeInfoBase.IsProduction)
|
||||
{
|
||||
_caseSensitive = StringComparison.OrdinalIgnoreCase;
|
||||
}
|
||||
_caseSensitive = RuntimeInfo.IsProduction ? DiskProviderBase.PathStringComparison : StringComparison.OrdinalIgnoreCase;
|
||||
}
|
||||
|
||||
public abstract string Map(string resourceUrl);
|
||||
@@ -38,7 +35,7 @@ namespace NzbDrone.Api.Frontend.Mappers
|
||||
if (_diskProvider.FileExists(filePath, _caseSensitive))
|
||||
{
|
||||
var response = new StreamResponse(() => GetContentStream(filePath), MimeTypes.GetMimeType(filePath));
|
||||
return response;
|
||||
return new MaterialisingResponse(response);
|
||||
}
|
||||
|
||||
_logger.Warn("File {0} not found", filePath);
|
||||
|
||||
@@ -95,11 +95,11 @@ namespace NzbDrone.Api.Indexers
|
||||
}
|
||||
catch (NotImplementedException ex)
|
||||
{
|
||||
_logger.Error(ex, "One or more indexer you selected does not support movie search yet: " + ex.Message);
|
||||
_logger.Error(ex, "One or more indexer you selected does not support movie search yet: {0}", ex.Message);
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
_logger.Error(ex, "Movie search failed: " + ex.Message);
|
||||
_logger.Error(ex, "Movie search failed: {0}", ex.Message);
|
||||
}
|
||||
|
||||
return new List<ReleaseResource>();
|
||||
|
||||
@@ -29,7 +29,7 @@ namespace NzbDrone.Api.Indexers
|
||||
public string Title { get; set; }
|
||||
public bool FullSeason { get; set; }
|
||||
public int SeasonNumber { get; set; }
|
||||
public Language Language { get; set; }
|
||||
public List<Language> Languages { get; set; }
|
||||
public int Year { get; set; }
|
||||
public string MovieTitle { get; set; }
|
||||
public int[] EpisodeNumbers { get; set; }
|
||||
@@ -108,7 +108,7 @@ namespace NzbDrone.Api.Indexers
|
||||
ReleaseGroup = parsedMovieInfo.ReleaseGroup,
|
||||
ReleaseHash = parsedMovieInfo.ReleaseHash,
|
||||
Title = releaseInfo.Title,
|
||||
Language = parsedMovieInfo.Language,
|
||||
Languages = parsedMovieInfo.Languages,
|
||||
Year = parsedMovieInfo.Year,
|
||||
MovieTitle = parsedMovieInfo.MovieTitle,
|
||||
Approved = model.Approved,
|
||||
@@ -133,7 +133,7 @@ namespace NzbDrone.Api.Indexers
|
||||
Protocol = releaseInfo.DownloadProtocol,
|
||||
IndexerFlags = torrentInfo.IndexerFlags.ToString().Split(new string[] { ", " }, StringSplitOptions.None),
|
||||
Edition = parsedMovieInfo.Edition,
|
||||
|
||||
|
||||
//Special = parsedMovieInfo.Special,
|
||||
};
|
||||
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using NzbDrone.Core.MediaFiles.MovieImport.Manual;
|
||||
using NzbDrone.Core.Qualities;
|
||||
@@ -36,8 +36,8 @@ namespace NzbDrone.Api.ManualImport
|
||||
item.QualityWeight += item.Quality.Revision.Real * 10;
|
||||
item.QualityWeight += item.Quality.Revision.Version;
|
||||
}
|
||||
|
||||
|
||||
return item;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -47,7 +47,7 @@ namespace NzbDrone.Api.MovieFiles
|
||||
|
||||
|
||||
private void SetQuality(MovieFileResource movieFileResource)
|
||||
{
|
||||
{
|
||||
var movieFile = _mediaFileService.GetMovie(movieFileResource.Id);
|
||||
movieFile.Quality = movieFileResource.Quality;
|
||||
_mediaFileService.Update(movieFile);
|
||||
|
||||
@@ -3,8 +3,6 @@ using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using NzbDrone.Api.REST;
|
||||
using NzbDrone.Api.Movies;
|
||||
using NzbDrone.Core.MediaCover;
|
||||
using NzbDrone.Core.Movies;
|
||||
using NzbDrone.Core.Qualities;
|
||||
using NzbDrone.Core.MediaFiles;
|
||||
|
||||
@@ -14,7 +12,7 @@ namespace NzbDrone.Api.MovieFiles
|
||||
{
|
||||
public MovieFileResource()
|
||||
{
|
||||
|
||||
|
||||
}
|
||||
|
||||
//Todo: Sorters should be done completely on the client
|
||||
@@ -75,7 +73,7 @@ namespace NzbDrone.Api.MovieFiles
|
||||
|
||||
return new MovieFile
|
||||
{
|
||||
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
@@ -14,6 +14,7 @@ using NzbDrone.Core.MediaFiles.MovieImport;
|
||||
using NzbDrone.Core.RootFolders;
|
||||
using NzbDrone.Common.Cache;
|
||||
using NzbDrone.Core.Movies;
|
||||
using NzbDrone.Core.Profiles;
|
||||
|
||||
namespace NzbDrone.Api.Movies
|
||||
{
|
||||
@@ -33,10 +34,14 @@ namespace NzbDrone.Api.Movies
|
||||
private readonly IMakeImportDecision _importDecisionMaker;
|
||||
private readonly IDiskScanService _diskScanService;
|
||||
private readonly ICached<Core.Movies.Movie> _mappedMovies;
|
||||
private readonly IParsingService _parsingService;
|
||||
private readonly IProfileService _profileService;
|
||||
private readonly IMovieService _movieService;
|
||||
|
||||
public MovieBulkImportModule(ISearchForNewMovie searchProxy, IRootFolderService rootFolderService, IMakeImportDecision importDecisionMaker,
|
||||
IDiskScanService diskScanService, ICacheManager cacheManager, IMovieService movieService)
|
||||
public MovieBulkImportModule(ISearchForNewMovie searchProxy, IRootFolderService rootFolderService,
|
||||
IMakeImportDecision importDecisionMaker,
|
||||
IDiskScanService diskScanService, ICacheManager cacheManager,
|
||||
IParsingService parsingService, IProfileService profileService, IMovieService movieService)
|
||||
: base("/movies/bulkimport")
|
||||
{
|
||||
_searchProxy = searchProxy;
|
||||
@@ -45,6 +50,8 @@ namespace NzbDrone.Api.Movies
|
||||
_diskScanService = diskScanService;
|
||||
_mappedMovies = cacheManager.GetCache<Core.Movies.Movie>(GetType(), "mappedMoviesCache");
|
||||
_movieService = movieService;
|
||||
_profileService = profileService;
|
||||
_parsingService = parsingService;
|
||||
Get["/"] = x => Search();
|
||||
}
|
||||
|
||||
@@ -56,6 +63,8 @@ namespace NzbDrone.Api.Movies
|
||||
//Todo error handling
|
||||
}
|
||||
|
||||
Profile tempProfile = _profileService.All().First();
|
||||
|
||||
RootFolder rootFolder = _rootFolderService.Get(Request.Query.Id);
|
||||
|
||||
int page = Request.Query.page;
|
||||
@@ -89,23 +98,27 @@ namespace NzbDrone.Api.Movies
|
||||
return mappedMovie;
|
||||
}
|
||||
|
||||
var parsedTitle = Parser.ParseMoviePath(f.Name, false);
|
||||
var parsedTitle = _parsingService.ParseMinimalPathMovieInfo(f.Name);
|
||||
if (parsedTitle == null)
|
||||
{
|
||||
m = new Core.Movies.Movie
|
||||
{
|
||||
Title = f.Name.Replace(".", " ").Replace("-", " "),
|
||||
Path = f.Path,
|
||||
Profile = tempProfile
|
||||
};
|
||||
}
|
||||
else
|
||||
{
|
||||
parsedTitle.ImdbId = Parser.ParseImdbId(parsedTitle.SimpleReleaseTitle);
|
||||
|
||||
m = new Core.Movies.Movie
|
||||
{
|
||||
Title = parsedTitle.MovieTitle,
|
||||
Year = parsedTitle.Year,
|
||||
ImdbId = parsedTitle.ImdbId,
|
||||
Path = f.Path
|
||||
Path = f.Path,
|
||||
Profile = tempProfile
|
||||
};
|
||||
}
|
||||
|
||||
@@ -119,7 +132,7 @@ namespace NzbDrone.Api.Movies
|
||||
{
|
||||
var local = decision.LocalMovie;
|
||||
|
||||
m.MovieFile = new LazyLoaded<MovieFile>(new MovieFile
|
||||
m.MovieFile = new MovieFile
|
||||
{
|
||||
Path = local.Path,
|
||||
Edition = local.ParsedMovieInfo.Edition,
|
||||
@@ -127,7 +140,7 @@ namespace NzbDrone.Api.Movies
|
||||
MediaInfo = local.MediaInfo,
|
||||
ReleaseGroup = local.ParsedMovieInfo.ReleaseGroup,
|
||||
RelativePath = f.Path.GetRelativePath(local.Path)
|
||||
});
|
||||
};
|
||||
}
|
||||
|
||||
mappedMovie = _searchProxy.MapMovieToTmdbMovie(m);
|
||||
@@ -143,7 +156,7 @@ namespace NzbDrone.Api.Movies
|
||||
|
||||
return null;
|
||||
});
|
||||
|
||||
|
||||
return new PagingResource<MovieResource>
|
||||
{
|
||||
Page = page,
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
using System.Linq;
|
||||
using System.Linq;
|
||||
using Nancy.Bootstrapper;
|
||||
using Nancy.Diagnostics;
|
||||
using NLog;
|
||||
@@ -24,9 +24,9 @@ namespace NzbDrone.Api
|
||||
|
||||
protected override void ApplicationStartup(TinyIoCContainer container, IPipelines pipelines)
|
||||
{
|
||||
Logger.Info("Starting NzbDrone API");
|
||||
Logger.Info("Starting Web Server");
|
||||
|
||||
if (RuntimeInfoBase.IsProduction)
|
||||
if (RuntimeInfo.IsProduction)
|
||||
{
|
||||
DiagnosticsHook.Disable(pipelines);
|
||||
}
|
||||
|
||||
@@ -1,45 +1,45 @@
|
||||
using System.Collections.Generic;
|
||||
using FluentValidation;
|
||||
using NzbDrone.Api.ClientSchema;
|
||||
using NzbDrone.Core.NetImport;
|
||||
using NzbDrone.Core.NetImport.ImportExclusions;
|
||||
using NzbDrone.Core.Validation.Paths;
|
||||
|
||||
namespace NzbDrone.Api.NetImport
|
||||
{
|
||||
public class ImportExclusionsModule : NzbDroneRestModule<ImportExclusionsResource>
|
||||
{
|
||||
private readonly IImportExclusionsService _exclusionService;
|
||||
|
||||
public ImportExclusionsModule(NetImportFactory netImportFactory, IImportExclusionsService exclusionService) : base("exclusions")
|
||||
{
|
||||
_exclusionService = exclusionService;
|
||||
GetResourceAll = GetAll;
|
||||
CreateResource = AddExclusion;
|
||||
DeleteResource = RemoveExclusion;
|
||||
GetResourceById = GetById;
|
||||
}
|
||||
|
||||
public List<ImportExclusionsResource> GetAll()
|
||||
{
|
||||
return _exclusionService.GetAllExclusions().ToResource();
|
||||
}
|
||||
|
||||
public ImportExclusionsResource GetById(int id)
|
||||
{
|
||||
return _exclusionService.GetById(id).ToResource();
|
||||
}
|
||||
|
||||
public int AddExclusion(ImportExclusionsResource exclusionResource)
|
||||
{
|
||||
var model = exclusionResource.ToModel();
|
||||
|
||||
return _exclusionService.AddExclusion(model).Id;
|
||||
}
|
||||
|
||||
public void RemoveExclusion (int id)
|
||||
{
|
||||
_exclusionService.RemoveExclusion(new ImportExclusion { Id = id });
|
||||
}
|
||||
}
|
||||
}
|
||||
using System.Collections.Generic;
|
||||
using FluentValidation;
|
||||
using NzbDrone.Api.ClientSchema;
|
||||
using NzbDrone.Core.NetImport;
|
||||
using NzbDrone.Core.NetImport.ImportExclusions;
|
||||
using NzbDrone.Core.Validation.Paths;
|
||||
|
||||
namespace NzbDrone.Api.NetImport
|
||||
{
|
||||
public class ImportExclusionsModule : NzbDroneRestModule<ImportExclusionsResource>
|
||||
{
|
||||
private readonly IImportExclusionsService _exclusionService;
|
||||
|
||||
public ImportExclusionsModule(NetImportFactory netImportFactory, IImportExclusionsService exclusionService) : base("exclusions")
|
||||
{
|
||||
_exclusionService = exclusionService;
|
||||
GetResourceAll = GetAll;
|
||||
CreateResource = AddExclusion;
|
||||
DeleteResource = RemoveExclusion;
|
||||
GetResourceById = GetById;
|
||||
}
|
||||
|
||||
public List<ImportExclusionsResource> GetAll()
|
||||
{
|
||||
return _exclusionService.GetAllExclusions().ToResource();
|
||||
}
|
||||
|
||||
public ImportExclusionsResource GetById(int id)
|
||||
{
|
||||
return _exclusionService.GetById(id).ToResource();
|
||||
}
|
||||
|
||||
public int AddExclusion(ImportExclusionsResource exclusionResource)
|
||||
{
|
||||
var model = exclusionResource.ToModel();
|
||||
|
||||
return _exclusionService.AddExclusion(model).Id;
|
||||
}
|
||||
|
||||
public void RemoveExclusion (int id)
|
||||
{
|
||||
_exclusionService.RemoveExclusion(new ImportExclusion { Id = id });
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,46 +1,46 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using NzbDrone.Core.NetImport;
|
||||
using NzbDrone.Core.Movies;
|
||||
|
||||
namespace NzbDrone.Api.NetImport
|
||||
{
|
||||
public class ImportExclusionsResource : ProviderResource
|
||||
{
|
||||
//public int Id { get; set; }
|
||||
public int TmdbId { get; set; }
|
||||
public string MovieTitle { get; set; }
|
||||
public int MovieYear { get; set; }
|
||||
}
|
||||
|
||||
public static class ImportExclusionsResourceMapper
|
||||
{
|
||||
public static ImportExclusionsResource ToResource(this Core.NetImport.ImportExclusions.ImportExclusion model)
|
||||
{
|
||||
if (model == null) return null;
|
||||
|
||||
return new ImportExclusionsResource
|
||||
{
|
||||
Id = model.Id,
|
||||
TmdbId = model.TmdbId,
|
||||
MovieTitle = model.MovieTitle,
|
||||
MovieYear = model.MovieYear
|
||||
};
|
||||
}
|
||||
|
||||
public static List<ImportExclusionsResource> ToResource(this IEnumerable<Core.NetImport.ImportExclusions.ImportExclusion> exclusions)
|
||||
{
|
||||
return exclusions.Select(ToResource).ToList();
|
||||
}
|
||||
|
||||
public static Core.NetImport.ImportExclusions.ImportExclusion ToModel(this ImportExclusionsResource resource)
|
||||
{
|
||||
return new Core.NetImport.ImportExclusions.ImportExclusion
|
||||
{
|
||||
TmdbId = resource.TmdbId,
|
||||
MovieTitle = resource.MovieTitle,
|
||||
MovieYear = resource.MovieYear
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using NzbDrone.Core.NetImport;
|
||||
using NzbDrone.Core.Movies;
|
||||
|
||||
namespace NzbDrone.Api.NetImport
|
||||
{
|
||||
public class ImportExclusionsResource : ProviderResource
|
||||
{
|
||||
//public int Id { get; set; }
|
||||
public int TmdbId { get; set; }
|
||||
public string MovieTitle { get; set; }
|
||||
public int MovieYear { get; set; }
|
||||
}
|
||||
|
||||
public static class ImportExclusionsResourceMapper
|
||||
{
|
||||
public static ImportExclusionsResource ToResource(this Core.NetImport.ImportExclusions.ImportExclusion model)
|
||||
{
|
||||
if (model == null) return null;
|
||||
|
||||
return new ImportExclusionsResource
|
||||
{
|
||||
Id = model.Id,
|
||||
TmdbId = model.TmdbId,
|
||||
MovieTitle = model.MovieTitle,
|
||||
MovieYear = model.MovieYear
|
||||
};
|
||||
}
|
||||
|
||||
public static List<ImportExclusionsResource> ToResource(this IEnumerable<Core.NetImport.ImportExclusions.ImportExclusion> exclusions)
|
||||
{
|
||||
return exclusions.Select(ToResource).ToList();
|
||||
}
|
||||
|
||||
public static Core.NetImport.ImportExclusions.ImportExclusion ToModel(this ImportExclusionsResource resource)
|
||||
{
|
||||
return new Core.NetImport.ImportExclusions.ImportExclusion
|
||||
{
|
||||
TmdbId = resource.TmdbId,
|
||||
MovieTitle = resource.MovieTitle,
|
||||
MovieYear = resource.MovieYear
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -24,6 +24,7 @@ namespace NzbDrone.Api.NetImport
|
||||
resource.RootFolderPath = definition.RootFolderPath;
|
||||
resource.ShouldMonitor = definition.ShouldMonitor;
|
||||
resource.MinimumAvailability = definition.MinimumAvailability;
|
||||
resource.Tags = definition.Tags;
|
||||
}
|
||||
|
||||
protected override void MapToModel(NetImportDefinition definition, NetImportResource resource)
|
||||
@@ -36,6 +37,7 @@ namespace NzbDrone.Api.NetImport
|
||||
definition.RootFolderPath = resource.RootFolderPath;
|
||||
definition.ShouldMonitor = resource.ShouldMonitor;
|
||||
definition.MinimumAvailability = resource.MinimumAvailability;
|
||||
definition.Tags = resource.Tags;
|
||||
}
|
||||
|
||||
protected override void Validate(NetImportDefinition definition, bool includeWarnings)
|
||||
|
||||
@@ -1,3 +1,4 @@
|
||||
using System.Collections.Generic;
|
||||
using NzbDrone.Core.Movies;
|
||||
|
||||
namespace NzbDrone.Api.NetImport
|
||||
@@ -10,5 +11,6 @@ namespace NzbDrone.Api.NetImport
|
||||
public string RootFolderPath { get; set; }
|
||||
public int ProfileId { get; set; }
|
||||
public MovieStatusType MinimumAvailability { get; set; }
|
||||
public HashSet<int> Tags { get; set; }
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,305 +1,308 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
|
||||
<PropertyGroup>
|
||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
||||
<Platform Condition=" '$(Platform)' == '' ">x86</Platform>
|
||||
<ProjectGuid>{FD286DF8-2D3A-4394-8AD5-443FADE55FB2}</ProjectGuid>
|
||||
<OutputType>Library</OutputType>
|
||||
<AppDesignerFolder>Properties</AppDesignerFolder>
|
||||
<RootNamespace>NzbDrone.Api</RootNamespace>
|
||||
<AssemblyName>NzbDrone.Api</AssemblyName>
|
||||
<TargetFrameworkVersion>v4.0</TargetFrameworkVersion>
|
||||
<FileAlignment>512</FileAlignment>
|
||||
<SolutionDir Condition="$(SolutionDir) == '' Or $(SolutionDir) == '*Undefined*'">..\</SolutionDir>
|
||||
<RestorePackages>true</RestorePackages>
|
||||
<TargetFrameworkProfile>
|
||||
</TargetFrameworkProfile>
|
||||
<ProductVersion>12.0.0</ProductVersion>
|
||||
<SchemaVersion>2.0</SchemaVersion>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'">
|
||||
<DebugSymbols>true</DebugSymbols>
|
||||
<OutputPath>..\..\_output\</OutputPath>
|
||||
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
||||
<DebugType>full</DebugType>
|
||||
<PlatformTarget>x86</PlatformTarget>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
<Optimize>false</Optimize>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x86'">
|
||||
<OutputPath>..\..\_output\</OutputPath>
|
||||
<DefineConstants>TRACE</DefineConstants>
|
||||
<Optimize>true</Optimize>
|
||||
<DebugType>pdbonly</DebugType>
|
||||
<PlatformTarget>x86</PlatformTarget>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
</PropertyGroup>
|
||||
<ItemGroup>
|
||||
<Reference Include="antlr.runtime, Version=2.7.6.2, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Ical.Net.2.2.25\lib\net40\antlr.runtime.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="FluentValidation, Version=6.2.1.0, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\FluentValidation.6.2.1.0\lib\portable-net40+sl50+wp80+win8+wpa81\FluentValidation.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Ical.Net, Version=2.1.0.30332, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Ical.Net.2.2.25\lib\net40\Ical.Net.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Ical.Net.Collections, Version=2.1.0.30331, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Ical.Net.2.2.25\lib\net40\Ical.Net.Collections.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Nancy, Version=1.4.2.0, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Nancy.1.4.3\lib\net40\Nancy.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Nancy.Authentication.Basic, Version=1.4.1.0, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Nancy.Authentication.Basic.1.4.1\lib\net40\Nancy.Authentication.Basic.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Nancy.Authentication.Forms, Version=1.4.1.0, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Nancy.Authentication.Forms.1.4.1\lib\net40\Nancy.Authentication.Forms.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Newtonsoft.Json, Version=6.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL">
|
||||
<SpecificVersion>False</SpecificVersion>
|
||||
<HintPath>..\packages\Newtonsoft.Json.6.0.6\lib\net40\Newtonsoft.Json.dll</HintPath>
|
||||
</Reference>
|
||||
<Reference Include="NLog, Version=4.0.0.0, Culture=neutral, PublicKeyToken=5120e14c03d0593c, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\NLog.4.5.0-rc06\lib\net40-client\NLog.dll</HintPath>
|
||||
</Reference>
|
||||
<Reference Include="NodaTime, Version=1.3.0.0, Culture=neutral, PublicKeyToken=4226afe0d9b296d1, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Ical.Net.2.2.25\lib\net40\NodaTime.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="System" />
|
||||
<Reference Include="System.Configuration" />
|
||||
<Reference Include="System.Core" />
|
||||
<Reference Include="System.Data" />
|
||||
<Reference Include="Microsoft.CSharp" />
|
||||
<Reference Include="System.Data.SQLite, Version=1.0.84.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139, processorArchitecture=MSIL">
|
||||
<SpecificVersion>False</SpecificVersion>
|
||||
<HintPath>..\Libraries\Sqlite\System.Data.SQLite.dll</HintPath>
|
||||
</Reference>
|
||||
<Reference Include="System.Runtime.Serialization" />
|
||||
<Reference Include="System.ServiceModel" />
|
||||
<Reference Include="System.Transactions" />
|
||||
<Reference Include="System.Xml" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Compile Include="..\NzbDrone.Common\Properties\SharedAssemblyInfo.cs">
|
||||
<Link>Properties\SharedAssemblyInfo.cs</Link>
|
||||
</Compile>
|
||||
<Compile Include="Authentication\AuthenticationService.cs" />
|
||||
<Compile Include="Authentication\EnableAuthInNancy.cs" />
|
||||
<Compile Include="Authentication\AuthenticationModule.cs" />
|
||||
<Compile Include="Authentication\LoginResource.cs" />
|
||||
<Compile Include="Authentication\NzbDroneUser.cs" />
|
||||
<Compile Include="Blacklist\BlacklistModule.cs" />
|
||||
<Compile Include="Blacklist\BlacklistResource.cs" />
|
||||
<Compile Include="Calendar\CalendarFeedModule.cs" />
|
||||
<Compile Include="Calendar\CalendarModule.cs" />
|
||||
<Compile Include="ClientSchema\Field.cs" />
|
||||
<Compile Include="ClientSchema\FieldDefinitionAttribute.cs" />
|
||||
<Compile Include="ClientSchema\SchemaBuilder.cs" />
|
||||
<Compile Include="ClientSchema\SchemaDeserializer.cs" />
|
||||
<Compile Include="ClientSchema\SelectOption.cs" />
|
||||
<Compile Include="Commands\CommandModule.cs" />
|
||||
<Compile Include="Commands\CommandResource.cs" />
|
||||
<Compile Include="Config\NetImportConfigModule.cs" />
|
||||
<Compile Include="Config\NetImportConfigResource.cs" />
|
||||
<Compile Include="Extensions\AccessControlHeaders.cs" />
|
||||
<Compile Include="Extensions\Pipelines\CorsPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\UrlBasePipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\RequestLoggingPipeline.cs" />
|
||||
<Compile Include="ExtraFiles\ExtraFileResource.cs" />
|
||||
<Compile Include="Frontend\Mappers\LoginHtmlMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\RobotsTxtMapper.cs" />
|
||||
<Compile Include="Indexers\ReleaseModuleBase.cs" />
|
||||
<Compile Include="Indexers\ReleasePushModule.cs" />
|
||||
<Compile Include="ExtraFiles\ExtraFileModule.cs" />
|
||||
<Compile Include="Movies\AlternativeTitleModule.cs" />
|
||||
<Compile Include="Movies\AlternativeYearResource.cs" />
|
||||
<Compile Include="Movies\AlternativeYearModule.cs" />
|
||||
<Compile Include="Movies\MovieModuleWithSignalR.cs" />
|
||||
<Compile Include="Movies\MovieBulkImportModule.cs" />
|
||||
<Compile Include="MovieFiles\MovieFileModule.cs" />
|
||||
<Compile Include="Movies\MovieModule.cs" />
|
||||
<Compile Include="Movies\RenameMovieModule.cs" />
|
||||
<Compile Include="Movies\RenameMovieResource.cs" />
|
||||
<Compile Include="Movies\MovieEditorModule.cs" />
|
||||
<Compile Include="NetImport\ListImportModule.cs" />
|
||||
<Compile Include="NetImport\NetImportModule.cs" />
|
||||
<Compile Include="NetImport\NetImportResource.cs" />
|
||||
<Compile Include="Parse\ParseModule.cs" />
|
||||
<Compile Include="Parse\ParseResource.cs" />
|
||||
<Compile Include="ManualImport\ManualImportModule.cs" />
|
||||
<Compile Include="ManualImport\ManualImportResource.cs" />
|
||||
<Compile Include="Profiles\Delay\DelayProfileModule.cs" />
|
||||
<Compile Include="Profiles\Delay\DelayProfileResource.cs" />
|
||||
<Compile Include="Queue\QueueActionModule.cs" />
|
||||
<Compile Include="RemotePathMappings\RemotePathMappingModule.cs" />
|
||||
<Compile Include="RemotePathMappings\RemotePathMappingResource.cs" />
|
||||
<Compile Include="Config\UiConfigModule.cs" />
|
||||
<Compile Include="Config\UiConfigResource.cs" />
|
||||
<Compile Include="Config\DownloadClientConfigModule.cs" />
|
||||
<Compile Include="Config\DownloadClientConfigResource.cs" />
|
||||
<Compile Include="Config\HostConfigModule.cs" />
|
||||
<Compile Include="Config\HostConfigResource.cs" />
|
||||
<Compile Include="Config\IndexerConfigModule.cs" />
|
||||
<Compile Include="Config\IndexerConfigResource.cs" />
|
||||
<Compile Include="Config\MediaManagementConfigModule.cs" />
|
||||
<Compile Include="Config\MediaManagementConfigResource.cs" />
|
||||
<Compile Include="Config\NamingConfigModule.cs" />
|
||||
<Compile Include="Config\NamingConfigResource.cs" />
|
||||
<Compile Include="Config\NamingSampleResource.cs" />
|
||||
<Compile Include="Config\NzbDroneConfigModule.cs" />
|
||||
<Compile Include="FileSystem\FileSystemModule.cs" />
|
||||
<Compile Include="DiskSpace\DiskSpaceModule.cs" />
|
||||
<Compile Include="DiskSpace\DiskSpaceResource.cs" />
|
||||
<Compile Include="DownloadClient\DownloadClientModule.cs" />
|
||||
<Compile Include="DownloadClient\DownloadClientResource.cs" />
|
||||
<Compile Include="ErrorManagement\ApiException.cs" />
|
||||
<Compile Include="ErrorManagement\ErrorHandler.cs" />
|
||||
<Compile Include="ErrorManagement\ErrorModel.cs" />
|
||||
<Compile Include="ErrorManagement\NzbDroneErrorPipeline.cs" />
|
||||
<Compile Include="Exceptions\InvalidApiKeyException.cs" />
|
||||
<Compile Include="Extensions\NancyJsonSerializer.cs" />
|
||||
<Compile Include="Extensions\Pipelines\CacheHeaderPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\GZipPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\IfModifiedPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\IRegisterNancyPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\NzbDroneVersionPipeline.cs" />
|
||||
<Compile Include="Extensions\ReqResExtensions.cs" />
|
||||
<Compile Include="Extensions\RequestExtensions.cs" />
|
||||
<Compile Include="Frontend\CacheableSpecification.cs" />
|
||||
<Compile Include="Frontend\Mappers\BackupFileMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\CacheBreakerProvider.cs" />
|
||||
<Compile Include="Frontend\Mappers\FaviconMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\IMapHttpRequestsToDisk.cs" />
|
||||
<Compile Include="Frontend\Mappers\IndexHtmlMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\LogFileMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\MediaCoverMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\StaticResourceMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\StaticResourceMapperBase.cs" />
|
||||
<Compile Include="Frontend\Mappers\UpdateLogFileMapper.cs" />
|
||||
<Compile Include="Frontend\StaticResourceModule.cs" />
|
||||
<Compile Include="Health\HealthModule.cs" />
|
||||
<Compile Include="Health\HealthResource.cs" />
|
||||
<Compile Include="History\HistoryModule.cs" />
|
||||
<Compile Include="History\HistoryResource.cs" />
|
||||
<Compile Include="Indexers\IndexerModule.cs" />
|
||||
<Compile Include="Indexers\IndexerResource.cs" />
|
||||
<Compile Include="Indexers\ReleaseModule.cs" />
|
||||
<Compile Include="Indexers\ReleaseResource.cs" />
|
||||
<Compile Include="Logs\LogFileModule.cs" />
|
||||
<Compile Include="Logs\LogFileModuleBase.cs" />
|
||||
<Compile Include="Logs\LogFileResource.cs" />
|
||||
<Compile Include="Logs\LogModule.cs" />
|
||||
<Compile Include="Logs\LogResource.cs" />
|
||||
<Compile Include="Logs\UpdateLogFileModule.cs" />
|
||||
<Compile Include="MediaCovers\MediaCoverModule.cs" />
|
||||
<Compile Include="Metadata\MetadataModule.cs" />
|
||||
<Compile Include="Metadata\MetadataResource.cs" />
|
||||
<Compile Include="NancyBootstrapper.cs" />
|
||||
<Compile Include="Notifications\NotificationModule.cs" />
|
||||
<Compile Include="Notifications\NotificationResource.cs" />
|
||||
<Compile Include="NzbDroneApiModule.cs" />
|
||||
<Compile Include="NzbDroneFeedModule.cs" />
|
||||
<Compile Include="NzbDroneRestModule.cs" />
|
||||
<Compile Include="NzbDroneRestModuleWithSignalR.cs" />
|
||||
<Compile Include="PagingResource.cs" />
|
||||
<Compile Include="Profiles\Languages\LanguageModule.cs" />
|
||||
<Compile Include="Profiles\Languages\LanguageResource.cs" />
|
||||
<Compile Include="Profiles\LegacyProfileModule.cs" />
|
||||
<Compile Include="Profiles\ProfileModule.cs" />
|
||||
<Compile Include="Profiles\ProfileResource.cs" />
|
||||
<Compile Include="Profiles\ProfileSchemaModule.cs" />
|
||||
<Compile Include="Profiles\ProfileValidation.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
<Compile Include="ProviderModuleBase.cs" />
|
||||
<Compile Include="ProviderResource.cs" />
|
||||
<Compile Include="Qualities\QualityDefinitionModule.cs" />
|
||||
<Compile Include="Qualities\QualityDefinitionResource.cs" />
|
||||
<Compile Include="Queue\QueueModule.cs" />
|
||||
<Compile Include="Queue\QueueResource.cs" />
|
||||
<Compile Include="ResourceChangeMessage.cs" />
|
||||
<Compile Include="Restrictions\RestrictionModule.cs" />
|
||||
<Compile Include="Restrictions\RestrictionResource.cs" />
|
||||
<Compile Include="REST\NotFoundException.cs" />
|
||||
<Compile Include="REST\BadRequestException.cs" />
|
||||
<Compile Include="REST\MethodNotAllowedException.cs" />
|
||||
<Compile Include="REST\ResourceValidator.cs" />
|
||||
<Compile Include="REST\RestModule.cs" />
|
||||
<Compile Include="REST\RestResource.cs" />
|
||||
<Compile Include="RootFolders\RootFolderModule.cs" />
|
||||
<Compile Include="RootFolders\RootFolderResource.cs" />
|
||||
<Compile Include="Movies\AlternativeTitleResource.cs" />
|
||||
<Compile Include="MovieFiles\MovieFileResource.cs" />
|
||||
<Compile Include="Movies\FetchMovieListModule.cs" />
|
||||
<Compile Include="Movies\MovieLookupModule.cs" />
|
||||
<Compile Include="Series\SeriesModule.cs" />
|
||||
<Compile Include="Movies\MovieResource.cs" />
|
||||
<Compile Include="Series\SeriesResource.cs" />
|
||||
<Compile Include="System\Backup\BackupModule.cs" />
|
||||
<Compile Include="System\Backup\BackupResource.cs" />
|
||||
<Compile Include="System\Tasks\TaskModule.cs" />
|
||||
<Compile Include="System\Tasks\TaskResource.cs" />
|
||||
<Compile Include="System\SystemModule.cs" />
|
||||
<Compile Include="Tags\TagModule.cs" />
|
||||
<Compile Include="Tags\TagResource.cs" />
|
||||
<Compile Include="TinyIoCNancyBootstrapper.cs" />
|
||||
<Compile Include="Update\UpdateModule.cs" />
|
||||
<Compile Include="Update\UpdateResource.cs" />
|
||||
<Compile Include="Validation\NetImportSyncIntervalValidator.cs" />
|
||||
<Compile Include="Validation\RssSyncIntervalValidator.cs" />
|
||||
<Compile Include="Validation\EmptyCollectionValidator.cs" />
|
||||
<Compile Include="Validation\RuleBuilderExtensions.cs" />
|
||||
<Compile Include="Wanted\LegacyMissingModule.cs" />
|
||||
<Compile Include="Wanted\MovieCutoffModule.cs" />
|
||||
<Compile Include="Wanted\MovieMissingModule.cs" />
|
||||
<Compile Include="Movies\MovieDiscoverModule.cs" />
|
||||
<Compile Include="NetImport\ImportExclusionsModule.cs" />
|
||||
<Compile Include="NetImport\ImportExclusionsResource.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<None Include="app.config" />
|
||||
<None Include="packages.config">
|
||||
<SubType>Designer</SubType>
|
||||
</None>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\Marr.Data\Marr.Data.csproj">
|
||||
<Project>{F6FC6BE7-0847-4817-A1ED-223DC647C3D7}</Project>
|
||||
<Name>Marr.Data</Name>
|
||||
</ProjectReference>
|
||||
<ProjectReference Include="..\NzbDrone.Common\NzbDrone.Common.csproj">
|
||||
<Project>{F2BE0FDF-6E47-4827-A420-DD4EF82407F8}</Project>
|
||||
<Name>NzbDrone.Common</Name>
|
||||
</ProjectReference>
|
||||
<ProjectReference Include="..\NzbDrone.Core\NzbDrone.Core.csproj">
|
||||
<Project>{FF5EE3B6-913B-47CE-9CEB-11C51B4E1205}</Project>
|
||||
<Name>NzbDrone.Core</Name>
|
||||
</ProjectReference>
|
||||
<ProjectReference Include="..\NzbDrone.SignalR\NzbDrone.SignalR.csproj">
|
||||
<Project>{7C2CC69F-5CA0-4E5C-85CB-983F9F6C3B36}</Project>
|
||||
<Name>NzbDrone.SignalR</Name>
|
||||
</ProjectReference>
|
||||
</ItemGroup>
|
||||
<ItemGroup />
|
||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
|
||||
<PropertyGroup>
|
||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
||||
<Platform Condition=" '$(Platform)' == '' ">x86</Platform>
|
||||
<ProjectGuid>{FD286DF8-2D3A-4394-8AD5-443FADE55FB2}</ProjectGuid>
|
||||
<OutputType>Library</OutputType>
|
||||
<AppDesignerFolder>Properties</AppDesignerFolder>
|
||||
<RootNamespace>NzbDrone.Api</RootNamespace>
|
||||
<AssemblyName>NzbDrone.Api</AssemblyName>
|
||||
<TargetFrameworkVersion>v4.0</TargetFrameworkVersion>
|
||||
<FileAlignment>512</FileAlignment>
|
||||
<SolutionDir Condition="$(SolutionDir) == '' Or $(SolutionDir) == '*Undefined*'">..\</SolutionDir>
|
||||
<RestorePackages>true</RestorePackages>
|
||||
<TargetFrameworkProfile>
|
||||
</TargetFrameworkProfile>
|
||||
<ProductVersion>12.0.0</ProductVersion>
|
||||
<SchemaVersion>2.0</SchemaVersion>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'">
|
||||
<DebugSymbols>true</DebugSymbols>
|
||||
<OutputPath>..\..\_output\</OutputPath>
|
||||
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
||||
<DebugType>full</DebugType>
|
||||
<PlatformTarget>x86</PlatformTarget>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
<Optimize>false</Optimize>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x86'">
|
||||
<OutputPath>..\..\_output\</OutputPath>
|
||||
<DefineConstants>TRACE</DefineConstants>
|
||||
<Optimize>true</Optimize>
|
||||
<DebugType>pdbonly</DebugType>
|
||||
<PlatformTarget>x86</PlatformTarget>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
</PropertyGroup>
|
||||
<ItemGroup>
|
||||
<Reference Include="antlr.runtime, Version=2.7.6.2, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Ical.Net.2.2.25\lib\net40\antlr.runtime.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="FluentValidation, Version=6.2.1.0, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\FluentValidation.6.2.1.0\lib\portable-net40+sl50+wp80+win8+wpa81\FluentValidation.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Ical.Net, Version=2.1.0.30332, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Ical.Net.2.2.25\lib\net40\Ical.Net.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Ical.Net.Collections, Version=2.1.0.30331, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Ical.Net.2.2.25\lib\net40\Ical.Net.Collections.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Nancy, Version=1.4.2.0, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Nancy.1.4.3\lib\net40\Nancy.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Nancy.Authentication.Basic, Version=1.4.1.0, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Nancy.Authentication.Basic.1.4.1\lib\net40\Nancy.Authentication.Basic.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Nancy.Authentication.Forms, Version=1.4.1.0, Culture=neutral, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Nancy.Authentication.Forms.1.4.1\lib\net40\Nancy.Authentication.Forms.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="Newtonsoft.Json, Version=9.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Newtonsoft.Json.9.0.1\lib\net40\Newtonsoft.Json.dll</HintPath>
|
||||
</Reference>
|
||||
<Reference Include="NLog, Version=4.0.0.0, Culture=neutral, PublicKeyToken=5120e14c03d0593c, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\NLog.4.5.0-rc06\lib\net40-client\NLog.dll</HintPath>
|
||||
</Reference>
|
||||
<Reference Include="NodaTime, Version=1.3.0.0, Culture=neutral, PublicKeyToken=4226afe0d9b296d1, processorArchitecture=MSIL">
|
||||
<HintPath>..\packages\Ical.Net.2.2.25\lib\net40\NodaTime.dll</HintPath>
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
<Reference Include="System" />
|
||||
<Reference Include="System.Configuration" />
|
||||
<Reference Include="System.Core" />
|
||||
<Reference Include="System.Data" />
|
||||
<Reference Include="Microsoft.CSharp" />
|
||||
<Reference Include="System.Data.SQLite, Version=1.0.84.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139, processorArchitecture=MSIL">
|
||||
<SpecificVersion>False</SpecificVersion>
|
||||
<HintPath>..\Libraries\Sqlite\System.Data.SQLite.dll</HintPath>
|
||||
</Reference>
|
||||
<Reference Include="System.Runtime.Serialization" />
|
||||
<Reference Include="System.ServiceModel" />
|
||||
<Reference Include="System.Transactions" />
|
||||
<Reference Include="System.Xml" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Compile Include="..\NzbDrone.Common\Properties\SharedAssemblyInfo.cs">
|
||||
<Link>Properties\SharedAssemblyInfo.cs</Link>
|
||||
</Compile>
|
||||
<Compile Include="Authentication\AuthenticationService.cs" />
|
||||
<Compile Include="Authentication\EnableAuthInNancy.cs" />
|
||||
<Compile Include="Authentication\AuthenticationModule.cs" />
|
||||
<Compile Include="Authentication\LoginResource.cs" />
|
||||
<Compile Include="Authentication\NzbDroneUser.cs" />
|
||||
<Compile Include="Blacklist\BlacklistModule.cs" />
|
||||
<Compile Include="Blacklist\BlacklistResource.cs" />
|
||||
<Compile Include="Calendar\CalendarFeedModule.cs" />
|
||||
<Compile Include="Calendar\CalendarModule.cs" />
|
||||
<Compile Include="ClientSchema\Field.cs" />
|
||||
<Compile Include="ClientSchema\FieldDefinitionAttribute.cs" />
|
||||
<Compile Include="ClientSchema\SchemaBuilder.cs" />
|
||||
<Compile Include="ClientSchema\SchemaDeserializer.cs" />
|
||||
<Compile Include="ClientSchema\SelectOption.cs" />
|
||||
<Compile Include="Commands\CommandModule.cs" />
|
||||
<Compile Include="Commands\CommandResource.cs" />
|
||||
<Compile Include="Config\NetImportConfigModule.cs" />
|
||||
<Compile Include="Config\NetImportConfigResource.cs" />
|
||||
<Compile Include="Extensions\AccessControlHeaders.cs" />
|
||||
<Compile Include="Extensions\Pipelines\CorsPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\UrlBasePipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\RequestLoggingPipeline.cs" />
|
||||
<Compile Include="ExtraFiles\ExtraFileResource.cs" />
|
||||
<Compile Include="Frontend\Mappers\LoginHtmlMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\RobotsTxtMapper.cs" />
|
||||
<Compile Include="Indexers\ReleaseModuleBase.cs" />
|
||||
<Compile Include="Indexers\ReleasePushModule.cs" />
|
||||
<Compile Include="ExtraFiles\ExtraFileModule.cs" />
|
||||
<Compile Include="Movies\AlternativeTitleModule.cs" />
|
||||
<Compile Include="Movies\AlternativeYearResource.cs" />
|
||||
<Compile Include="Movies\AlternativeYearModule.cs" />
|
||||
<Compile Include="Movies\MovieModuleWithSignalR.cs" />
|
||||
<Compile Include="Movies\MovieBulkImportModule.cs" />
|
||||
<Compile Include="MovieFiles\MovieFileModule.cs" />
|
||||
<Compile Include="Movies\MovieModule.cs" />
|
||||
<Compile Include="Movies\RenameMovieModule.cs" />
|
||||
<Compile Include="Movies\RenameMovieResource.cs" />
|
||||
<Compile Include="Movies\MovieEditorModule.cs" />
|
||||
<Compile Include="NetImport\ListImportModule.cs" />
|
||||
<Compile Include="NetImport\NetImportModule.cs" />
|
||||
<Compile Include="NetImport\NetImportResource.cs" />
|
||||
<Compile Include="Parse\ParseModule.cs" />
|
||||
<Compile Include="Parse\ParseResource.cs" />
|
||||
<Compile Include="ManualImport\ManualImportModule.cs" />
|
||||
<Compile Include="ManualImport\ManualImportResource.cs" />
|
||||
<Compile Include="Profiles\Delay\DelayProfileModule.cs" />
|
||||
<Compile Include="Profiles\Delay\DelayProfileResource.cs" />
|
||||
<Compile Include="Qualities\CustomFormatModule.cs" />
|
||||
<Compile Include="Qualities\CustomFormatResource.cs" />
|
||||
<Compile Include="Qualities\FormatTagMatchResultResource.cs" />
|
||||
<Compile Include="Qualities\FormatTagValidator.cs" />
|
||||
<Compile Include="Queue\QueueActionModule.cs" />
|
||||
<Compile Include="RemotePathMappings\RemotePathMappingModule.cs" />
|
||||
<Compile Include="RemotePathMappings\RemotePathMappingResource.cs" />
|
||||
<Compile Include="Config\UiConfigModule.cs" />
|
||||
<Compile Include="Config\UiConfigResource.cs" />
|
||||
<Compile Include="Config\DownloadClientConfigModule.cs" />
|
||||
<Compile Include="Config\DownloadClientConfigResource.cs" />
|
||||
<Compile Include="Config\HostConfigModule.cs" />
|
||||
<Compile Include="Config\HostConfigResource.cs" />
|
||||
<Compile Include="Config\IndexerConfigModule.cs" />
|
||||
<Compile Include="Config\IndexerConfigResource.cs" />
|
||||
<Compile Include="Config\MediaManagementConfigModule.cs" />
|
||||
<Compile Include="Config\MediaManagementConfigResource.cs" />
|
||||
<Compile Include="Config\NamingConfigModule.cs" />
|
||||
<Compile Include="Config\NamingConfigResource.cs" />
|
||||
<Compile Include="Config\NamingSampleResource.cs" />
|
||||
<Compile Include="Config\NzbDroneConfigModule.cs" />
|
||||
<Compile Include="FileSystem\FileSystemModule.cs" />
|
||||
<Compile Include="DiskSpace\DiskSpaceModule.cs" />
|
||||
<Compile Include="DiskSpace\DiskSpaceResource.cs" />
|
||||
<Compile Include="DownloadClient\DownloadClientModule.cs" />
|
||||
<Compile Include="DownloadClient\DownloadClientResource.cs" />
|
||||
<Compile Include="ErrorManagement\ApiException.cs" />
|
||||
<Compile Include="ErrorManagement\ErrorHandler.cs" />
|
||||
<Compile Include="ErrorManagement\ErrorModel.cs" />
|
||||
<Compile Include="ErrorManagement\NzbDroneErrorPipeline.cs" />
|
||||
<Compile Include="Exceptions\InvalidApiKeyException.cs" />
|
||||
<Compile Include="Extensions\NancyJsonSerializer.cs" />
|
||||
<Compile Include="Extensions\Pipelines\CacheHeaderPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\GZipPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\IfModifiedPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\IRegisterNancyPipeline.cs" />
|
||||
<Compile Include="Extensions\Pipelines\NzbDroneVersionPipeline.cs" />
|
||||
<Compile Include="Extensions\ReqResExtensions.cs" />
|
||||
<Compile Include="Extensions\RequestExtensions.cs" />
|
||||
<Compile Include="Frontend\CacheableSpecification.cs" />
|
||||
<Compile Include="Frontend\Mappers\BackupFileMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\CacheBreakerProvider.cs" />
|
||||
<Compile Include="Frontend\Mappers\FaviconMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\IMapHttpRequestsToDisk.cs" />
|
||||
<Compile Include="Frontend\Mappers\IndexHtmlMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\LogFileMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\MediaCoverMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\StaticResourceMapper.cs" />
|
||||
<Compile Include="Frontend\Mappers\StaticResourceMapperBase.cs" />
|
||||
<Compile Include="Frontend\Mappers\UpdateLogFileMapper.cs" />
|
||||
<Compile Include="Frontend\StaticResourceModule.cs" />
|
||||
<Compile Include="Health\HealthModule.cs" />
|
||||
<Compile Include="Health\HealthResource.cs" />
|
||||
<Compile Include="History\HistoryModule.cs" />
|
||||
<Compile Include="History\HistoryResource.cs" />
|
||||
<Compile Include="Indexers\IndexerModule.cs" />
|
||||
<Compile Include="Indexers\IndexerResource.cs" />
|
||||
<Compile Include="Indexers\ReleaseModule.cs" />
|
||||
<Compile Include="Indexers\ReleaseResource.cs" />
|
||||
<Compile Include="Logs\LogFileModule.cs" />
|
||||
<Compile Include="Logs\LogFileModuleBase.cs" />
|
||||
<Compile Include="Logs\LogFileResource.cs" />
|
||||
<Compile Include="Logs\LogModule.cs" />
|
||||
<Compile Include="Logs\LogResource.cs" />
|
||||
<Compile Include="Logs\UpdateLogFileModule.cs" />
|
||||
<Compile Include="MediaCovers\MediaCoverModule.cs" />
|
||||
<Compile Include="Metadata\MetadataModule.cs" />
|
||||
<Compile Include="Metadata\MetadataResource.cs" />
|
||||
<Compile Include="NancyBootstrapper.cs" />
|
||||
<Compile Include="Notifications\NotificationModule.cs" />
|
||||
<Compile Include="Notifications\NotificationResource.cs" />
|
||||
<Compile Include="NzbDroneApiModule.cs" />
|
||||
<Compile Include="NzbDroneFeedModule.cs" />
|
||||
<Compile Include="NzbDroneRestModule.cs" />
|
||||
<Compile Include="NzbDroneRestModuleWithSignalR.cs" />
|
||||
<Compile Include="PagingResource.cs" />
|
||||
<Compile Include="Profiles\Languages\LanguageModule.cs" />
|
||||
<Compile Include="Profiles\Languages\LanguageResource.cs" />
|
||||
<Compile Include="Profiles\LegacyProfileModule.cs" />
|
||||
<Compile Include="Profiles\ProfileModule.cs" />
|
||||
<Compile Include="Profiles\ProfileResource.cs" />
|
||||
<Compile Include="Profiles\ProfileSchemaModule.cs" />
|
||||
<Compile Include="Profiles\ProfileValidation.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
<Compile Include="ProviderModuleBase.cs" />
|
||||
<Compile Include="ProviderResource.cs" />
|
||||
<Compile Include="Qualities\QualityDefinitionModule.cs" />
|
||||
<Compile Include="Qualities\QualityDefinitionResource.cs" />
|
||||
<Compile Include="Queue\QueueModule.cs" />
|
||||
<Compile Include="Queue\QueueResource.cs" />
|
||||
<Compile Include="ResourceChangeMessage.cs" />
|
||||
<Compile Include="Restrictions\RestrictionModule.cs" />
|
||||
<Compile Include="Restrictions\RestrictionResource.cs" />
|
||||
<Compile Include="REST\NotFoundException.cs" />
|
||||
<Compile Include="REST\BadRequestException.cs" />
|
||||
<Compile Include="REST\MethodNotAllowedException.cs" />
|
||||
<Compile Include="REST\ResourceValidator.cs" />
|
||||
<Compile Include="REST\RestModule.cs" />
|
||||
<Compile Include="REST\RestResource.cs" />
|
||||
<Compile Include="RootFolders\RootFolderModule.cs" />
|
||||
<Compile Include="RootFolders\RootFolderResource.cs" />
|
||||
<Compile Include="Movies\AlternativeTitleResource.cs" />
|
||||
<Compile Include="MovieFiles\MovieFileResource.cs" />
|
||||
<Compile Include="Movies\FetchMovieListModule.cs" />
|
||||
<Compile Include="Movies\MovieLookupModule.cs" />
|
||||
<Compile Include="Series\SeriesModule.cs" />
|
||||
<Compile Include="Movies\MovieResource.cs" />
|
||||
<Compile Include="Series\SeriesResource.cs" />
|
||||
<Compile Include="System\Backup\BackupModule.cs" />
|
||||
<Compile Include="System\Backup\BackupResource.cs" />
|
||||
<Compile Include="System\Tasks\TaskModule.cs" />
|
||||
<Compile Include="System\Tasks\TaskResource.cs" />
|
||||
<Compile Include="System\SystemModule.cs" />
|
||||
<Compile Include="Tags\TagModule.cs" />
|
||||
<Compile Include="Tags\TagResource.cs" />
|
||||
<Compile Include="TinyIoCNancyBootstrapper.cs" />
|
||||
<Compile Include="Update\UpdateModule.cs" />
|
||||
<Compile Include="Update\UpdateResource.cs" />
|
||||
<Compile Include="Validation\NetImportSyncIntervalValidator.cs" />
|
||||
<Compile Include="Validation\RssSyncIntervalValidator.cs" />
|
||||
<Compile Include="Validation\EmptyCollectionValidator.cs" />
|
||||
<Compile Include="Validation\RuleBuilderExtensions.cs" />
|
||||
<Compile Include="Wanted\LegacyMissingModule.cs" />
|
||||
<Compile Include="Wanted\MovieCutoffModule.cs" />
|
||||
<Compile Include="Wanted\MovieMissingModule.cs" />
|
||||
<Compile Include="Movies\MovieDiscoverModule.cs" />
|
||||
<Compile Include="NetImport\ImportExclusionsModule.cs" />
|
||||
<Compile Include="NetImport\ImportExclusionsResource.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<None Include="app.config" />
|
||||
<None Include="packages.config">
|
||||
<SubType>Designer</SubType>
|
||||
</None>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\Marr.Data\Marr.Data.csproj">
|
||||
<Project>{F6FC6BE7-0847-4817-A1ED-223DC647C3D7}</Project>
|
||||
<Name>Marr.Data</Name>
|
||||
</ProjectReference>
|
||||
<ProjectReference Include="..\NzbDrone.Common\NzbDrone.Common.csproj">
|
||||
<Project>{F2BE0FDF-6E47-4827-A420-DD4EF82407F8}</Project>
|
||||
<Name>NzbDrone.Common</Name>
|
||||
</ProjectReference>
|
||||
<ProjectReference Include="..\NzbDrone.Core\NzbDrone.Core.csproj">
|
||||
<Project>{FF5EE3B6-913B-47CE-9CEB-11C51B4E1205}</Project>
|
||||
<Name>NzbDrone.Core</Name>
|
||||
</ProjectReference>
|
||||
<ProjectReference Include="..\NzbDrone.SignalR\NzbDrone.SignalR.csproj">
|
||||
<Project>{7C2CC69F-5CA0-4E5C-85CB-983F9F6C3B36}</Project>
|
||||
<Name>NzbDrone.SignalR</Name>
|
||||
</ProjectReference>
|
||||
</ItemGroup>
|
||||
<ItemGroup />
|
||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
||||
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.
|
||||
Other similar extension points exist, see Microsoft.Common.targets.
|
||||
<Target Name="BeforeBuild">
|
||||
</Target>
|
||||
<Target Name="AfterBuild">
|
||||
</Target>
|
||||
-->
|
||||
-->
|
||||
</Project>
|
||||