-
Notifications
You must be signed in to change notification settings - Fork 0
/
pylyglot.py
74 lines (60 loc) · 1.69 KB
/
pylyglot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
import click
class jpeg:
def __init__(self, fileName):
with open(fileName, "rb") as data:
jpg = bytearray(data.read())
i = jpg.index(b"\xdb")
self.jfif = jpg[0:i-1]
self.imageData = jpg[i:]
@property
def jfif(self):
return self.__jfif
@jfif.setter
def jfif(self, jfif):
self.__jfif = jfif
@property
def imageData(self):
return self.__imageData
@imageData.setter
def imageData(self, imageData):
self.__imageData = imageData
class jfif:
def __init__(self, data):
pass
class pdf:
def __init__(self, fileName):
with open(fileName, "rb") as data:
pdf = bytearray(data.read())
i = 0
while i <= len(pdf):
if chr(pdf[i]) == 'o' and chr(pdf[i+1]) == 'b' and chr(pdf[i+2]) == 'j':
self.pdfHeader = pdf[:i-1]
self.pdfData = pdf[i:]
break
i += 1
@property
def pdfHeader(self):
return self.__pdfHeader
@pdfHeader.setter
def pdfHeader(self, pdfHeader):
self.__pdfHeader = pdfHeader
@property
def pdfData(self):
return self.__pdfData
@pdfData.setter
def pdfData(self, pdfData):
self.__pdfData = pdfData
def jpgInPdf(jpg, pdf):
output = bytearray()
head = jpg.jfif
tail = ""
dummyObject = bytearray()
head[2] = ord('\x00')
head[3] = ord('\x00')
output.extend(head)
with open("out.pdf", "wb") as outputFile:
pass
with open("vapor.jpg", "rb") as jpg:
pdf = pdf("koc-do-you-want-vaporwave.pdf")
jpg = jpeg("vapor.jpg")
jpgInPdf(jpg, pdf)