diff --git a/dwmscripts/calc.py b/dwmscripts/calc.py new file mode 100644 index 0000000..7388a4e --- /dev/null +++ b/dwmscripts/calc.py @@ -0,0 +1,59 @@ +import os +from typing import List +import subprocess +import requests + + +def get_ex_rates() -> float: + response = \ + requests.get("https://www.cbr-xml-daily.ru/daily_json.js").json() + out = {} + for valute in response["Valute"]: + out[valute] = response["Valute"][valute]["Value"] + return out + + +def show_command_out(command: str, return_out: str = True) -> str | None: + if not return_out: + os.system(command) + return + return subprocess.check_output( + command, + shell=True + ).decode("utf-8") + + +def show_dmenu_out(question: str, answers: List[str] = None) -> str: + if not answers: + return show_command_out( + 'cat /dev/null | dmenu -p "{}"'.format( + question + ) + )[:-1] + return show_command_out( + 'echo "{}" | dmenu -p "{}"'.format( + "".join([f"{x}\n" for x in answers])[:-1], + question + ) + )[:-1] + + +def main() -> None: + sentence = show_dmenu_out(">") + try: + ex_rates = get_ex_rates() + for ex_rate in ex_rates: + locals()[ex_rate] = ex_rates[ex_rate] + answer = str(eval(sentence)) + except Exception as exc: + answer = str(exc) + do_copy = show_dmenu_out(f"{sentence} = {answer}", ["Exit", "Copy"]) + if do_copy == "Copy": + show_command_out( + f'echo "{answer}" | xclip -selection clipboard -r', + False + ) + + +if __name__ == '__main__': + main() diff --git a/dwmscripts/calc.sh b/dwmscripts/calc.sh new file mode 100755 index 0000000..e6bc338 --- /dev/null +++ b/dwmscripts/calc.sh @@ -0,0 +1 @@ +python /home/naki/dwmscripts/calc.py diff --git a/dwmscripts/convert.sh b/dwmscripts/convert.sh new file mode 100755 index 0000000..19307c9 --- /dev/null +++ b/dwmscripts/convert.sh @@ -0,0 +1,8 @@ +#!/bin/bash + +# xclip -o > /tmp/convert.txt; iconv -f WINDOWS-1251 -t UTF-8 /tmp/convert.txt | xclip -selection clipboard +# { echo "." & ms-gen 10 9; } | xclip -selection clipboard +# /home/plaza/dwmscripts/main 10 10 | xclip -selection clipboard +# xclip -o | base64 | xclip -selection clibboard -r +# printf "worried\nthinking\nshrug\nangry\nangrysight\ncuddles\nhappy\ncrying\ndancing\nconfused" | dmenu -l 20 -p "Select emoji" | +python /home/naki/dwmscripts/emoji.py diff --git a/dwmscripts/dictionary.json b/dwmscripts/dictionary.json new file mode 100644 index 0000000..27794e0 --- /dev/null +++ b/dwmscripts/dictionary.json @@ -0,0 +1,18 @@ +{ + "panic": "(つ﹏⊂)", + "thinking": "(;・・)ゞ", + "shrug": "¯\\(ツ)/¯", + "angry": "ヾ(`д´*)ノ", + "angrysight": "(⚞︵⚟)", + "happysight": "(≧ω≦)", + "cuddles": "(つ´∀`)つ", + "happy": "(^▽^)", + "cryinghappy": "(*≧▽≦)", + "confusedhappy": "(.❛ ᴗ ❛.)", + "crying": "( ≧Д≦)", + "dancing": "ヽ(o´∀´)ノ♪♬", + "confused": "(´・_・´)", + "cute": "(⌒ω⌒)", + "sleeping": "(∪。∪)。。。zzz", + "writing": "__φ(..)" +} \ No newline at end of file diff --git a/dwmscripts/dwmbar/__init__.py b/dwmscripts/dwmbar/__init__.py new file mode 100644 index 0000000..6ca8f39 --- /dev/null +++ b/dwmscripts/dwmbar/__init__.py @@ -0,0 +1,3 @@ +from dwmbar.bar import Bar +import dwmbar.modules +from dwmbar.other import get_command_out diff --git a/dwmscripts/dwmbar/__pycache__/__init__.cpython-311.pyc b/dwmscripts/dwmbar/__pycache__/__init__.cpython-311.pyc new file mode 100644 index 0000000..747445e Binary files /dev/null and b/dwmscripts/dwmbar/__pycache__/__init__.cpython-311.pyc differ diff --git a/dwmscripts/dwmbar/__pycache__/bar.cpython-311.pyc b/dwmscripts/dwmbar/__pycache__/bar.cpython-311.pyc new file mode 100644 index 0000000..f84f6ae Binary files /dev/null and b/dwmscripts/dwmbar/__pycache__/bar.cpython-311.pyc differ diff --git a/dwmscripts/dwmbar/__pycache__/dwmbar.cpython-311.pyc b/dwmscripts/dwmbar/__pycache__/dwmbar.cpython-311.pyc new file mode 100644 index 0000000..93adc12 Binary files /dev/null and b/dwmscripts/dwmbar/__pycache__/dwmbar.cpython-311.pyc differ diff --git a/dwmscripts/dwmbar/__pycache__/modules.cpython-311.pyc b/dwmscripts/dwmbar/__pycache__/modules.cpython-311.pyc new file mode 100644 index 0000000..b2dcf58 Binary files /dev/null and b/dwmscripts/dwmbar/__pycache__/modules.cpython-311.pyc differ diff --git a/dwmscripts/dwmbar/__pycache__/other.cpython-311.pyc b/dwmscripts/dwmbar/__pycache__/other.cpython-311.pyc new file mode 100644 index 0000000..a338ecb Binary files /dev/null and b/dwmscripts/dwmbar/__pycache__/other.cpython-311.pyc differ diff --git a/dwmscripts/dwmbar/bar.py b/dwmscripts/dwmbar/bar.py new file mode 100644 index 0000000..85ab3f3 --- /dev/null +++ b/dwmscripts/dwmbar/bar.py @@ -0,0 +1,48 @@ +from dwmbar.modules import BarItem +import os +from time import sleep, time + + +class Bar: + def __init__( + self, + items_count: int = 10, + sep: str = '' + ) -> None: + self.sep = sep + self.items = [BarItem(False) for _ in range(items_count)] + + def start(self, update_time: float = 0) -> None: + """After call this function program will start infinity loop""" + while True: + start = time() + for i in range(len(self.items)): + self[i].update() + self.write() + finish = time() + sleep_time = update_time - (finish - start) + sleep(0 if sleep_time < 0 else sleep_time) + + def __getitem__( + self, + key: int + ) -> BarItem: + return self.items[key] + + def __setitem__( + self, + key: int, + value: BarItem + ) -> None: + self.items[key] = value + + def __len__(self) -> int: + return len(self.items) + + def write(self, reversed: bool = True) -> None: + out = ' ' + ''.join( + [str(self[i]) + ' / ' for i in range(len(self)) + if self[i] + ] + )[:-3] + ' ' + os.system(f"xsetroot -name \"{out}\"") diff --git a/dwmscripts/dwmbar/main.cc b/dwmscripts/dwmbar/main.cc new file mode 100644 index 0000000..e69de29 diff --git a/dwmscripts/dwmbar/modules.py b/dwmscripts/dwmbar/modules.py new file mode 100644 index 0000000..5738136 --- /dev/null +++ b/dwmscripts/dwmbar/modules.py @@ -0,0 +1,125 @@ +from subprocess import CalledProcessError +import psutil +from datetime import datetime +from dwmbar.other import get_command_out + + +class BarItem: + def __init__( + self, + filled: bool = True + ) -> None: + self.filled = bool(filled) + self.out = '' + + def update(self) -> None: + pass + + def __str__(self) -> str: + return self.out + + def __bool__(self) -> bool: + return self.filled + + +class TimeItem(BarItem): + def update(self) -> None: + # + now = datetime.now() + if now.strftime("%p") == "AM": + self.out = " " + else: + self.out = " " + self.out += datetime.now().strftime("%I:%M") + + +class RAMItem(BarItem): + def __init__(self) -> None: + """RAM in G""" + super().__init__(True) + self.divider = 2**30 + self.total = round(psutil.virtual_memory()[0] / self.divider, 1) + + def update(self) -> None: + used = round(psutil.virtual_memory()[3] / self.divider, 1) + self.out = f" {used}G" + + +class LayoutItem(BarItem): + def update(self) -> None: + self.out = ' ' + get_command_out( + "setxkbmap -query | grep layout" + ).split()[-1].upper() + + +class CPUUsageItem(BarItem): + def update(self) -> None: + usage = psutil.cpu_percent() + usage = f"{usage}" if usage % 1 else f"{int(usage)}.0" + self.out = f" {usage:0>4}%" + + +class DiskUsageItem(BarItem): + def __init__(self, divider: int = 10**9) -> None: + super().__init__(True) + """Disk in GB""" + self.divider = 10**9 + self.total = round(psutil.disk_usage('/').total / self.divider, 1) + + def update(self) -> None: + used = round(psutil.disk_usage('/').used / self.divider, 1) + self.out = F" {used}G/{self.total}G" + + +class BatteryItem(BarItem): + def __init__(self, hide_if_full: bool = False) -> None: + super().__init__(True) + # self.hide_if_full = hide_if_full + + def update(self) -> None: + battery = psutil.sensors_battery() + # plugged = battery.power_plugged + percent = round(battery.percent) + # self.out = f" {'#' if plugged else '*'}{percent}%" + self.out = f" {percent}%" + # self.filled = False if self.hide_if_full and percent == 100 else True + + +class VolumeItem(BarItem): + def update(self) -> None: + volume = get_command_out( + "amixer get Master | awk -F'[][]' 'END{ print $4\":\"$2 }'" + ) + self.out = " " + volume[volume.find(":") + 1:-1] + + +class MusicItem(BarItem): + def update(self) -> None: + try: + status = get_command_out("cmus-remote -Q") + except CalledProcessError: + self.out = " cmus" + return + if "file" not in status: + self.out = " cmus" + return + for var in status.split("\n"): + args = var.split() + if not args: + continue + match args[0]: + case "status": + if args[1] == "playing": + self.out = "" + else: + self.out = "" + case "file": + filename = var[var.rfind("/") + 1:var.rfind(".")] + self.out += " " + filename + + +class InfoItem(BarItem): + def __init__(self, text: str) -> None: + super().__init__() + self.out = text + diff --git a/dwmscripts/dwmbar/other.py b/dwmscripts/dwmbar/other.py new file mode 100644 index 0000000..06a8cd1 --- /dev/null +++ b/dwmscripts/dwmbar/other.py @@ -0,0 +1,8 @@ +import subprocess + + +def get_command_out(command: str) -> None: + return subprocess.check_output( + command, + shell=True + ).decode("utf-8") diff --git a/dwmscripts/emoji.py b/dwmscripts/emoji.py new file mode 100644 index 0000000..d8d9ab9 --- /dev/null +++ b/dwmscripts/emoji.py @@ -0,0 +1,33 @@ +import subprocess +import os +import json + + +def show_command_out(command: str) -> str: + return subprocess.check_output( + command, + shell=True + ).decode("utf-8") + + +def main(): + path = os.path.dirname(os.path.realpath(__file__)) + with open(f"{path}/dictionary.json") as file: + dictionary = json.load(file) + dictionary_list = [x for x in dictionary] + + key = show_command_out( + 'echo "{}"\ +| dmenu -l 20 -p \"Select alias\"'.format(''.join([f'{x}\n' for x + in dictionary_list])[:-1]) + ).strip() + + try: + out = dictionary[key] + except KeyError: + return + os.system(f"echo \"{out}\" | xclip -selection clipboard -r") + + +if __name__ == '__main__': + main() diff --git a/dwmscripts/emojis.txt b/dwmscripts/emojis.txt new file mode 100644 index 0000000..7aeb7c9 --- /dev/null +++ b/dwmscripts/emojis.txt @@ -0,0 +1,10 @@ +worried +thinking +shrug +angry +angrysight +cuddles +happy +crying +dancing +confused \ No newline at end of file diff --git a/dwmscripts/genpass.py b/dwmscripts/genpass.py new file mode 100644 index 0000000..dd6580f --- /dev/null +++ b/dwmscripts/genpass.py @@ -0,0 +1,18 @@ +from random import choice + + +def main() -> None: + SIZE = 64 + ALPHABET = ( + "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" + "0123456789!@#$%^&*()[]{},." + ) + + out = '' + for _ in range(SIZE): + out += choice(ALPHABET) + print(out) + + +if __name__ == '__main__': + main() diff --git a/dwmscripts/layout.py b/dwmscripts/layout.py new file mode 100644 index 0000000..1139ae0 --- /dev/null +++ b/dwmscripts/layout.py @@ -0,0 +1,28 @@ +import json +import os +import sys + + +states = ["us", "ru"] + + +def main() -> None: + state = states[1] + if os.path.exists("/tmp/layout.json"): + with open("/tmp/layout.json") as f: + state = json.load(f)["layout"] + for i, val in enumerate(states): + if val == state: + state = states[(i + 1) % len(states)] + break + with open("/tmp/layout.json", 'w') as f: + json.dump({"layout": state}, f, indent=4) + os.system(f"setxkbmap {state}") + + +if __name__ == "__main__": + if len(sys.argv) == 1: + main() + else: + if "-s" in sys.argv: + os.system(f"setxkbmap {states[0]}") diff --git a/dwmscripts/out b/dwmscripts/out new file mode 100644 index 0000000..e9ff9e4 Binary files /dev/null and b/dwmscripts/out differ diff --git a/dwmscripts/prekol.py b/dwmscripts/prekol.py new file mode 100644 index 0000000..f5bbef9 --- /dev/null +++ b/dwmscripts/prekol.py @@ -0,0 +1,36 @@ +import psutil +from pypresence import Presence +import time + + +def main() -> None: + client_id = '1149335280072020078' + RPC = Presence(client_id, pipe=0) + RPC.connect() + + start_time = psutil.boot_time() + while True: + # waiting = time.time() - start_time + # minutes = waiting // 60 + # hours = minutes // 60 + # minutes = minutes % 60 + # waiting_days = int(time.time() - start_time) // 60 // 60 // 24 + waiting_days = int(time.time() - start_time) // 60 // 60 // 24 + # state=f"{int(hours):02}:{int(minutes):02}:{int(waiting % 60):02}", + RPC.update( + # details=details_list[i1], + state=f"{waiting_days} days,", + large_image="superpuper", + large_text="This is a picture, isn't it?", + buttons=[{ + "label": "This is not rickroll", + "url": "https://goo.su/eriA6eD" + }], + start=start_time + ) + RPC.update + time.sleep(10) + + +if __name__ == '__main__': + main() diff --git a/dwmscripts/scrot.py b/dwmscripts/scrot.py new file mode 100644 index 0000000..72ab351 --- /dev/null +++ b/dwmscripts/scrot.py @@ -0,0 +1,74 @@ +import os +from random import choice +# from requests import get + +INDEX_HTML = "/home/naki/server/index.html" +SERVER_PATH = "/home/naki/server/a/" +LULS_PATH = "/home/naki/server/luls/" + +RANDOM_SIZE = 5 +RANDOM_ALPHABET = ( + "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" + "0123456789" +) + + +def gen_random(size, alphabet) -> str: + out = '' + for _ in range(size): + out += choice(alphabet) + return out + + +def main() -> None: + images = next(os.walk(SERVER_PATH), (None, None, []))[2] + # images = list(map(int, [image[3:-4] for image in images])) + images = [image[:-4] for image in images] + # out = max(images) + 1 if images else 0 + name = '' + while True: + name = gen_random(RANDOM_SIZE, RANDOM_ALPHABET) + if name not in images: + break + os.system(f"/home/naki/dwmscripts/scrotpy.sh '{SERVER_PATH + name + '.png'}'") + + # os.system( + # f"flameshot gui --raw > {SERVER_PATH}img{out}.png" + # ) + + # os.system( + # f"flameshot gui --raw > {SERVER_PATH}{name}.png" + # ) + + ip = "nakidai.ddns.net" # get('https://api.ipify.org').content.decode('utf8') + + os.system( + f"echo \"http://{ip}/a/{name}.png\" |" + f" xclip -selection clipboard -r" + ) + + with open(INDEX_HTML, 'w') as f: + f.write(f""" + + +
+ + +
+ {"
".join([f"https://{ip}/luls/{img}
"
+ for img in os.listdir(LULS_PATH)])}
+
+
+""")
+
+
+if __name__ == '__main__':
+ main()
diff --git a/dwmscripts/scrot.sh b/dwmscripts/scrot.sh
new file mode 100755
index 0000000..02180ae
--- /dev/null
+++ b/dwmscripts/scrot.sh
@@ -0,0 +1,7 @@
+scrot -o /tmp/scrot.png
+feh -F /tmp/scrot.png &
+feh_pid=$!
+scrot --select '/home/naki/pic/screenshots/%F_%T_$wx$h.png' -e 'xclip -selection clipboard -target image/png -i $f'
+kill $feh_pid
+# flameshot gui --raw | xclip -selection clipboard -target image/png
+# maim -u | feh -F - & sleep 1 && maim -s | xclip -selection clipboard -target image/png && kill $!
diff --git a/dwmscripts/scrotpy.sh b/dwmscripts/scrotpy.sh
new file mode 100755
index 0000000..f26c9c8
--- /dev/null
+++ b/dwmscripts/scrotpy.sh
@@ -0,0 +1,3 @@
+#!/bin/bash
+scrot -s -f -o $1
+
diff --git a/dwmscripts/sysbar.py b/dwmscripts/sysbar.py
new file mode 100644
index 0000000..a3f3957
--- /dev/null
+++ b/dwmscripts/sysbar.py
@@ -0,0 +1,22 @@
+import dwmbar
+
+
+def main() -> None:
+ # kernel_ver = dwmbar.get_command_out("uname -r")[:-1]
+
+ bar = dwmbar.Bar()
+ bar[9] = dwmbar.modules.TimeItem()
+ bar[8] = dwmbar.modules.RAMItem()
+ # bar[7] = dwmbar.modules.DiskUsageItem()
+ # bar[6] = dwmbar.modules.CPUUsageItem()
+ bar[5] = dwmbar.modules.BatteryItem(True)
+
+ # bar[1] = dwmbar.modules.InfoItem(kernel_ver)
+ bar[2] = dwmbar.modules.VolumeItem()
+ bar[1] = dwmbar.modules.LayoutItem()
+ bar[0] = dwmbar.modules.MusicItem()
+ bar.start(1)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/dwmscripts/turnoffscreen.sh b/dwmscripts/turnoffscreen.sh
new file mode 100755
index 0000000..7924182
--- /dev/null
+++ b/dwmscripts/turnoffscreen.sh
@@ -0,0 +1 @@
+sleep 1 && xset -display :0.0 dpms force off