diff --git a/src/de/movie2k/AndroidManifest.xml b/src/de/movie2k/AndroidManifest.xml
new file mode 100644
index 000000000..568741e54
--- /dev/null
+++ b/src/de/movie2k/AndroidManifest.xml
@@ -0,0 +1,2 @@
+
+
\ No newline at end of file
diff --git a/src/de/movie2k/build.gradle b/src/de/movie2k/build.gradle
new file mode 100644
index 000000000..9c697190d
--- /dev/null
+++ b/src/de/movie2k/build.gradle
@@ -0,0 +1,21 @@
+apply plugin: 'com.android.application'
+apply plugin: 'kotlin-android'
+apply plugin: 'kotlinx-serialization'
+
+ext {
+ extName = 'Movie2k'
+ pkgNameSuffix = 'de.movie2k'
+ extClass = '.Movie2k'
+ extVersionCode = 1
+ libVersion = '13'
+}
+
+dependencies {
+ implementation(project(':lib-dood-extractor'))
+ implementation(project(':lib-streamtape-extractor'))
+ implementation(project(':lib-mixdrop-extractor'))
+ implementation "dev.datlag.jsunpacker:jsunpacker:1.0.1"
+}
+
+
+apply from: "$rootDir/common.gradle"
diff --git a/src/de/movie2k/res/mipmap-hdpi/ic_launcher.png b/src/de/movie2k/res/mipmap-hdpi/ic_launcher.png
new file mode 100644
index 000000000..27449d101
Binary files /dev/null and b/src/de/movie2k/res/mipmap-hdpi/ic_launcher.png differ
diff --git a/src/de/movie2k/res/mipmap-hdpi/ic_launcher_background.png b/src/de/movie2k/res/mipmap-hdpi/ic_launcher_background.png
new file mode 100644
index 000000000..2d07511b8
Binary files /dev/null and b/src/de/movie2k/res/mipmap-hdpi/ic_launcher_background.png differ
diff --git a/src/de/movie2k/res/mipmap-hdpi/ic_launcher_foreground.png b/src/de/movie2k/res/mipmap-hdpi/ic_launcher_foreground.png
new file mode 100644
index 000000000..cf49c8906
Binary files /dev/null and b/src/de/movie2k/res/mipmap-hdpi/ic_launcher_foreground.png differ
diff --git a/src/de/movie2k/res/mipmap-hdpi/ic_launcher_monochrome.png b/src/de/movie2k/res/mipmap-hdpi/ic_launcher_monochrome.png
new file mode 100644
index 000000000..cf49c8906
Binary files /dev/null and b/src/de/movie2k/res/mipmap-hdpi/ic_launcher_monochrome.png differ
diff --git a/src/de/movie2k/res/mipmap-mdpi/ic_launcher.png b/src/de/movie2k/res/mipmap-mdpi/ic_launcher.png
new file mode 100644
index 000000000..cc3cec2f5
Binary files /dev/null and b/src/de/movie2k/res/mipmap-mdpi/ic_launcher.png differ
diff --git a/src/de/movie2k/res/mipmap-mdpi/ic_launcher_background.png b/src/de/movie2k/res/mipmap-mdpi/ic_launcher_background.png
new file mode 100644
index 000000000..09b41700c
Binary files /dev/null and b/src/de/movie2k/res/mipmap-mdpi/ic_launcher_background.png differ
diff --git a/src/de/movie2k/res/mipmap-mdpi/ic_launcher_foreground.png b/src/de/movie2k/res/mipmap-mdpi/ic_launcher_foreground.png
new file mode 100644
index 000000000..d4276e61d
Binary files /dev/null and b/src/de/movie2k/res/mipmap-mdpi/ic_launcher_foreground.png differ
diff --git a/src/de/movie2k/res/mipmap-mdpi/ic_launcher_monochrome.png b/src/de/movie2k/res/mipmap-mdpi/ic_launcher_monochrome.png
new file mode 100644
index 000000000..d4276e61d
Binary files /dev/null and b/src/de/movie2k/res/mipmap-mdpi/ic_launcher_monochrome.png differ
diff --git a/src/de/movie2k/res/mipmap-xhdpi/ic_launcher.png b/src/de/movie2k/res/mipmap-xhdpi/ic_launcher.png
new file mode 100644
index 000000000..1ea1b4c43
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xhdpi/ic_launcher.png differ
diff --git a/src/de/movie2k/res/mipmap-xhdpi/ic_launcher_background.png b/src/de/movie2k/res/mipmap-xhdpi/ic_launcher_background.png
new file mode 100644
index 000000000..ea00baaf9
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xhdpi/ic_launcher_background.png differ
diff --git a/src/de/movie2k/res/mipmap-xhdpi/ic_launcher_foreground.png b/src/de/movie2k/res/mipmap-xhdpi/ic_launcher_foreground.png
new file mode 100644
index 000000000..6474e13c7
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xhdpi/ic_launcher_foreground.png differ
diff --git a/src/de/movie2k/res/mipmap-xhdpi/ic_launcher_monochrome.png b/src/de/movie2k/res/mipmap-xhdpi/ic_launcher_monochrome.png
new file mode 100644
index 000000000..6474e13c7
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xhdpi/ic_launcher_monochrome.png differ
diff --git a/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher.png b/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher.png
new file mode 100644
index 000000000..da271e15b
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher.png differ
diff --git a/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher_background.png b/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher_background.png
new file mode 100644
index 000000000..adcd3c25e
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher_background.png differ
diff --git a/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher_foreground.png b/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher_foreground.png
new file mode 100644
index 000000000..3777ec91e
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher_foreground.png differ
diff --git a/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher_monochrome.png b/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher_monochrome.png
new file mode 100644
index 000000000..3777ec91e
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xxhdpi/ic_launcher_monochrome.png differ
diff --git a/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher.png b/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher.png
new file mode 100644
index 000000000..f719fe5a5
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher.png differ
diff --git a/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher_background.png b/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher_background.png
new file mode 100644
index 000000000..08eb24e0c
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher_background.png differ
diff --git a/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher_foreground.png b/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher_foreground.png
new file mode 100644
index 000000000..bbeb49b61
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher_foreground.png differ
diff --git a/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher_monochrome.png b/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher_monochrome.png
new file mode 100644
index 000000000..bbeb49b61
Binary files /dev/null and b/src/de/movie2k/res/mipmap-xxxhdpi/ic_launcher_monochrome.png differ
diff --git a/src/de/movie2k/src/eu/kanade/tachiyomi/animeextension/de/movie2k/Movie2k.kt b/src/de/movie2k/src/eu/kanade/tachiyomi/animeextension/de/movie2k/Movie2k.kt
new file mode 100644
index 000000000..021cb4719
--- /dev/null
+++ b/src/de/movie2k/src/eu/kanade/tachiyomi/animeextension/de/movie2k/Movie2k.kt
@@ -0,0 +1,263 @@
+package eu.kanade.tachiyomi.animeextension.de.movie2k
+
+import android.app.Application
+import android.content.SharedPreferences
+import androidx.preference.ListPreference
+import androidx.preference.MultiSelectListPreference
+import androidx.preference.PreferenceScreen
+import eu.kanade.tachiyomi.animeextension.de.movie2k.extractors.DroploadExtractor
+import eu.kanade.tachiyomi.animeextension.de.movie2k.extractors.UpstreamExtractor
+import eu.kanade.tachiyomi.animesource.ConfigurableAnimeSource
+import eu.kanade.tachiyomi.animesource.model.AnimeFilterList
+import eu.kanade.tachiyomi.animesource.model.SAnime
+import eu.kanade.tachiyomi.animesource.model.SEpisode
+import eu.kanade.tachiyomi.animesource.model.Video
+import eu.kanade.tachiyomi.animesource.online.ParsedAnimeHttpSource
+import eu.kanade.tachiyomi.lib.doodextractor.DoodExtractor
+import eu.kanade.tachiyomi.lib.mixdropextractor.MixDropExtractor
+import eu.kanade.tachiyomi.lib.streamtapeextractor.StreamTapeExtractor
+import eu.kanade.tachiyomi.network.GET
+import eu.kanade.tachiyomi.util.asJsoup
+import okhttp3.OkHttpClient
+import okhttp3.Request
+import okhttp3.Response
+import org.jsoup.nodes.Document
+import org.jsoup.nodes.Element
+import uy.kohesive.injekt.Injekt
+import uy.kohesive.injekt.api.get
+import kotlin.Exception
+
+class Movie2k : ConfigurableAnimeSource, ParsedAnimeHttpSource() {
+
+ override val name = "Movie2k"
+
+ override val baseUrl = "https://movie2k.skin"
+
+ override val lang = "de"
+
+ override val supportsLatest = false
+
+ override val client: OkHttpClient = network.cloudflareClient
+
+ private val preferences: SharedPreferences by lazy {
+ Injekt.get().getSharedPreferences("source_$id", 0x0000)
+ }
+
+ override fun popularAnimeSelector(): String = "div.item-container div.item"
+
+ override fun popularAnimeRequest(page: Int): Request = GET("$baseUrl/page/$page/")
+
+ override fun popularAnimeFromElement(element: Element): SAnime {
+ val anime = SAnime.create()
+ anime.setUrlWithoutDomain(element.select("a").attr("href"))
+ anime.thumbnail_url = element.select("a div.item-inner img").attr("data-src")
+ anime.title = element.select("a div.item-inner img").attr("alt")
+ return anime
+ }
+
+ override fun popularAnimeNextPageSelector(): String = "div.pagination a.next"
+
+ // episodes
+
+ override fun episodeListSelector() = throw Exception("not used")
+
+ override fun episodeListParse(response: Response): List {
+ val document = response.asJsoup()
+ val episodeList = mutableListOf()
+ val episode = SEpisode.create()
+ episode.episode_number = 1F
+ episode.name = "Film"
+ val hostdoc = client.newCall(GET(document.select("#multiplayer a").attr("href"))).execute().asJsoup()
+ episode.url = hostdoc.select("#video-container div.server1 iframe").attr("src")
+ episodeList.add(episode)
+ return episodeList.reversed()
+ }
+
+ override fun episodeFromElement(element: Element): SEpisode = throw Exception("not used")
+
+ // Video Extractor
+
+ override fun videoListRequest(episode: SEpisode): Request {
+ return GET(episode.url.replace(baseUrl, ""))
+ }
+
+ override fun videoListParse(response: Response): List