diff --git a/src/en/supermega/AndroidManifest.xml b/src/en/supermega/AndroidManifest.xml
new file mode 100644
index 000000000..8072ee00d
--- /dev/null
+++ b/src/en/supermega/AndroidManifest.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="utf-8"?>
+<manifest />
diff --git a/src/en/supermega/build.gradle b/src/en/supermega/build.gradle
new file mode 100644
index 000000000..4757ac763
--- /dev/null
+++ b/src/en/supermega/build.gradle
@@ -0,0 +1,11 @@
+apply plugin: 'com.android.application'
+apply plugin: 'kotlin-android'
+
+ext {
+    extName = 'SUPER MEGA'
+    pkgNameSuffix = 'en.supermega'
+    extClass = '.Supermega'
+    extVersionCode = 3
+}
+
+apply from: "$rootDir/common.gradle"
diff --git a/src/en/supermega/res/mipmap-hdpi/ic_launcher.png b/src/en/supermega/res/mipmap-hdpi/ic_launcher.png
new file mode 100644
index 000000000..0d7e28dea
Binary files /dev/null and b/src/en/supermega/res/mipmap-hdpi/ic_launcher.png differ
diff --git a/src/en/supermega/res/mipmap-mdpi/ic_launcher.png b/src/en/supermega/res/mipmap-mdpi/ic_launcher.png
new file mode 100644
index 000000000..bc895916d
Binary files /dev/null and b/src/en/supermega/res/mipmap-mdpi/ic_launcher.png differ
diff --git a/src/en/supermega/res/mipmap-xhdpi/ic_launcher.png b/src/en/supermega/res/mipmap-xhdpi/ic_launcher.png
new file mode 100644
index 000000000..764345c95
Binary files /dev/null and b/src/en/supermega/res/mipmap-xhdpi/ic_launcher.png differ
diff --git a/src/en/supermega/res/mipmap-xxhdpi/ic_launcher.png b/src/en/supermega/res/mipmap-xxhdpi/ic_launcher.png
new file mode 100644
index 000000000..fdc760e25
Binary files /dev/null and b/src/en/supermega/res/mipmap-xxhdpi/ic_launcher.png differ
diff --git a/src/en/supermega/res/mipmap-xxxhdpi/ic_launcher.png b/src/en/supermega/res/mipmap-xxxhdpi/ic_launcher.png
new file mode 100644
index 000000000..b691cfae5
Binary files /dev/null and b/src/en/supermega/res/mipmap-xxxhdpi/ic_launcher.png differ
diff --git a/src/en/supermega/res/web_hi_res_512.png b/src/en/supermega/res/web_hi_res_512.png
new file mode 100644
index 000000000..8421a90bb
Binary files /dev/null and b/src/en/supermega/res/web_hi_res_512.png differ
diff --git a/src/en/supermega/src/eu/kanade/tachiyomi/extension/en/supermega/Supermega.kt b/src/en/supermega/src/eu/kanade/tachiyomi/extension/en/supermega/Supermega.kt
new file mode 100644
index 000000000..0590c12ce
--- /dev/null
+++ b/src/en/supermega/src/eu/kanade/tachiyomi/extension/en/supermega/Supermega.kt
@@ -0,0 +1,129 @@
+package eu.kanade.tachiyomi.extension.en.supermega
+
+import eu.kanade.tachiyomi.network.GET
+import eu.kanade.tachiyomi.source.model.FilterList
+import eu.kanade.tachiyomi.source.model.MangasPage
+import eu.kanade.tachiyomi.source.model.Page
+import eu.kanade.tachiyomi.source.model.SChapter
+import eu.kanade.tachiyomi.source.model.SManga
+import eu.kanade.tachiyomi.source.online.ParsedHttpSource
+import eu.kanade.tachiyomi.util.asJsoup
+import okhttp3.OkHttpClient
+import okhttp3.Request
+import org.jsoup.nodes.Document
+import org.jsoup.nodes.Element
+import rx.Observable
+import java.security.cert.X509Certificate
+import javax.net.ssl.SSLContext
+import javax.net.ssl.TrustManager
+import javax.net.ssl.X509TrustManager
+
+class Supermega : ParsedHttpSource() {
+
+    override val name = "SUPER MEGA"
+
+    override val baseUrl = "https://www.supermegacomics.com"
+
+    override val lang = "en"
+
+    override val supportsLatest = false
+
+    override val client = getUnsafeOkHttpClient()
+
+    override fun fetchPopularManga(page: Int): Observable<MangasPage> {
+        val manga = SManga.create()
+        manga.setUrlWithoutDomain("/")
+        manga.title = "SUPER MEGA"
+        manga.artist = "JohnnySmash"
+        manga.author = "JohnnySmash"
+        manga.status = SManga.ONGOING
+        manga.description = ""
+        manga.thumbnail_url = "https://www.supermegacomics.com/runningman_inverted.PNG"
+
+        return Observable.just(MangasPage(arrayListOf(manga), false))
+    }
+
+    override fun fetchMangaDetails(manga: SManga): Observable<SManga> = fetchPopularManga(1)
+        .map { it.mangas.first().apply { initialized = true } }
+
+    override fun fetchChapterList(manga: SManga): Observable<List<SChapter>> {
+        val latestComicNumber = client.newCall(GET(baseUrl)).execute().asJsoup().select("[name='bigbuttonprevious']").first()!!.parent()!!.attr("href").substringAfter("?i=").toInt() + 1
+        return Observable.just(
+            IntRange(1, latestComicNumber).reversed().map { it ->
+                SChapter.create().apply {
+                    name = it.toString()
+                    chapter_number = it.toFloat()
+                    setUrlWithoutDomain("?i=$it")
+                }
+            },
+        )
+    }
+
+    override fun pageListParse(document: Document) =
+        document.select("img[border='4']")
+            .mapIndexed { i, element ->
+                Page(i, "", element.attr("src"))
+            }
+
+    // idk if this is needed i just copied the megatokyo extension lul
+    // certificate wasn't trusted for some reason so trusted all certificates
+    private fun getUnsafeOkHttpClient(): OkHttpClient {
+        // Create a trust manager that does not validate certificate chains
+        val trustAllCerts = arrayOf<TrustManager>(
+            object : X509TrustManager {
+                override fun checkClientTrusted(chain: Array<out X509Certificate>?, authType: String?) {
+                }
+                override fun checkServerTrusted(chain: Array<out X509Certificate>?, authType: String?) {
+                }
+
+                override fun getAcceptedIssuers() = arrayOf<X509Certificate>()
+            },
+        )
+
+        // Install the all-trusting trust manager
+        val sslContext = SSLContext.getInstance("SSL")
+        sslContext.init(null, trustAllCerts, java.security.SecureRandom())
+        // Create an ssl socket factory with our all-trusting manager
+        val sslSocketFactory = sslContext.socketFactory
+
+        return OkHttpClient.Builder()
+            .sslSocketFactory(sslSocketFactory, trustAllCerts[0] as X509TrustManager)
+            .hostnameVerifier { _, _ -> true }.build()
+    }
+
+    override fun chapterListSelector(): String = throw UnsupportedOperationException("Not used")
+    override fun chapterFromElement(element: Element) = throw UnsupportedOperationException("Not used")
+
+    override fun fetchSearchManga(page: Int, query: String, filters: FilterList): Observable<MangasPage> = throw Exception("Not used")
+
+    override fun imageUrlRequest(page: Page) = GET(page.url)
+
+    override fun imageUrlParse(document: Document) = throw Exception("Not used")
+
+    override fun popularMangaSelector(): String = throw Exception("Not used")
+
+    override fun searchMangaFromElement(element: Element): SManga = throw Exception("Not used")
+
+    override fun searchMangaNextPageSelector(): String = throw Exception("Not used")
+
+    override fun searchMangaSelector(): String = throw Exception("Not used")
+
+    override fun popularMangaRequest(page: Int): Request = throw Exception("Not used")
+
+    override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request =
+        throw Exception("Not used")
+
+    override fun popularMangaNextPageSelector(): String = throw Exception("Not used")
+
+    override fun popularMangaFromElement(element: Element): SManga = throw Exception("Not used")
+
+    override fun mangaDetailsParse(document: Document): SManga = throw Exception("Not used")
+
+    override fun latestUpdatesNextPageSelector(): String = throw Exception("Not used")
+
+    override fun latestUpdatesFromElement(element: Element): SManga = throw Exception("Not used")
+
+    override fun latestUpdatesRequest(page: Int): Request = throw Exception("Not used")
+
+    override fun latestUpdatesSelector(): String = throw Exception("Not used")
+}