29 libtiff-ver = "4.0.3"; # The version in thirdparty/tiff-*
30 opentoonz-ver = "1.7.1";
32 src = fetchFromGitHub {
35 rev = "v${opentoonz-ver}";
36 hash = "sha256-5iXOvh4QTv+G0fjEHU62u7QCee+jbvKhK0+fQXbdJis=";
39 opentoonz-opencv = opencv.override {
43 opentoonz-libtiff = stdenv.mkDerivation {
45 version = "${libtiff-ver}-opentoonz";
48 outputs = [ "bin" "dev" "out" "man" "doc" ];
50 nativeBuildInputs = [ pkg-config ];
51 propagatedBuildInputs = [ zlib libjpeg xz ];
54 sourceRoot="$sourceRoot/thirdparty/tiff-${libtiff-ver}"
57 # opentoonz uses internal libtiff headers
59 cp libtiff/{tif_config,tif_dir,tiffiop}.h $dev/include
62 meta = libtiff.meta // {
63 knownVulnerabilities = [
65 Do not open untrusted files with Opentoonz:
66 Opentoonz uses an old custom fork of tibtiff from 2012 that is known to
67 be affected by at least these 50 vulnerabilities:
68 CVE-2012-4564 CVE-2013-4232 CVE-2013-4243 CVE-2013-4244 CVE-2014-8127
69 CVE-2014-8128 CVE-2014-8129 CVE-2014-8130 CVE-2014-9330 CVE-2015-1547
70 CVE-2015-8781 CVE-2015-8782 CVE-2015-8783 CVE-2015-8784 CVE-2015-8870
71 CVE-2016-3620 CVE-2016-3621 CVE-2016-3623 CVE-2016-3624 CVE-2016-3625
72 CVE-2016-3631 CVE-2016-3632 CVE-2016-3633 CVE-2016-3634 CVE-2016-3658
73 CVE-2016-3945 CVE-2016-3990 CVE-2016-3991 CVE-2016-5102 CVE-2016-5314
74 CVE-2016-5315 CVE-2016-5316 CVE-2016-5318 CVE-2016-5319 CVE-2016-5321
75 CVE-2016-5322 CVE-2016-5323 CVE-2016-6223 CVE-2016-9453 CVE-2016-9532
76 CVE-2017-9935 CVE-2017-9937 CVE-2018-10963 CVE-2018-5360
77 CVE-2019-14973 CVE-2019-17546 CVE-2020-35521 CVE-2020-35522
78 CVE-2020-35523 CVE-2020-35524
79 More info at https://github.com/opentoonz/opentoonz/issues/4193
82 maintainers = with lib.maintainers; [ chkno ];
90 version = opentoonz-ver;
92 nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ];
116 postUnpack = "sourceRoot=$sourceRoot/toonz";
118 cmakeDir = "../sources";
120 "-DCMAKE_SKIP_BUILD_RPATH=ON"
121 "-DTIFF_INCLUDE_DIR=${opentoonz-libtiff.dev}/include"
122 "-DTIFF_LIBRARY=${opentoonz-libtiff.out}/lib/libtiff.so"
123 (lib.cmakeBool "CMAKE_SKIP_BUILD_RPATH" true)
127 sed -i '/cp -r .*stuff/a\ chmod -R u+w $HOME/.config/OpenToonz/stuff' $out/bin/opentoonz
131 description = "Full-featured 2D animation creation software";
132 homepage = "https://opentoonz.github.io/";
133 license = lib.licenses.bsd3;
134 maintainers = with lib.maintainers; [ chkno ];