talimat.py

This commit is contained in:
milisbir 2017-11-28 15:11:39 +02:00
parent 67a12f4359
commit 53c2c9baa8
1 changed files with 102 additions and 3 deletions

View File

@ -46,6 +46,7 @@ class Talimat():
self.url="" self.url=""
self.paketci="" self.paketci=""
self.gerekler=[] self.gerekler=[]
self.gruplar=[]
self.isim="" self.isim=""
self._isim="" self._isim=""
self.surum="" self.surum=""
@ -74,6 +75,10 @@ class Talimat():
for gerek in pkgbuild.depends: for gerek in pkgbuild.depends:
if gerek not in self.gerekler: if gerek not in self.gerekler:
self.gerekler.append(gerek) self.gerekler.append(gerek)
if hasattr(pkgbuild, 'groups'):
for grup in pkgbuild.groups:
if grup not in self.gruplar:
self.gruplar.append(grup)
if isinstance(pkgbuild.name, list): if isinstance(pkgbuild.name, list):
self.isim=d_isim self.isim=d_isim
else: else:
@ -95,6 +100,12 @@ class Talimat():
print renk.uyari+gerek+" talimatı yapılmalı!"+renk.son print renk.uyari+gerek+" talimatı yapılmalı!"+renk.son
return gerekstr return gerekstr
def _gruplar(self):
grupstr=""
for grup in self.gruplar:
grupstr+=grup+" "
return grupstr
def _kaynaklar(self): def _kaynaklar(self):
kaynakstr="" kaynakstr=""
for kaynak in self.kaynaklar: for kaynak in self.kaynaklar:
@ -110,7 +121,7 @@ class Talimat():
blok=False blok=False
onblok=False onblok=False
for satir in satirlar: for satir in satirlar:
if "md5sums=(" in satir or "sha256sums=('" in satir: if "md5sums=(" in satir or "sha256sums=('" in satir or "sha1sums=('" in satir:
onblok=True onblok=True
if onblok is True and "')" in satir: if onblok is True and "')" in satir:
blok=True blok=True
@ -137,7 +148,8 @@ class Talimat():
icerikstr+="# Tanım: "+self.tanim+"\n" icerikstr+="# Tanım: "+self.tanim+"\n"
icerikstr+="# URL: "+self.url+"\n" icerikstr+="# URL: "+self.url+"\n"
icerikstr+="# Paketçi: "+self.paketci+"\n" icerikstr+="# Paketçi: "+self.paketci+"\n"
icerikstr+="# Gerekler: "+self._gerekler() icerikstr+="# Gerekler: "+self._gerekler()+"\n"
icerikstr+="# Grup: "+self._gruplar()
icerikstr+="\n"+"\n" icerikstr+="\n"+"\n"
icerikstr+="isim="+self.isim+"\n" icerikstr+="isim="+self.isim+"\n"
if self._isim !="": if self._isim !="":
@ -375,12 +387,71 @@ class Arge:
return None return None
return None return None
# kaosx github linki indirme
def indir_kaos(self,paket,tip="isim"):
if tip=="isim":
repolar=["main","apps","core"]
for repo in repolar:
link="https://raw.githubusercontent.com/KaOSx/"+repo+"/master/"+paket+"/PKGBUILD"
try:
veri = urllib2.urlopen(link)
print renk.tamamb+repo+" reposunda bulundu"+renk.son
open(paket+"_pkgbuild","w").write(veri.read())
return paket+"_pkgbuild"
except urllib2.HTTPError, e:
if e.code == 404:
print renk.hata+link+" bulunamadı!"+renk.son
elif tip=="link":
paket=link.split("/")[-2]
print renk.tamamb+paket+" indiriliyor..."+renk.son
try:
veri = urllib2.urlopen(link)
open(paket+"_pkgbuild","w").write(veri.read())
return paket+"_pkgbuild"
except urllib2.HTTPError, e:
if e.code == 404:
print renk.hata+link+" bulunamadı!"+renk.son
return None
return None
# blackarch github linki indirme
def indir_blackarch(self,paket,tip="isim"):
if tip=="isim":
repolar=["packages"]
for repo in repolar:
link="https://raw.githubusercontent.com/BlackArch/blackarch/master/"+repo+"/"+paket+"/PKGBUILD"
try:
veri = urllib2.urlopen(link)
print renk.tamamb+repo+" reposunda bulundu"+renk.son
open(paket+"_pkgbuild","w").write(veri.read())
return paket+"_pkgbuild"
except urllib2.HTTPError, e:
if e.code == 404:
print renk.hata+link+" bulunamadı!"+renk.son
elif tip=="link":
paket=link.split("/")[-2]
print renk.tamamb+paket+" indiriliyor..."+renk.son
try:
veri = urllib2.urlopen(link)
open(paket+"_pkgbuild","w").write(veri.read())
return paket+"_pkgbuild"
except urllib2.HTTPError, e:
if e.code == 404:
print renk.hata+link+" bulunamadı!"+renk.son
return None
return None
def yardim(self):
print renk.tamamb+"talimat.py -a (archlinux) paket_ismi | url "+renk.son
print renk.tamamb+"talimat.py -k (kaosx) paket_ismi | url "+renk.son
print renk.tamamb+"talimat.py -b (blackarch) paket_ismi | url "+renk.son
if __name__ == '__main__': if __name__ == '__main__':
arge=Arge()
if len(sys.argv) > 1: if len(sys.argv) > 1:
dosya=sys.argv[1] dosya=sys.argv[1]
talimat=Talimat() talimat=Talimat()
arge=Arge()
if os.path.exists(dosya): if os.path.exists(dosya):
talimat.cevir(dosya) talimat.cevir(dosya)
elif len(sys.argv) > 2: elif len(sys.argv) > 2:
@ -402,6 +473,32 @@ if __name__ == '__main__':
dosya=arge.indir(link) dosya=arge.indir(link)
if link and dosya: if link and dosya:
talimat.cevir(dosya) talimat.cevir(dosya)
elif dosya == "-k":
link=sys.argv[2]
if "https" in link or "http" in link:
Pdosya=arge.indir_kaos(link,"link")
talimat.cevir(Pdosya)
else :
paket=sys.argv[2]
paket=str(paket)
dosya=arge.indir_kaos(paket,"isim")
if dosya:
talimat.cevir(dosya)
else:
renk.hata+str(dosya)+" repolarda bulunamadı!"+renk.son
elif dosya == "-b":
link=sys.argv[2]
if "https" in link or "http" in link:
Pdosya=arge.indir_blackarch(link,"link")
talimat.cevir(Pdosya)
else :
paket=sys.argv[2]
paket=str(paket)
dosya=arge.indir_blackarch(paket,"isim")
if dosya:
talimat.cevir(dosya)
else:
renk.hata+str(dosya)+" repolarda bulunamadı!"+renk.son
elif dosya == "-al": elif dosya == "-al":
link=sys.argv[2] link=sys.argv[2]
if "https" in link or "http" in link: if "https" in link or "http" in link:
@ -419,3 +516,5 @@ if __name__ == '__main__':
renk.hata+str(dosya)+" repolarda bulunamadı!"+renk.son renk.hata+str(dosya)+" repolarda bulunamadı!"+renk.son
else: else:
print renk.hata+dosya+" paremetre bulunamadı!"+renk.son print renk.hata+dosya+" paremetre bulunamadı!"+renk.son
else:
arge.yardim()