txtrecord_decode.py
· 845 B · Python
Raw
#!/usr/bin/env python3
# txtrecord_decode.py output.png logo.example.com
import dns.resolver # pip3 install dnspython
import base64
import sys
def parse_records(name):
_next = ""
print("{}".format(name), file=sys.stderr)
q = dns.resolver.query(name,"TXT").response.answer[0]
out = b""
for line in sorted(_.strings[0] for _ in q):
if chr(line[0]) == "{":
if chr(line[1]) == "n":
_next = line.split(b"}",1)[1].decode("utf-8")
continue
try:
out += line.split(b"}",1)[1]
except IndexError:
pass
return out, _next
out = b""
name = sys.argv[2]
while True:
next_out, name = parse_records(name)
out += next_out
if not name:
break
with open(sys.argv[1],"wb") as f:
f.write(base64.b64decode(out))
| 1 | #!/usr/bin/env python3 |
| 2 | # txtrecord_decode.py output.png logo.example.com |
| 3 | import dns.resolver # pip3 install dnspython |
| 4 | import base64 |
| 5 | import sys |
| 6 | def parse_records(name): |
| 7 | _next = "" |
| 8 | print("{}".format(name), file=sys.stderr) |
| 9 | q = dns.resolver.query(name,"TXT").response.answer[0] |
| 10 | out = b"" |
| 11 | for line in sorted(_.strings[0] for _ in q): |
| 12 | if chr(line[0]) == "{": |
| 13 | if chr(line[1]) == "n": |
| 14 | _next = line.split(b"}",1)[1].decode("utf-8") |
| 15 | continue |
| 16 | try: |
| 17 | out += line.split(b"}",1)[1] |
| 18 | except IndexError: |
| 19 | pass |
| 20 | return out, _next |
| 21 | |
| 22 | out = b"" |
| 23 | name = sys.argv[2] |
| 24 | while True: |
| 25 | next_out, name = parse_records(name) |
| 26 | out += next_out |
| 27 | if not name: |
| 28 | break |
| 29 | |
| 30 | with open(sys.argv[1],"wb") as f: |
| 31 | f.write(base64.b64decode(out)) |
| 32 |
txtrecord_encode.py
· 811 B · Python
Raw
#!/usr/bin/env python3
# txtrecord_encode.py input.png logo.example.com
import base64
import sys
from textwrap import wrap
with open(sys.argv[1],"rb") as f:
enc = base64.b64encode(f.read()).decode("utf-8")
# '%04d' and '247' may need to be updated for large files to ensure the line count doesn't push the length
# longer than 255 bytes
tot = len(enc)
tmp = 0
for n,block in enumerate(wrap(enc,65000)):
tmp += len(block)
print("\n".join("{0}. IN TXT '{1}{2}'".format((str(n) if n else "") + sys.argv[2], "{%03d}" % _n, s) for _n, s in enumerate(wrap(block,249))))
if tmp != tot:
print("{0}. IN TXT '{1}{2}.".format((str(n) if n else "") + sys.argv[2], "{nxt}", str(n+1) + sys.argv[2]))
#print("\n".join("%s. IN TXT '{%03d}%s'" % (sys.argv[2], n,s) for n,s in enumerate(wrap(enc,249))))
| 1 | #!/usr/bin/env python3 |
| 2 | # txtrecord_encode.py input.png logo.example.com |
| 3 | import base64 |
| 4 | import sys |
| 5 | from textwrap import wrap |
| 6 | with open(sys.argv[1],"rb") as f: |
| 7 | enc = base64.b64encode(f.read()).decode("utf-8") |
| 8 | |
| 9 | # '%04d' and '247' may need to be updated for large files to ensure the line count doesn't push the length |
| 10 | # longer than 255 bytes |
| 11 | tot = len(enc) |
| 12 | tmp = 0 |
| 13 | for n,block in enumerate(wrap(enc,65000)): |
| 14 | tmp += len(block) |
| 15 | print("\n".join("{0}. IN TXT '{1}{2}'".format((str(n) if n else "") + sys.argv[2], "{%03d}" % _n, s) for _n, s in enumerate(wrap(block,249)))) |
| 16 | if tmp != tot: |
| 17 | print("{0}. IN TXT '{1}{2}.".format((str(n) if n else "") + sys.argv[2], "{nxt}", str(n+1) + sys.argv[2])) |
| 18 | #print("\n".join("%s. IN TXT '{%03d}%s'" % (sys.argv[2], n,s) for n,s in enumerate(wrap(enc,249)))) |
| 19 |
untitled.ipynb
· 7.6 KiB · Text
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"This is a test of Jupyter generating a cool blog post about a neat python project or something."
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"b'test'\n",
"b'{00}iVBORw0KGgoAAAAN...sQo8aFRo0+M8YCYKGjiE'\n",
"b'{01}Q1CiALGgCAgINfud...ZGAkyJ9sDvO2DzNa4dZk'\n",
"b'{02}E+BTF9RgIePCSjO3...UX6911GGr69VMh/3eWDV'\n",
"b'{03}bE6tkPWUyTPRkqrY...bw8nGGgoCoYXopEPQ1Q7'\n"
]
}
],
"source": [
"import dns.resolver\n",
"import base64\n",
"from IPython.display import HTML\n",
"q = dns.resolver.query(\"logo.hosttel.com.au\",\"TXT\").response.answer[0]\n",
"for line in sorted(_.strings[0] for _ in q)[:5]:\n",
" print((line[:20] + b\"...\" + line[-20:]) if len(line) > 20 else line)"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<img src=''/>"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"execution_count": 3,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"out = b\"\"\n",
"for line in sorted(_.strings[0] for _ in q):\n",
" if chr(line[0]) == \"{\":\n",
" try:\n",
" out += line.split(b\"}\",1)[1]\n",
" except IndexError:\n",
" pass\n",
"HTML(\"<img src='data:image/png;base64,{0}'/>\".format(out.decode('utf-8')))"
]
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.7.3"
}
},
"nbformat": 4,
"nbformat_minor": 2
}
| 1 | { |
| 2 | "cells": [ |
| 3 | { |
| 4 | "cell_type": "markdown", |
| 5 | "metadata": {}, |
| 6 | "source": [ |
| 7 | "This is a test of Jupyter generating a cool blog post about a neat python project or something." |
| 8 | ] |
| 9 | }, |
| 10 | { |
| 11 | "cell_type": "code", |
| 12 | "execution_count": 10, |
| 13 | "metadata": {}, |
| 14 | "outputs": [ |
| 15 | { |
| 16 | "name": "stdout", |
| 17 | "output_type": "stream", |
| 18 | "text": [ |
| 19 | "b'test'\n", |
| 20 | "b'{00}iVBORw0KGgoAAAAN...sQo8aFRo0+M8YCYKGjiE'\n", |
| 21 | "b'{01}Q1CiALGgCAgINfud...ZGAkyJ9sDvO2DzNa4dZk'\n", |
| 22 | "b'{02}E+BTF9RgIePCSjO3...UX6911GGr69VMh/3eWDV'\n", |
| 23 | "b'{03}bE6tkPWUyTPRkqrY...bw8nGGgoCoYXopEPQ1Q7'\n" |
| 24 | ] |
| 25 | } |
| 26 | ], |
| 27 | "source": [ |
| 28 | "import dns.resolver\n", |
| 29 | "import base64\n", |
| 30 | "from IPython.display import HTML\n", |
| 31 | "q = dns.resolver.query(\"logo.hosttel.com.au\",\"TXT\").response.answer[0]\n", |
| 32 | "for line in sorted(_.strings[0] for _ in q)[:5]:\n", |
| 33 | " print((line[:20] + b\"...\" + line[-20:]) if len(line) > 20 else line)" |
| 34 | ] |
| 35 | }, |
| 36 | { |
| 37 | "cell_type": "code", |
| 38 | "execution_count": 3, |
| 39 | "metadata": {}, |
| 40 | "outputs": [ |
| 41 | { |
| 42 | "data": { |
| 43 | "text/html": [ |
| 44 | "<img src=''/>" |
| 45 | ], |
| 46 | "text/plain": [ |
| 47 | "<IPython.core.display.HTML object>" |
| 48 | ] |
| 49 | }, |
| 50 | "execution_count": 3, |
| 51 | "metadata": {}, |
| 52 | "output_type": "execute_result" |
| 53 | } |
| 54 | ], |
| 55 | "source": [ |
| 56 | "out = b\"\"\n", |
| 57 | "for line in sorted(_.strings[0] for _ in q):\n", |
| 58 | " if chr(line[0]) == \"{\":\n", |
| 59 | " try:\n", |
| 60 | " out += line.split(b\"}\",1)[1]\n", |
| 61 | " except IndexError:\n", |
| 62 | " pass\n", |
| 63 | "HTML(\"<img src='data:image/png;base64,{0}'/>\".format(out.decode('utf-8')))" |
| 64 | ] |
| 65 | } |
| 66 | ], |
| 67 | "metadata": { |
| 68 | "kernelspec": { |
| 69 | "display_name": "Python 3", |
| 70 | "language": "python", |
| 71 | "name": "python3" |
| 72 | }, |
| 73 | "language_info": { |
| 74 | "codemirror_mode": { |
| 75 | "name": "ipython", |
| 76 | "version": 3 |
| 77 | }, |
| 78 | "file_extension": ".py", |
| 79 | "mimetype": "text/x-python", |
| 80 | "name": "python", |
| 81 | "nbconvert_exporter": "python", |
| 82 | "pygments_lexer": "ipython3", |
| 83 | "version": "3.7.3" |
| 84 | } |
| 85 | }, |
| 86 | "nbformat": 4, |
| 87 | "nbformat_minor": 2 |
| 88 | } |
| 89 |