-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/categories/index.xml b/categories/index.xml
index 1be3928..363bba9 100644
--- a/categories/index.xml
+++ b/categories/index.xml
@@ -6,6 +6,10 @@
Recent content in Categories on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
-
+
\ No newline at end of file
diff --git a/cheatsheet/index.html b/cheatsheet/index.html
index 1a8fa39..e536d95 100644
--- a/cheatsheet/index.html
+++ b/cheatsheet/index.html
@@ -176,6 +176,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/cheatsheet/index.xml b/cheatsheet/index.xml
index f5a1436..197c151 100644
--- a/cheatsheet/index.xml
+++ b/cheatsheet/index.xml
@@ -6,7 +6,11 @@
Recent content in Cheatsheets on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
Emacs
/cheatsheet/emacs/
@@ -48,4 +52,4 @@
-
+
\ No newline at end of file
diff --git a/cheatsheet/linux/index.html b/cheatsheet/linux/index.html
index 923c1ba..04dc2a3 100644
--- a/cheatsheet/linux/index.html
+++ b/cheatsheet/linux/index.html
@@ -201,7 +201,7 @@ A much more convenient alternative is installing this NetworkManager plugin:
pacman -Sy networkmanager-fortisslvpn
-# Or apt get install networkmanager-fortisslvpn
+# Or apt get install networkmanager-fortisslvpn
Now you can simply add a new VPN connection in NetworkManager and manage it as you would any other connection.
diff --git a/cheatsheet/page/1/index.html b/cheatsheet/page/1/index.html
index d9cd9be..0783a2c 100644
--- a/cheatsheet/page/1/index.html
+++ b/cheatsheet/page/1/index.html
@@ -1 +1 @@
-/cheatsheet/
\ No newline at end of file
+/cheatsheet/
\ No newline at end of file
diff --git a/index.html b/index.html
index cf04d4d..c76556a 100644
--- a/index.html
+++ b/index.html
@@ -1,7 +1,7 @@
-
+
Balkian's site - Balkian's site
@@ -56,6 +56,27 @@
+
+
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
-
- Zotero is an Open Source tool that lets you organise your bibliography, syncing it with the cloud. Unlike other alternatives such as Mendeley, Zotero can upload the attachments and data to a private cloud via WebDav.
-If you use nginx as your web server, know that even though it provides partial support for webdav, Zotero needs more than that.
-
diff --git a/index.json b/index.json
index ece4225..ada0f59 100644
--- a/index.json
+++ b/index.json
@@ -1 +1 @@
-[{"categories":null,"contents":"Believe it or not, Surface tablets have pretty good linux support, except for the webcams in newer models. These are some useful notes to get Ubuntu installed in your surface go, as of Summer 2019.\nInstalling the kernel 1 2 git clone --depth 1 https://github.com/jakeday/linux-surface.git ~/linux-surface cp -a ~/linux-surface /media/\u0026lt;your usb\u0026gt; 1 2 3 cp -a /media/\u0026lt;your usb\u0026gt;/linux-surface ~/ cd ~/linux-surface/ sudo sh setup.sh Booting ubuntu first Switch out of Windows S mode.\nBoot into the \u0026ldquo;Command Prompt\u0026rdquo;.\nFrom Windows go to \u0026ldquo;change advanced startup options\u0026rdquo; and select \u0026ldquo;restart now\u0026rdquo;.\nWhen it reboots, choose the \u0026ldquo;Troubleshoot\u0026rdquo; option, then choose the \u0026ldquo;Advanced options\u0026rdquo; option, and finally choose the \u0026ldquo;Command Prompt\u0026rdquo; option.\nAfter the device reboots, login to the command prompt and then you should see a terminal with X:\\windows\\system32\u0026gt;\nAt the prompt, check your UEFI entries:\n1 bcdedit /enum firmware Copy UEFI entry of \u0026ldquo;Windows Boot Manager\u0026rdquo; to create a new entry for Ubuntu: bcdedit /copy {bootmgr} /d \u0026ldquo;Ubuntu\u0026rdquo;\nCopy the printed GUID number including the braces {} using Ctrl+C\nSet file path for the new Ubuntu entry. Replace {guid} with the returned GUID of the previous command (Ctrl+V). bcdedit /set {guid} path \\EFI\\ubuntu\\grubx64.efi\nSet Ubuntu as the first/ entry in the boot sequence. Again replace {guid} with the returned GUID of the copy command.\n1 bcdedit /set {fwbootmgr} displayorder {guid} /addfirst Check your UEFI entries again: bcdedit /enum firmware You should see something like this:\n1 2 3 4 5 6 7 8 9 10 Firmware Boot Manager --------------------- identifier {fwbootmgr} displayorder {3510232e-f8eb-e811-95ce-9ecab3f9d1c4} {bootmgr} {2148799b-f8eb-e811-95ce-9ecab3f9d1c4} {312e8a67-c2f6-e811-95ce-3c1ab3f9d1de} {312e8a68-c2f6-e811-95ce-3c1ab3f9d1de} timeout 0 Make sure the GUID you copied is the first one listed in displayorder. Then type exit, turn off the PC and turn it back on. After this my surface go is automatically booting to the grub bootloader which lets me choose between Windows and Ubuntu but defaults to Ubuntu after ten seconds.\n","permalink":"/post/2019-05-01-surface-go/","tags":["linux","surface go","config"],"title":"Linux on the Microsoft Surface Go"},{"categories":null,"contents":"This is a short tutorial on connecting a zigbee device (an Aqara cube) to an MQTT server, so you can control your zigbee devices from the network.\nIf you\u0026rsquo;re anything like me, you\u0026rsquo;re probably a sucker for IoT devices. For a long time, I\u0026rsquo;ve been using WiFi-enabled lights, and Amazon dash buttons to control them. To keep these (cheap Chinese) internet enabled devices away from your network and their respective cloud services, you\u0026rsquo;ll probably want to set up a dedicated network in your router (more on this on a future post, maybe). Another disadvantage of WiFi devices is that they\u0026rsquo;re relatively power hungry.\nA popular alternative is using ZigBee for communication. It is a dedicated protocol similar to bluetooth (BLE), with lower power requirements and bitrate.\nTake the (super cute) aqara cube as an example. It is a small cube that detects rotation on all of its axes, and tapping events. Here\u0026rsquo;s a video:\n To connect to zigbee devices you will need a zigbee enabled gateway (a.k.a. hub), which connects to your WiFi network and your zigbee devices. Once again, this means adding an internet-enabled device to your home, and probably a couple of cloud services.\nAs an alternative, you can set up your own zigbee gateway, and control it to your home automation platform of choice (e.g. home assistant). We will cover how to set up a zigbee2mqtt gateway that is also connected to an MQTT server, so you can use MQTT to control your devices and get notifications.\nWhat you need:\n Aqara cube. CC2531 zigbee sniffer. CC-debugger. You will need to flash your sniffer. For that, you only need to follow the instructions from the zigbee2mqtt documentation.\nOnce you\u0026rsquo;re done flashing, you\u0026rsquo;re ready to set up the zigbee2mqtt server. For convenience, I wrote a simple docker-compose to deploy a zigbee2mqtt server and a test mosquitto server:\n1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 version: \u0026#39;2.1\u0026#39; services: zigbee2mqtt: image: koenkk/zigbee2mqtt container_name: zigbee2mqtt restart: always volumes: - ./z2m-data/:/app/data/ devices: - \u0026#34;/dev/ttyACM0\u0026#34; networks: - hass mqtt: image: eclipse-mosquitto ports: - 1883:1883 - 9001:9001 networks: - hass volumes: - ./mosquitto.conf:/mosquitto/config/mosquitto.conf networks: hass: driver: overlay You can test your installation with:\n1 2 3 4 5 6 ❯ mosquitto_sub -h localhost -p 1883 -t \u0026#39;zigbee2mqtt/#\u0026#39; online {\u0026#34;battery\u0026#34;:17,\u0026#34;voltage\u0026#34;:2925,\u0026#34;linkquality\u0026#34;:149,\u0026#34;action\u0026#34;:\u0026#34;rotate_right\u0026#34;,\u0026#34;angle\u0026#34;:12.8} {\u0026#34;battery\u0026#34;:17,\u0026#34;voltage\u0026#34;:2925,\u0026#34;linkquality\u0026#34;:141,\u0026#34;action\u0026#34;:\u0026#34;slide\u0026#34;,\u0026#34;side\u0026#34;:2} {\u0026#34;battery\u0026#34;:17,\u0026#34;voltage\u0026#34;:2925,\u0026#34;linkquality\u0026#34;:120} {\u0026#34;battery\u0026#34;:17,\u0026#34;voltage\u0026#34;:2925,\u0026#34;linkquality\u0026#34;:141,\u0026#34;action\u0026#34;:\u0026#34;wakeup\u0026#34;} zigbee2mqtt supports the following events for the aqara cube: shake, wakeup, fall, tap, slide, flip180, flip90, rotate_left and rotate_right. Every event has additional information, such as the sides involved, or the degrees turned.\nNow you are ready to set up home assistant support in zigbee2mqtt following this guide.\n","permalink":"/post/2019-01-06-zigbee2mqtt/","tags":["mqtt","iot","zigbee"],"title":"Controlling Zigbee devices with MQTT"},{"categories":null,"contents":"tqdm is a nice way to add progress bars in the command line or in a jupyter notebook.\n1 2 3 4 5 from tqdm import tqdm import time for i in tqdm(range(100)): time.sleep(1) ","permalink":"/post/2016-09-28-tqdm/","tags":["python"],"title":"Progress bars in python"},{"categories":null,"contents":"Today\u0026rsquo;s post is half a quick note, half public shaming. In other words, it is a reminder to be very careful with OAuth tokens and passwords.\nAs part of moving to emacs, I starting using the incredibly useful gh.el. When you first use it, the extension saves either your password or an OAuth token in your .gitconfig file. This is cool and convenient, unless you happen to be publishing your .gitconfig file in a public repo.\nSo, how can you still share your gitconfig without sharing your password/token with the rest of the world? Since Git 1.7.0, you can include other files in your gitconfig.\n[include] path = ~/.gitconfig_secret And now, in your .gitconfig_secret file, you just have to add this:\n[github] user = balkian token = \u0026quot;\u0026lt; Your secret token \u0026gt;\u0026quot; ","permalink":"/post/2015-04-10-github-dotfiles/","tags":["github","git","dotfiles"],"title":"Sharing dotfiles"},{"categories":null,"contents":"Zotero is an Open Source tool that lets you organise your bibliography, syncing it with the cloud. Unlike other alternatives such as Mendeley, Zotero can upload the attachments and data to a private cloud via WebDav.\nIf you use nginx as your web server, know that even though it provides partial support for webdav, Zotero needs more than that. Hence, you will need another webdav server, and optionally let nginx proxy to it. This short post provides the basics to get that set-up working under Debian/Ubuntu.\nSetting up Apache First we need to install Apache:\n1 sudo apt-get install apache2 Change the head of \u0026ldquo;/etc/apache2/sites-enabled/000-default\u0026rdquo; to:\n1 \u0026lt;VirtualHost *:880\u0026gt; Then, create a file /etc/apache2/sites-available/webdav:\n1 2 3 4 5 6 7 8 9 10 11 12 13 Alias /dav /home/webdav/dav \u0026lt;Location /dav\u0026gt; Dav on Order Allow,Deny Allow from all Dav On Options +Indexes AuthType Basic AuthName DAV AuthBasicProvider file AuthUserFile /home/webdav/.htpasswd Require valid-user \u0026lt;/Location\u0026gt; Ideally, you want your webdav folders to be private, adding authentication to them. So you need to create the webdav and zotero users and add the passwords to an htpasswd file. Even though you could use a single user, since you will be configuring several clients with your credentials I encourage you to create the zotero user as well. This way you can always change the password for zotero without affecting any other application using webdav.\n1 2 3 4 sudo adduser webdav sudo htpasswd -c /home/webdav/.htpasswd webdav sudo htpasswd /home/webdav/.htpasswd zotero sudo mkdir -p /home/webdav/dav/zotero Enable the site and restart apache:\n1 2 3 4 sudo a2enmod webdav sudo a2enmod dav_fs sudo a2ensite webdav sudo service apache2 restart At this point everything should be working at http://\u0026lt;your_host\u0026gt;:880/dav/zotero\nSetting up NGINX After the Apache side is working, we can use nginx as a proxy to get cleaner URIs. In your desired site/location, add this:\n1 2 3 4 5 6 7 location /dav { client_max_body_size 20M; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $remote_addr; proxy_set_header Host $host; proxy_pass http://127.0.0.1:880; } Now just reload nginx:\n1 sudo service nginx force-reload Extras Zotero Reader - HTML5 client Zandy - Android Open Source client ","permalink":"/post/2014-12-09-zotero/","tags":["zotero","webdav","nginx","apache"],"title":"Zotero"},{"categories":null,"contents":"This is a quick note on proxying a local python application (e.g. flask) to a subdirectory in Apache. This assumes that the file wsgi.py contains a WSGI application with the name application. Hence, wsgi:application.\nGunicorn 1 2 3 4 5 \u0026lt;Location /myapp/\u0026gt; ProxyPass http://127.0.0.1:8888/myapp/ ProxyPassReverse http://127.0.0.1:8888/myapp/ RequestHeader set SCRIPT_NAME \u0026#34;/myapp/\u0026#34; \u0026lt;/Location\u0026gt; Important: SCRIPT_NAME and the end of ProxyPass URL MUST BE THE SAME. Otherwise, Gunicorn will fail miserably.\nTry it with:\n1 venv/bin/gunicorn -w 4 -b 127.0.0.1:8888 --log-file - --access-logfile - wsgi:application UWSGI This is a very simple configuration. I will try to upload one with more options for uwsgi (in a .ini file).\n1 2 3 4 \u0026lt;Location /myapp/\u0026gt; SetHandler uwsgi_handler uWSGISocker 127.0.0.1:8888 \u0026lt;/Location\u0026gt; Try it with:\n1 uwsgi --socket 127.0.0.1:8888 -w wsgi:application Extra: Supervisor If everything went as expected, you can wrap your command in a supervisor config file and let it handle the server for you.\n1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 [unix_http_server] file=/tmp/myapp.sock ; path to your socket file [supervisord] logfile = %(here)s/logs/supervisor.log childlogdir = %(here)s/logs/ [rpcinterface:supervisor] supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface [supervisorctl] logfile = %(here)s/logs/supervisorctl.log serverurl=unix:///tmp/supervisor.sock ; use a unix:// URL for a unix socket [program:myapp] command = venv/bin/gunicorn -w 4 -b 0.0.0.0:5000 --log-file %(here)s/logs/gunicorn.log --access-logfile - wsgi:application directory = %(here)s environment = PATH=%(here)s/venv/bin/ logfile = %(here)s/logs/myapp.log ","permalink":"/post/2014-10-09-proxies/","tags":["python","apache","proxy","gunicorn","uwsgi"],"title":"Proxies with Apache and python"},{"categories":null,"contents":"Developing a python module and publishing it on Github is cool, but most of the times you want others to download and use it easily. That is the role of PyPi, the python package repository. In this post I show you how to publish your package in less than 10 minutes.\nChoose a fancy name If you haven\u0026rsquo;t done so yet, take a minute or two to think about this. To publish on PyPi you need a name for your package that isn\u0026rsquo;t taken. What\u0026rsquo;s more, a catchy and unique name will help people remember your module and feel more inclined to at least try it.\nThe package name should hint what your module does, but that\u0026rsquo;s not always the case. That\u0026rsquo;s your call. I personally put uniqueness and memorability over describing the functionality.\nCreate a .pypirc configuration file 1 2 3 4 5 6 7 8 9 10 11 12 13 [distutils] # this tells distutils what package indexes you can push to index-servers =pypi # the live PyPI pypitest # test PyPI [pypi] # authentication details for live PyPI repository = https://pypi.python.org/pypi username = { your_username } password = { your_password } # not necessary [pypitest] # authentication details for test PyPI repository = https://testpypi.python.org/pypi username = { your_username } As you can see, you need to register both in the main pypi repository and the testing server. The usernames and passwords might be different, that is up to you!\nPrepare your package This should be the structure:\nroot-dir/ # Any name you want setup.py setup.cfg LICENSE.txt README.md mypackage/ __init__.py foo.py bar.py baz.py setup.cfg 1 2 [metadata] description-file = README.md The markdown README is the de facto standard in Github, but you can also use rST (reStructuredText), the standard in the python community.\nsetup.py 1 2 3 4 5 6 7 8 9 10 11 12 from distutils.core import setup setup(name = \u0026#39;mypackage\u0026#39;, packages = [\u0026#39;mypackage\u0026#39;], # this must be the same as the name above version = \u0026#39;{ version }\u0026#39;, description = \u0026#39;{ description }\u0026#39;, author = \u0026#39;{ name }\u0026#39;, email = \u0026#39;{ email }\u0026#39;, url = \u0026#39;https://github.com/{user}/{package}\u0026#39;, # URL to the github repo download_url = \u0026#39;https://github.com/{user}/{repo}/tarball/{version}\u0026#39;, keywords = [\u0026#39;websockets\u0026#39;, \u0026#39;display\u0026#39;, \u0026#39;d3\u0026#39;], # list of keywords that represent your package classifiers = [], ) You might notice that the download_url points to a Github URL. We could host our package anywhere, but Github is a convenient option. To create the tarball and the zip packages, you only need to tag a tag in your repository and push it to github:\n1 2 git tag {version} -m \u0026#34;{ Description of this tag/version}\u0026#34; git push --tags origin master Push to the testing/main pypi server It is advisable that you try your package on the test repository and fix any problems first. The process is simple:\n1 python setup.py register -r {pypitest/pypi} python setup.py sdist upload -r {pypitest/pypi} If everything went as expected, you can now install your package through pip and browse your package\u0026rsquo;s page. For instance, check my senpy package: https://pypi.python.org/pypi/senpy\n1 pip install senpy ","permalink":"/post/2014-09-23-publishing-to-pypi/","tags":["github","python","pypi"],"title":"Publishing on PyPi"},{"categories":null,"contents":"As part of the OpeNER hackathon we decided to build a prototype that would allow us to compare how different countries feel about several topics. We used the OpeNER pipeline to get the sentiment from a set of newspaper articles we gathered from media in several languages. Then we aggregated those articles by category and country (using the source of the article or the language it was written in), obtaining the \u0026ldquo;overall feeling\u0026rdquo; of each country about each topic. Then, we used some fancy JavaScript to make sense out of the raw information.\nIt didn\u0026rsquo;t go too bad, it turns out we won.\nNow, it was time for a face-lift. I used this opportunity to play with new technologies and improve it:\n Using Flask, this time using python 3.3 and Bootstrap 3.0 Cool HTML5+JS cards (thanks to pastetophone) Automatic generation of fake personal data to test the interface Obfuscation of personal emails The result can be seen here.\nPublishing a Python 3 app on Heroku 1 mkvirtualenv -p /usr/bin/python3.3 eurolovemap Since Heroku uses python 2.7 by default, we have to tell it which version we want, although it supports python 3.4 as well. I couldn\u0026rsquo;t get python 3.4 working using the deadsnakes ppa, so I used python 3.3 instead, which works fine but is not officially supported. Just create a file named runtime.txt in your project root, with the python version you want to use:\n1 python-3.3.1 Don\u0026rsquo;t forget to freeze your dependencies so Heroku can install them: bash pip freze \u0026gt; requirements.txt\nPublishing personal emails There are really sophisticated and effective ways to obfuscate personal emails so that spammers cannot easily grab yours. However, this time I needed something really simple to hide our emails from the simplest form of crawlers. Most of the team are in academia somehow, so in the end all our emails are available in sites like Google Scholar. Anyway, nobody likes getting spammed so I settled for a custom Caesar cipher. Please, don\u0026rsquo;t use it for any serious application if you are concerned about being spammed.\n1 2 def blur_email(email): return \u0026#34;\u0026#34;.join([chr(ord(i)+5) for i in email]) And this is the client side:\n1 2 3 4 5 6 7 8 9 10 11 12 window.onload = function(){ elems = document.getElementsByClassName(\u0026#39;profile-email\u0026#39;); for(var e in elems){ var blur = elems[e].innerHTML; var email = \u0026#34;\u0026#34;; for(var s in blur){ var a = blur.charCodeAt(s) email = email+String.fromCharCode(a-5); } elems[e].innerHTML = email; } } Unfortunately, this approach does not hide your email from anyone using PhantomJS, ZombieJS or similar. For that, other approaches like generating a picture with the address would be necessary. Nevertheless, it is overkill for a really simple ad-hoc application with custom formatting and just a bunch of emails that would easily be grabbed manually.\nGeneration of fake data To test the contact section of the site, I wanted to populate it with fake data. Fake-Factory is an amazing library that can generate fake data of almost any kind: emails, association names, acronyms\u0026hellip; It even lets you localise the results (get Spanish names, for instance) and generate factories for certain classes (à la Django).\nBut I also wanted pictures, enter Lorem Pixel. With its API you can generate pictures of almost any size, for different topics (e.g. nightlife, people) and with a custom text. You can even use an index, so it will always show the same picture.\nFor instance, the picture below is served through Lorem Pixel.\nBy the way, if you only want cat pictures, take a look at Placekitten. And for NSFW text, there\u0026rsquo;s the Samuel L. Jackson Ipsum\n","permalink":"/post/2014-03-27-updating-eurolovemap/","tags":["javascript","python","heroku"],"title":"Updating EuroLoveMap"},{"categories":null,"contents":"A simple trick. If you want to remove all the \u0026lsquo;.swp\u0026rsquo; files from a git repository, just use:\n1 git rm --cached \u0026#39;**.swp\u0026#39; ","permalink":"/post/2013-08-22-remove-git-files-with-globbing/","tags":["git"],"title":"Remove git files with globbing"},{"categories":null,"contents":"I\u0026rsquo;ve finally decided to set up a decent personal page. I have settled for github-pages because I like the idea of keeping my site in a repository and having someone else host and deploy it for me. The site will be really simple, mostly static files. Thanks to Github, Jekyll will automatically generate static pages for my posts every time I commit anything new to this repository.\nBut Jekyll can be used independently, so if I ever choose to host the site myself, I can do it quite easily. Another thing that I liked about this approach is that the generated html files can be used in the future, and I will not need Jekyll to serve it. Jekyll is really simple and most of the things are written in plain html. That means that everything could be easily reused if I ever choose to change to another blogging framework (e.g. pelical). But, for the time being, I like the fact that Github takes care of the compilation as well, so I can simply modify or add files through the web interface should I need to.\nI hadn\u0026rsquo;t played with HTML and CSS for a while now, so I also wanted to use this site as a playground. At some point, I realised I was doing mostly everything in plain HTML and CSS, and decided to keep it like that for as long as possible. As of this writing, I haven\u0026rsquo;t included any Javascript code in the page. Probably I will use some to add my gists and repositories, but we will see about that.\nI think the code speaks for itself, so you can check out my repository on Github. You can clone and deploy it easily like this:\n1 2 3 git clone https://github.com/balkian/balkian.github.com cd balkian.github.com jekyll serve -w I will keep updating this post with information about:\n Some Jekyll plugins that might be useful What CSS tricks I learnt The webfonts I used The badge on the left side of the page ","permalink":"/post/2013-08-17-creating-my-web/","tags":["starters","javascript","ruby","github","git"],"title":"Creating my web"},{"categories":null,"contents":"Show plain text version 1 (font-lock-mode) ","permalink":"/cheatsheet/emacs/","tags":["emacs","org","productivity","lisp"],"title":"Emacs"},{"categories":null,"contents":"Ongoing Projects Senpy: a framework for semantic sentiment and emotion analysis services. Soil: an agent-based simulator for social networks based on nx-sim and networkx. Onyx: an ontology for emotion analysis that includes concepts from W3C\u0026rsquo;s provenance. Past Projects Marl: I updated this ontology, originally created by Adam Westerski, to make it compatible with the W3C\u0026rsquo;s provenance ontology. Hermes: one of my first projects, developed together with David Pérez as the special custom assignment in one of our courses. Hermes is an affective bot designed to mimic the behavour of humans. It included a plug-in system for its sensors and actuators. The information from its sensors changed its emotional state, which was shown via its actuators. Among others, it could fetch inforation from Twitter or its host system and change the expressions of an external Face made with servo motors or speak via its Text-To-Speech software. For instance, it could detect it was running out of battery, showing a sad face and sending an alerting tweet. You can see it in action in these two youtube videos: Part 1 and Part 2. Maia: the Modular Architecture for Intelligent Agents is an evented agent architecture that aims to update the classical frameworks for intelligent agents with the concepts emerged from the Live Web. EESTEC.net: the Plone based official portal of EESTEC. It has been my first and only experience with Plone. I fixed some bugs and implemented basic features. For more information, check my list of public repositories in Github.\n","permalink":"/project/","tags":null,"title":"Index of projects"},{"categories":null,"contents":"Black screen and LightDM doesn\u0026rsquo;t unlock Add this to your /etc/lightdm/lightdm.conf file:\n1 2 [LightDM] logind-check-graphical=true Edit previous commands fc is a shell builtin to list and edit previous commands in an editor. In addition to editing a single line (which you can also do with C-x C-e), it also allows you to edit and run several lines at the same time. You use it like this:\nList previous commands\n1 2 3 4 5 $ fc -l 10259 nvim deploy.sh 10260* cd .. 10261* nvim content/cheatsheet/linux.md 10262 cd List commands with date (in zsh)\n1 2 3 4 5 $ fc -ld 10260* 19:38 cd .. 10261* 19:38 nvim content/cheatsheet/linux.md 10262 19:40 cd 10263 19:40 fc -l You can add the date too:\n1 2 3 4 $ fc -fld 10262 1/10/2019 19:40 cd 10263 1/10/2019 19:40 fc -l 10264 1/10/2019 19:40 fc -ld You can edit a range of commands\n1 $ fc 10262 10264 The range can be relative to the current position, so the previous command is equivalent to:\n1 $ fc -3 -1 If you save and exit, all commands are executed as a script, and it will be added to your history.\nSource: https://shapeshed.com/unix-fc/\nPrevent logoff from killing tmux sessions Lately I\u0026rsquo;ve noticed that logging out of i3, intentionally or when i3 fails, would also kill any tmux or emacs sessions. This is extremely annoying.\nThis is caused by a new default in logind (systemd\u0026rsquo;s login) to kill user process on logoff. You can revert this setting in your logind.conf (/etc/systemd/logind.conf):\n1 KillUserProcesses=no Or only for a specific process (e.g., tmux):\n1 systemd-run --scope --user tmux Source: https://unix.stackexchange.com/questions/490267/prevent-logoff-from-killing-tmux-session\nUpload a temporary file Sometimes you just need to copy/paste a file from a server, and copying from the terminal can be a hassle. These two services are command-line \u0026ldquo;pastebins\u0026rdquo; just one curl away:\n1 2 3 4 5 6 7 8 \u0026lt;command\u0026gt; | curl -F \u0026#39;sprunge=\u0026lt;-\u0026#39; http://sprunge.us # OR \u0026lt;command\u0026gt; 2\u0026gt;\u0026amp;1 | curl -F \u0026#39;f:1=\u0026lt;-\u0026#39; ix.io # OR \u0026lt;command\u0026gt; | curl -F\u0026#34;file=@-\u0026#34; https://ttm.sh Install Fortinet SSLVPN support for NetworkManager UPM (Universidad Politécnica de Madrid) uses a propriatary VPN solution. The instructions for GNU/Linux on their website involve downloading a specific client (.tar.gz) and manually running it. That works, but it is kind of a hassle. A much more convenient alternative is installing this NetworkManager plugin:\n1 2 pacman -Sy networkmanager-fortisslvpn # Or apt get install networkmanager-fortisslvpn Now you can simply add a new VPN connection in NetworkManager and manage it as you would any other connection.\n","permalink":"/cheatsheet/linux/","tags":["linux","arch"],"title":"Linux"},{"categories":null,"contents":"Interesting libraries TQDM From tqdm\u0026rsquo;s github repository:\n tqdm means \u0026ldquo;progress\u0026rdquo; in Arabic (taqadum, تقدّم) and an abbreviation for \u0026ldquo;I love you so much\u0026rdquo; in Spanish (te quiero demasiado).\n ","permalink":"/cheatsheet/python/","tags":["python","programming"],"title":"Python"},{"categories":null,"contents":"HDMI flickering Avoid HDMI flickering/intermittent blanking on RPI with a 1400x1050 VGA monitor.\n1 2 3 4 5 6 hdmi_drive=2 hdmi_group=2 hdmi_mode=42 disable_overscan=1 config_hdmi_boost=7 ","permalink":"/cheatsheet/rpi/","tags":["rpi"],"title":"Raspberry Pi"},{"categories":null,"contents":"This file exists solely to respond to /search URL with the related search layout template.\nNo content shown here is rendered, all content is based in the template layouts/page/search.html\nSetting a very low sitemap priority will tell search engines this is not important content.\nThis implementation uses Fusejs, jquery and mark.js\nInitial setup Search depends on additional output content type of JSON in config.toml ``` [outputs] home = [\u0026ldquo;HTML\u0026rdquo;, \u0026ldquo;JSON\u0026rdquo;] ```\nSearching additional fileds To search additional fields defined in front matter, you must add it in 2 places.\nEdit layouts/_default/index.JSON This exposes the values in /index.json i.e. add category ``` \u0026hellip; \u0026ldquo;contents\u0026rdquo;:{{ .Content | plainify | jsonify }} {{ if .Params.tags }}, \u0026ldquo;tags\u0026rdquo;:{{ .Params.tags | jsonify }}{{end}}, \u0026ldquo;categories\u0026rdquo; : {{ .Params.categories | jsonify }}, \u0026hellip; ```\nEdit fuse.js options to Search static/js/search.js ``` keys: [ \u0026ldquo;title\u0026rdquo;, \u0026ldquo;contents\u0026rdquo;, \u0026ldquo;tags\u0026rdquo;, \u0026ldquo;categories\u0026rdquo; ] ```\n ${title} ${snippet}\n ","permalink":"/search/","tags":null,"title":"Search Results"},{"categories":null,"contents":"PhD Write my first workshop paper as main author Write my first journal paper Write my first book chapter Chair a W3C Community Group Collaborate on a W3C recommendation Become a doctor! Technical Write a NodeJS App. Maia [See ISSUES] Write my first Django Application Develop a distributed LibP2P golang application Github repo with +100 stars Build a custom LineageOS image Languages English Chinese Greek German Esperanto Personal Run a 10k Blog regularly for a year ","permalink":"/page/todo/","tags":null,"title":"To-do"}]
\ No newline at end of file
+[{"categories":null,"contents":"I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.\nAs soon as I plugged it in, I realized there were some glaring issues with the keyboard. First of all, the Meta/Super and Alt keys are reversed in this keyboard. In the normal/full version of this keyboard, Logitech gives an option to choose between Mac, Windows and iOS host, and that changes the behavior of the keys. In this version, tho, only iOS and Mac are available.\nBesides that, there\u0026rsquo;s the issue of the grave (tilde) and angle keys switched as well.\nSwitching these keys around would be very easy with Xorg, but Wayland once again complicates things\u0026hellip;\nThese issues almost made me return the keyboard. Luckily, tho, there is another option: configuring the keys one level lower than wayland (and X11), through hwdb.\nLong story short, this will configure any Logitech keyboard with the same product id (0x4092) to use a saner configuration:\n1 2 3 4 5 6 7 8 #File: /etc/udev/hwdb.d/90-logitech-keyboard.hwdb evdev:input:b0003v046Dp4092* KEYBOARD_KEY_700e2=leftmeta KEYBOARD_KEY_700e3=leftalt KEYBOARD_KEY_70039=leftctrl KEYBOARD_KEY_70064=grave KEYBOARD_KEY_70035=102nd After that, simply run:\n sudo udevadm hwdb --update \u0026amp;\u0026amp; sudo udevadm trigger ","permalink":"/post/2021-10-29-logitech-mx-keys-mac/","tags":["linux","logitech","keyboard"],"title":"Logitech MX Keys for Mac on Linux"},{"categories":null,"contents":"Believe it or not, Surface tablets have pretty good linux support, except for the webcams in newer models. These are some useful notes to get Ubuntu installed in your surface go, as of Summer 2019.\nInstalling the kernel 1 2 git clone --depth 1 https://github.com/jakeday/linux-surface.git ~/linux-surface cp -a ~/linux-surface /media/\u0026lt;your usb\u0026gt; 1 2 3 cp -a /media/\u0026lt;your usb\u0026gt;/linux-surface ~/ cd ~/linux-surface/ sudo sh setup.sh Booting ubuntu first Switch out of Windows S mode.\nBoot into the \u0026ldquo;Command Prompt\u0026rdquo;.\nFrom Windows go to \u0026ldquo;change advanced startup options\u0026rdquo; and select \u0026ldquo;restart now\u0026rdquo;.\nWhen it reboots, choose the \u0026ldquo;Troubleshoot\u0026rdquo; option, then choose the \u0026ldquo;Advanced options\u0026rdquo; option, and finally choose the \u0026ldquo;Command Prompt\u0026rdquo; option.\nAfter the device reboots, login to the command prompt and then you should see a terminal with X:\\windows\\system32\u0026gt;\nAt the prompt, check your UEFI entries:\n1 bcdedit /enum firmware Copy UEFI entry of \u0026ldquo;Windows Boot Manager\u0026rdquo; to create a new entry for Ubuntu: bcdedit /copy {bootmgr} /d \u0026ldquo;Ubuntu\u0026rdquo;\nCopy the printed GUID number including the braces {} using Ctrl+C\nSet file path for the new Ubuntu entry. Replace {guid} with the returned GUID of the previous command (Ctrl+V). bcdedit /set {guid} path \\EFI\\ubuntu\\grubx64.efi\nSet Ubuntu as the first/ entry in the boot sequence. Again replace {guid} with the returned GUID of the copy command.\n1 bcdedit /set {fwbootmgr} displayorder {guid} /addfirst Check your UEFI entries again: bcdedit /enum firmware You should see something like this:\n1 2 3 4 5 6 7 8 9 10 Firmware Boot Manager --------------------- identifier {fwbootmgr} displayorder {3510232e-f8eb-e811-95ce-9ecab3f9d1c4} {bootmgr} {2148799b-f8eb-e811-95ce-9ecab3f9d1c4} {312e8a67-c2f6-e811-95ce-3c1ab3f9d1de} {312e8a68-c2f6-e811-95ce-3c1ab3f9d1de} timeout 0 Make sure the GUID you copied is the first one listed in displayorder. Then type exit, turn off the PC and turn it back on. After this my surface go is automatically booting to the grub bootloader which lets me choose between Windows and Ubuntu but defaults to Ubuntu after ten seconds.\n","permalink":"/post/2019-05-01-surface-go/","tags":["linux","surface go","config"],"title":"Linux on the Microsoft Surface Go"},{"categories":null,"contents":"This is a short tutorial on connecting a zigbee device (an Aqara cube) to an MQTT server, so you can control your zigbee devices from the network.\nIf you\u0026rsquo;re anything like me, you\u0026rsquo;re probably a sucker for IoT devices. For a long time, I\u0026rsquo;ve been using WiFi-enabled lights, and Amazon dash buttons to control them. To keep these (cheap Chinese) internet enabled devices away from your network and their respective cloud services, you\u0026rsquo;ll probably want to set up a dedicated network in your router (more on this on a future post, maybe). Another disadvantage of WiFi devices is that they\u0026rsquo;re relatively power hungry.\nA popular alternative is using ZigBee for communication. It is a dedicated protocol similar to bluetooth (BLE), with lower power requirements and bitrate.\nTake the (super cute) aqara cube as an example. It is a small cube that detects rotation on all of its axes, and tapping events. Here\u0026rsquo;s a video:\n To connect to zigbee devices you will need a zigbee enabled gateway (a.k.a. hub), which connects to your WiFi network and your zigbee devices. Once again, this means adding an internet-enabled device to your home, and probably a couple of cloud services.\nAs an alternative, you can set up your own zigbee gateway, and control it to your home automation platform of choice (e.g. home assistant). We will cover how to set up a zigbee2mqtt gateway that is also connected to an MQTT server, so you can use MQTT to control your devices and get notifications.\nWhat you need:\n Aqara cube. CC2531 zigbee sniffer. CC-debugger. You will need to flash your sniffer. For that, you only need to follow the instructions from the zigbee2mqtt documentation.\nOnce you\u0026rsquo;re done flashing, you\u0026rsquo;re ready to set up the zigbee2mqtt server. For convenience, I wrote a simple docker-compose to deploy a zigbee2mqtt server and a test mosquitto server:\n1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 version: \u0026#39;2.1\u0026#39; services: zigbee2mqtt: image: koenkk/zigbee2mqtt container_name: zigbee2mqtt restart: always volumes: - ./z2m-data/:/app/data/ devices: - \u0026#34;/dev/ttyACM0\u0026#34; networks: - hass mqtt: image: eclipse-mosquitto ports: - 1883:1883 - 9001:9001 networks: - hass volumes: - ./mosquitto.conf:/mosquitto/config/mosquitto.conf networks: hass: driver: overlay You can test your installation with:\n1 2 3 4 5 6 ❯ mosquitto_sub -h localhost -p 1883 -t \u0026#39;zigbee2mqtt/#\u0026#39; online {\u0026#34;battery\u0026#34;:17,\u0026#34;voltage\u0026#34;:2925,\u0026#34;linkquality\u0026#34;:149,\u0026#34;action\u0026#34;:\u0026#34;rotate_right\u0026#34;,\u0026#34;angle\u0026#34;:12.8} {\u0026#34;battery\u0026#34;:17,\u0026#34;voltage\u0026#34;:2925,\u0026#34;linkquality\u0026#34;:141,\u0026#34;action\u0026#34;:\u0026#34;slide\u0026#34;,\u0026#34;side\u0026#34;:2} {\u0026#34;battery\u0026#34;:17,\u0026#34;voltage\u0026#34;:2925,\u0026#34;linkquality\u0026#34;:120} {\u0026#34;battery\u0026#34;:17,\u0026#34;voltage\u0026#34;:2925,\u0026#34;linkquality\u0026#34;:141,\u0026#34;action\u0026#34;:\u0026#34;wakeup\u0026#34;} zigbee2mqtt supports the following events for the aqara cube: shake, wakeup, fall, tap, slide, flip180, flip90, rotate_left and rotate_right. Every event has additional information, such as the sides involved, or the degrees turned.\nNow you are ready to set up home assistant support in zigbee2mqtt following this guide.\n","permalink":"/post/2019-01-06-zigbee2mqtt/","tags":["mqtt","iot","zigbee"],"title":"Controlling Zigbee devices with MQTT"},{"categories":null,"contents":"tqdm is a nice way to add progress bars in the command line or in a jupyter notebook.\n1 2 3 4 5 from tqdm import tqdm import time for i in tqdm(range(100)): time.sleep(1) ","permalink":"/post/2016-09-28-tqdm/","tags":["python"],"title":"Progress bars in python"},{"categories":null,"contents":"Today\u0026rsquo;s post is half a quick note, half public shaming. In other words, it is a reminder to be very careful with OAuth tokens and passwords.\nAs part of moving to emacs, I starting using the incredibly useful gh.el. When you first use it, the extension saves either your password or an OAuth token in your .gitconfig file. This is cool and convenient, unless you happen to be publishing your .gitconfig file in a public repo.\nSo, how can you still share your gitconfig without sharing your password/token with the rest of the world? Since Git 1.7.0, you can include other files in your gitconfig.\n[include] path = ~/.gitconfig_secret And now, in your .gitconfig_secret file, you just have to add this:\n[github] user = balkian token = \u0026quot;\u0026lt; Your secret token \u0026gt;\u0026quot; ","permalink":"/post/2015-04-10-github-dotfiles/","tags":["github","git","dotfiles"],"title":"Sharing dotfiles"},{"categories":null,"contents":"Zotero is an Open Source tool that lets you organise your bibliography, syncing it with the cloud. Unlike other alternatives such as Mendeley, Zotero can upload the attachments and data to a private cloud via WebDav.\nIf you use nginx as your web server, know that even though it provides partial support for webdav, Zotero needs more than that. Hence, you will need another webdav server, and optionally let nginx proxy to it. This short post provides the basics to get that set-up working under Debian/Ubuntu.\nSetting up Apache First we need to install Apache:\n1 sudo apt-get install apache2 Change the head of \u0026ldquo;/etc/apache2/sites-enabled/000-default\u0026rdquo; to:\n1 \u0026lt;VirtualHost *:880\u0026gt; Then, create a file /etc/apache2/sites-available/webdav:\n1 2 3 4 5 6 7 8 9 10 11 12 13 Alias /dav /home/webdav/dav \u0026lt;Location /dav\u0026gt; Dav on Order Allow,Deny Allow from all Dav On Options +Indexes AuthType Basic AuthName DAV AuthBasicProvider file AuthUserFile /home/webdav/.htpasswd Require valid-user \u0026lt;/Location\u0026gt; Ideally, you want your webdav folders to be private, adding authentication to them. So you need to create the webdav and zotero users and add the passwords to an htpasswd file. Even though you could use a single user, since you will be configuring several clients with your credentials I encourage you to create the zotero user as well. This way you can always change the password for zotero without affecting any other application using webdav.\n1 2 3 4 sudo adduser webdav sudo htpasswd -c /home/webdav/.htpasswd webdav sudo htpasswd /home/webdav/.htpasswd zotero sudo mkdir -p /home/webdav/dav/zotero Enable the site and restart apache:\n1 2 3 4 sudo a2enmod webdav sudo a2enmod dav_fs sudo a2ensite webdav sudo service apache2 restart At this point everything should be working at http://\u0026lt;your_host\u0026gt;:880/dav/zotero\nSetting up NGINX After the Apache side is working, we can use nginx as a proxy to get cleaner URIs. In your desired site/location, add this:\n1 2 3 4 5 6 7 location /dav { client_max_body_size 20M; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $remote_addr; proxy_set_header Host $host; proxy_pass http://127.0.0.1:880; } Now just reload nginx:\n1 sudo service nginx force-reload Extras Zotero Reader - HTML5 client Zandy - Android Open Source client ","permalink":"/post/2014-12-09-zotero/","tags":["zotero","webdav","nginx","apache"],"title":"Zotero"},{"categories":null,"contents":"This is a quick note on proxying a local python application (e.g. flask) to a subdirectory in Apache. This assumes that the file wsgi.py contains a WSGI application with the name application. Hence, wsgi:application.\nGunicorn 1 2 3 4 5 \u0026lt;Location /myapp/\u0026gt; ProxyPass http://127.0.0.1:8888/myapp/ ProxyPassReverse http://127.0.0.1:8888/myapp/ RequestHeader set SCRIPT_NAME \u0026#34;/myapp/\u0026#34; \u0026lt;/Location\u0026gt; Important: SCRIPT_NAME and the end of ProxyPass URL MUST BE THE SAME. Otherwise, Gunicorn will fail miserably.\nTry it with:\n1 venv/bin/gunicorn -w 4 -b 127.0.0.1:8888 --log-file - --access-logfile - wsgi:application UWSGI This is a very simple configuration. I will try to upload one with more options for uwsgi (in a .ini file).\n1 2 3 4 \u0026lt;Location /myapp/\u0026gt; SetHandler uwsgi_handler uWSGISocker 127.0.0.1:8888 \u0026lt;/Location\u0026gt; Try it with:\n1 uwsgi --socket 127.0.0.1:8888 -w wsgi:application Extra: Supervisor If everything went as expected, you can wrap your command in a supervisor config file and let it handle the server for you.\n1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 [unix_http_server] file=/tmp/myapp.sock ; path to your socket file [supervisord] logfile = %(here)s/logs/supervisor.log childlogdir = %(here)s/logs/ [rpcinterface:supervisor] supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface [supervisorctl] logfile = %(here)s/logs/supervisorctl.log serverurl=unix:///tmp/supervisor.sock ; use a unix:// URL for a unix socket [program:myapp] command = venv/bin/gunicorn -w 4 -b 0.0.0.0:5000 --log-file %(here)s/logs/gunicorn.log --access-logfile - wsgi:application directory = %(here)s environment = PATH=%(here)s/venv/bin/ logfile = %(here)s/logs/myapp.log ","permalink":"/post/2014-10-09-proxies/","tags":["python","apache","proxy","gunicorn","uwsgi"],"title":"Proxies with Apache and python"},{"categories":null,"contents":"Developing a python module and publishing it on Github is cool, but most of the times you want others to download and use it easily. That is the role of PyPi, the python package repository. In this post I show you how to publish your package in less than 10 minutes.\nChoose a fancy name If you haven\u0026rsquo;t done so yet, take a minute or two to think about this. To publish on PyPi you need a name for your package that isn\u0026rsquo;t taken. What\u0026rsquo;s more, a catchy and unique name will help people remember your module and feel more inclined to at least try it.\nThe package name should hint what your module does, but that\u0026rsquo;s not always the case. That\u0026rsquo;s your call. I personally put uniqueness and memorability over describing the functionality.\nCreate a .pypirc configuration file 1 2 3 4 5 6 7 8 9 10 11 12 13 [distutils] # this tells distutils what package indexes you can push to index-servers =pypi # the live PyPI pypitest # test PyPI [pypi] # authentication details for live PyPI repository = https://pypi.python.org/pypi username = { your_username } password = { your_password } # not necessary [pypitest] # authentication details for test PyPI repository = https://testpypi.python.org/pypi username = { your_username } As you can see, you need to register both in the main pypi repository and the testing server. The usernames and passwords might be different, that is up to you!\nPrepare your package This should be the structure:\nroot-dir/ # Any name you want setup.py setup.cfg LICENSE.txt README.md mypackage/ __init__.py foo.py bar.py baz.py setup.cfg 1 2 [metadata] description-file = README.md The markdown README is the de facto standard in Github, but you can also use rST (reStructuredText), the standard in the python community.\nsetup.py 1 2 3 4 5 6 7 8 9 10 11 12 from distutils.core import setup setup(name = \u0026#39;mypackage\u0026#39;, packages = [\u0026#39;mypackage\u0026#39;], # this must be the same as the name above version = \u0026#39;{ version }\u0026#39;, description = \u0026#39;{ description }\u0026#39;, author = \u0026#39;{ name }\u0026#39;, email = \u0026#39;{ email }\u0026#39;, url = \u0026#39;https://github.com/{user}/{package}\u0026#39;, # URL to the github repo download_url = \u0026#39;https://github.com/{user}/{repo}/tarball/{version}\u0026#39;, keywords = [\u0026#39;websockets\u0026#39;, \u0026#39;display\u0026#39;, \u0026#39;d3\u0026#39;], # list of keywords that represent your package classifiers = [], ) You might notice that the download_url points to a Github URL. We could host our package anywhere, but Github is a convenient option. To create the tarball and the zip packages, you only need to tag a tag in your repository and push it to github:\n1 2 git tag {version} -m \u0026#34;{ Description of this tag/version}\u0026#34; git push --tags origin master Push to the testing/main pypi server It is advisable that you try your package on the test repository and fix any problems first. The process is simple:\n1 python setup.py register -r {pypitest/pypi} python setup.py sdist upload -r {pypitest/pypi} If everything went as expected, you can now install your package through pip and browse your package\u0026rsquo;s page. For instance, check my senpy package: https://pypi.python.org/pypi/senpy\n1 pip install senpy ","permalink":"/post/2014-09-23-publishing-to-pypi/","tags":["github","python","pypi"],"title":"Publishing on PyPi"},{"categories":null,"contents":"As part of the OpeNER hackathon we decided to build a prototype that would allow us to compare how different countries feel about several topics. We used the OpeNER pipeline to get the sentiment from a set of newspaper articles we gathered from media in several languages. Then we aggregated those articles by category and country (using the source of the article or the language it was written in), obtaining the \u0026ldquo;overall feeling\u0026rdquo; of each country about each topic. Then, we used some fancy JavaScript to make sense out of the raw information.\nIt didn\u0026rsquo;t go too bad, it turns out we won.\nNow, it was time for a face-lift. I used this opportunity to play with new technologies and improve it:\n Using Flask, this time using python 3.3 and Bootstrap 3.0 Cool HTML5+JS cards (thanks to pastetophone) Automatic generation of fake personal data to test the interface Obfuscation of personal emails The result can be seen here.\nPublishing a Python 3 app on Heroku 1 mkvirtualenv -p /usr/bin/python3.3 eurolovemap Since Heroku uses python 2.7 by default, we have to tell it which version we want, although it supports python 3.4 as well. I couldn\u0026rsquo;t get python 3.4 working using the deadsnakes ppa, so I used python 3.3 instead, which works fine but is not officially supported. Just create a file named runtime.txt in your project root, with the python version you want to use:\n1 python-3.3.1 Don\u0026rsquo;t forget to freeze your dependencies so Heroku can install them: bash pip freze \u0026gt; requirements.txt\nPublishing personal emails There are really sophisticated and effective ways to obfuscate personal emails so that spammers cannot easily grab yours. However, this time I needed something really simple to hide our emails from the simplest form of crawlers. Most of the team are in academia somehow, so in the end all our emails are available in sites like Google Scholar. Anyway, nobody likes getting spammed so I settled for a custom Caesar cipher. Please, don\u0026rsquo;t use it for any serious application if you are concerned about being spammed.\n1 2 def blur_email(email): return \u0026#34;\u0026#34;.join([chr(ord(i)+5) for i in email]) And this is the client side:\n1 2 3 4 5 6 7 8 9 10 11 12 window.onload = function(){ elems = document.getElementsByClassName(\u0026#39;profile-email\u0026#39;); for(var e in elems){ var blur = elems[e].innerHTML; var email = \u0026#34;\u0026#34;; for(var s in blur){ var a = blur.charCodeAt(s) email = email+String.fromCharCode(a-5); } elems[e].innerHTML = email; } } Unfortunately, this approach does not hide your email from anyone using PhantomJS, ZombieJS or similar. For that, other approaches like generating a picture with the address would be necessary. Nevertheless, it is overkill for a really simple ad-hoc application with custom formatting and just a bunch of emails that would easily be grabbed manually.\nGeneration of fake data To test the contact section of the site, I wanted to populate it with fake data. Fake-Factory is an amazing library that can generate fake data of almost any kind: emails, association names, acronyms\u0026hellip; It even lets you localise the results (get Spanish names, for instance) and generate factories for certain classes (à la Django).\nBut I also wanted pictures, enter Lorem Pixel. With its API you can generate pictures of almost any size, for different topics (e.g. nightlife, people) and with a custom text. You can even use an index, so it will always show the same picture.\nFor instance, the picture below is served through Lorem Pixel.\nBy the way, if you only want cat pictures, take a look at Placekitten. And for NSFW text, there\u0026rsquo;s the Samuel L. Jackson Ipsum\n","permalink":"/post/2014-03-27-updating-eurolovemap/","tags":["javascript","python","heroku"],"title":"Updating EuroLoveMap"},{"categories":null,"contents":"A simple trick. If you want to remove all the \u0026lsquo;.swp\u0026rsquo; files from a git repository, just use:\n1 git rm --cached \u0026#39;**.swp\u0026#39; ","permalink":"/post/2013-08-22-remove-git-files-with-globbing/","tags":["git"],"title":"Remove git files with globbing"},{"categories":null,"contents":"I\u0026rsquo;ve finally decided to set up a decent personal page. I have settled for github-pages because I like the idea of keeping my site in a repository and having someone else host and deploy it for me. The site will be really simple, mostly static files. Thanks to Github, Jekyll will automatically generate static pages for my posts every time I commit anything new to this repository.\nBut Jekyll can be used independently, so if I ever choose to host the site myself, I can do it quite easily. Another thing that I liked about this approach is that the generated html files can be used in the future, and I will not need Jekyll to serve it. Jekyll is really simple and most of the things are written in plain html. That means that everything could be easily reused if I ever choose to change to another blogging framework (e.g. pelical). But, for the time being, I like the fact that Github takes care of the compilation as well, so I can simply modify or add files through the web interface should I need to.\nI hadn\u0026rsquo;t played with HTML and CSS for a while now, so I also wanted to use this site as a playground. At some point, I realised I was doing mostly everything in plain HTML and CSS, and decided to keep it like that for as long as possible. As of this writing, I haven\u0026rsquo;t included any Javascript code in the page. Probably I will use some to add my gists and repositories, but we will see about that.\nI think the code speaks for itself, so you can check out my repository on Github. You can clone and deploy it easily like this:\n1 2 3 git clone https://github.com/balkian/balkian.github.com cd balkian.github.com jekyll serve -w I will keep updating this post with information about:\n Some Jekyll plugins that might be useful What CSS tricks I learnt The webfonts I used The badge on the left side of the page ","permalink":"/post/2013-08-17-creating-my-web/","tags":["starters","javascript","ruby","github","git"],"title":"Creating my web"},{"categories":null,"contents":"Show plain text version 1 (font-lock-mode) ","permalink":"/cheatsheet/emacs/","tags":["emacs","org","productivity","lisp"],"title":"Emacs"},{"categories":null,"contents":"Ongoing Projects Senpy: a framework for semantic sentiment and emotion analysis services. Soil: an agent-based simulator for social networks based on nx-sim and networkx. Onyx: an ontology for emotion analysis that includes concepts from W3C\u0026rsquo;s provenance. Past Projects Marl: I updated this ontology, originally created by Adam Westerski, to make it compatible with the W3C\u0026rsquo;s provenance ontology. Hermes: one of my first projects, developed together with David Pérez as the special custom assignment in one of our courses. Hermes is an affective bot designed to mimic the behavour of humans. It included a plug-in system for its sensors and actuators. The information from its sensors changed its emotional state, which was shown via its actuators. Among others, it could fetch inforation from Twitter or its host system and change the expressions of an external Face made with servo motors or speak via its Text-To-Speech software. For instance, it could detect it was running out of battery, showing a sad face and sending an alerting tweet. You can see it in action in these two youtube videos: Part 1 and Part 2. Maia: the Modular Architecture for Intelligent Agents is an evented agent architecture that aims to update the classical frameworks for intelligent agents with the concepts emerged from the Live Web. EESTEC.net: the Plone based official portal of EESTEC. It has been my first and only experience with Plone. I fixed some bugs and implemented basic features. For more information, check my list of public repositories in Github.\n","permalink":"/project/","tags":null,"title":"Index of projects"},{"categories":null,"contents":"Black screen and LightDM doesn\u0026rsquo;t unlock Add this to your /etc/lightdm/lightdm.conf file:\n1 2 [LightDM] logind-check-graphical=true Edit previous commands fc is a shell builtin to list and edit previous commands in an editor. In addition to editing a single line (which you can also do with C-x C-e), it also allows you to edit and run several lines at the same time. You use it like this:\nList previous commands\n1 2 3 4 5 $ fc -l 10259 nvim deploy.sh 10260* cd .. 10261* nvim content/cheatsheet/linux.md 10262 cd List commands with date (in zsh)\n1 2 3 4 5 $ fc -ld 10260* 19:38 cd .. 10261* 19:38 nvim content/cheatsheet/linux.md 10262 19:40 cd 10263 19:40 fc -l You can add the date too:\n1 2 3 4 $ fc -fld 10262 1/10/2019 19:40 cd 10263 1/10/2019 19:40 fc -l 10264 1/10/2019 19:40 fc -ld You can edit a range of commands\n1 $ fc 10262 10264 The range can be relative to the current position, so the previous command is equivalent to:\n1 $ fc -3 -1 If you save and exit, all commands are executed as a script, and it will be added to your history.\nSource: https://shapeshed.com/unix-fc/\nPrevent logoff from killing tmux sessions Lately I\u0026rsquo;ve noticed that logging out of i3, intentionally or when i3 fails, would also kill any tmux or emacs sessions. This is extremely annoying.\nThis is caused by a new default in logind (systemd\u0026rsquo;s login) to kill user process on logoff. You can revert this setting in your logind.conf (/etc/systemd/logind.conf):\n1 KillUserProcesses=no Or only for a specific process (e.g., tmux):\n1 systemd-run --scope --user tmux Source: https://unix.stackexchange.com/questions/490267/prevent-logoff-from-killing-tmux-session\nUpload a temporary file Sometimes you just need to copy/paste a file from a server, and copying from the terminal can be a hassle. These two services are command-line \u0026ldquo;pastebins\u0026rdquo; just one curl away:\n1 2 3 4 5 6 7 8 \u0026lt;command\u0026gt; | curl -F \u0026#39;sprunge=\u0026lt;-\u0026#39; http://sprunge.us # OR \u0026lt;command\u0026gt; 2\u0026gt;\u0026amp;1 | curl -F \u0026#39;f:1=\u0026lt;-\u0026#39; ix.io # OR \u0026lt;command\u0026gt; | curl -F\u0026#34;file=@-\u0026#34; https://ttm.sh Install Fortinet SSLVPN support for NetworkManager UPM (Universidad Politécnica de Madrid) uses a propriatary VPN solution. The instructions for GNU/Linux on their website involve downloading a specific client (.tar.gz) and manually running it. That works, but it is kind of a hassle. A much more convenient alternative is installing this NetworkManager plugin:\n1 2 pacman -Sy networkmanager-fortisslvpn # Or apt get install networkmanager-fortisslvpn Now you can simply add a new VPN connection in NetworkManager and manage it as you would any other connection.\n","permalink":"/cheatsheet/linux/","tags":["linux","arch"],"title":"Linux"},{"categories":null,"contents":"Interesting libraries TQDM From tqdm\u0026rsquo;s github repository:\n tqdm means \u0026ldquo;progress\u0026rdquo; in Arabic (taqadum, تقدّم) and an abbreviation for \u0026ldquo;I love you so much\u0026rdquo; in Spanish (te quiero demasiado).\n ","permalink":"/cheatsheet/python/","tags":["python","programming"],"title":"Python"},{"categories":null,"contents":"HDMI flickering Avoid HDMI flickering/intermittent blanking on RPI with a 1400x1050 VGA monitor.\n1 2 3 4 5 6 hdmi_drive=2 hdmi_group=2 hdmi_mode=42 disable_overscan=1 config_hdmi_boost=7 ","permalink":"/cheatsheet/rpi/","tags":["rpi"],"title":"Raspberry Pi"},{"categories":null,"contents":"This file exists solely to respond to /search URL with the related search layout template.\nNo content shown here is rendered, all content is based in the template layouts/page/search.html\nSetting a very low sitemap priority will tell search engines this is not important content.\nThis implementation uses Fusejs, jquery and mark.js\nInitial setup Search depends on additional output content type of JSON in config.toml ``` [outputs] home = [\u0026ldquo;HTML\u0026rdquo;, \u0026ldquo;JSON\u0026rdquo;] ```\nSearching additional fileds To search additional fields defined in front matter, you must add it in 2 places.\nEdit layouts/_default/index.JSON This exposes the values in /index.json i.e. add category ``` \u0026hellip; \u0026ldquo;contents\u0026rdquo;:{{ .Content | plainify | jsonify }} {{ if .Params.tags }}, \u0026ldquo;tags\u0026rdquo;:{{ .Params.tags | jsonify }}{{end}}, \u0026ldquo;categories\u0026rdquo; : {{ .Params.categories | jsonify }}, \u0026hellip; ```\nEdit fuse.js options to Search static/js/search.js ``` keys: [ \u0026ldquo;title\u0026rdquo;, \u0026ldquo;contents\u0026rdquo;, \u0026ldquo;tags\u0026rdquo;, \u0026ldquo;categories\u0026rdquo; ] ```\n ${title} ${snippet}\n ","permalink":"/search/","tags":null,"title":"Search Results"},{"categories":null,"contents":"PhD Write my first workshop paper as main author Write my first journal paper Write my first book chapter Chair a W3C Community Group Collaborate on a W3C recommendation Become a doctor! Technical Write a NodeJS App. Maia [See ISSUES] Write my first Django Application Develop a distributed LibP2P golang application Github repo with +100 stars Build a custom LineageOS image Languages English Chinese Greek German Esperanto Personal Run a 10k Blog regularly for a year ","permalink":"/page/todo/","tags":null,"title":"To-do"}]
\ No newline at end of file
diff --git a/index.xml b/index.xml
index b7f7206..c95a6f5 100644
--- a/index.xml
+++ b/index.xml
@@ -7,7 +7,21 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Sat, 01 Jun 2019 00:00:01 +0000
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+
+
+
+
+ Logitech MX Keys for Mac on Linux
+ /post/2021-10-29-logitech-mx-keys-mac/
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+ /post/2021-10-29-logitech-mx-keys-mac/
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
+
Linux on the Microsoft Surface Go
/post/2019-05-01-surface-go/
@@ -195,4 +209,4 @@ This implementation uses Fusejs, jquery and mark.
-
+
\ No newline at end of file
diff --git a/page/1/index.html b/page/1/index.html
index 7a1d5b2..6926291 100644
--- a/page/1/index.html
+++ b/page/1/index.html
@@ -1 +1 @@
-/
\ No newline at end of file
+/
\ No newline at end of file
diff --git a/page/2/index.html b/page/2/index.html
index 394356e..afaf8f2 100644
--- a/page/2/index.html
+++ b/page/2/index.html
@@ -1,7 +1,7 @@
-
+
Balkian's site - Balkian's site
@@ -56,6 +56,29 @@
+
+
+ Zotero is an Open Source tool that lets you organise your bibliography, syncing it with the cloud. Unlike other alternatives such as Mendeley, Zotero can upload the attachments and data to a private cloud via WebDav.
+If you use nginx as your web server, know that even though it provides partial support for webdav, Zotero needs more than that.
+
-
- I’ve finally decided to set up a decent personal page. I have settled for github-pages because I like the idea of keeping my site in a repository and having someone else host and deploy it for me. The site will be really simple, mostly static files. Thanks to Github, Jekyll will automatically generate static pages for my posts every time I commit anything new to this repository.
-
+
+ I’ve finally decided to set up a decent personal page. I have settled for github-pages because I like the idea of keeping my site in a repository and having someone else host and deploy it for me. The site will be really simple, mostly static files. Thanks to Github, Jekyll will automatically generate static pages for my posts every time I commit anything new to this repository.
+
+ Linux user
+ Android dev and user
+ Github user
+ GitLab user
+ StackExchange fan
+ Music lover
+ Movie fan
+ Always on a PC
+ Night owl
+ CLI user
+ I love languages
+ I love programming
+
diff --git a/page/index.xml b/page/index.xml
index 111b5f4..49173cc 100644
--- a/page/index.xml
+++ b/page/index.xml
@@ -6,7 +6,11 @@
Recent content in Pages on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
To-do
/page/todo/
@@ -17,4 +21,4 @@
-
+
\ No newline at end of file
diff --git a/page/page/1/index.html b/page/page/1/index.html
index 2af228d..b19c856 100644
--- a/page/page/1/index.html
+++ b/page/page/1/index.html
@@ -1 +1 @@
-/page/
\ No newline at end of file
+/page/
\ No newline at end of file
diff --git a/page/todo/index.html b/page/todo/index.html
index d2d846d..7006f49 100644
--- a/page/todo/index.html
+++ b/page/todo/index.html
@@ -132,6 +132,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/post/2014-03-27-updating-eurolovemap/index.html b/post/2014-03-27-updating-eurolovemap/index.html
index 0bef7e3..4438276 100644
--- a/post/2014-03-27-updating-eurolovemap/index.html
+++ b/post/2014-03-27-updating-eurolovemap/index.html
@@ -234,6 +234,17 @@ an index, so it will always show the same picture.
+
I recently got Logitech MX Keys for Mac keyboard at work.
+The German version, to be more precise.
+This version was three times cheaper than the Windows equivalent with either US or ES layout.
+Since I touch type anyway, I thought it was a bargain.
+
As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+First of all, the Meta/Super and Alt keys are reversed in this keyboard.
+In the normal/full version of this keyboard, Logitech gives an option to choose between Mac, Windows and iOS host, and that changes the behavior of the keys.
+In this version, tho, only iOS and Mac are available.
+
Besides that, there’s the issue of the grave (tilde) and angle keys switched as well.
+
Switching these keys around would be very easy with Xorg, but Wayland once again complicates things…
+
These issues almost made me return the keyboard.
+Luckily, tho, there is another option: configuring the keys one level lower than wayland (and X11), through hwdb.
+
Long story short, this will configure any Logitech keyboard with the same product id (0x4092) to use a saner configuration:
+ Linux user
+ Android dev and user
+ Github user
+ GitLab user
+ StackExchange fan
+ Music lover
+ Movie fan
+ Always on a PC
+ Night owl
+ CLI user
+ I love languages
+ I love programming
+
+
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
-
- Zotero is an Open Source tool that lets you organise your bibliography, syncing it with the cloud. Unlike other alternatives such as Mendeley, Zotero can upload the attachments and data to a private cloud via WebDav.
-If you use nginx as your web server, know that even though it provides partial support for webdav, Zotero needs more than that.
-
diff --git a/post/index.xml b/post/index.xml
index f936088..aca06e4 100644
--- a/post/index.xml
+++ b/post/index.xml
@@ -7,7 +7,21 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Sat, 01 Jun 2019 00:00:01 +0000
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+
+
+
+
+ Logitech MX Keys for Mac on Linux
+ /post/2021-10-29-logitech-mx-keys-mac/
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+ /post/2021-10-29-logitech-mx-keys-mac/
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
+
Linux on the Microsoft Surface Go
/post/2019-05-01-surface-go/
@@ -125,4 +139,4 @@ a WSGI application with the name <em>application</em>. Hence, wsgi:a
-
+
\ No newline at end of file
diff --git a/post/page/1/index.html b/post/page/1/index.html
index 83b55b0..5887d0a 100644
--- a/post/page/1/index.html
+++ b/post/page/1/index.html
@@ -1 +1 @@
-/post/
\ No newline at end of file
+/post/
\ No newline at end of file
diff --git a/post/page/2/index.html b/post/page/2/index.html
index 2257a3e..fff86d1 100644
--- a/post/page/2/index.html
+++ b/post/page/2/index.html
@@ -55,6 +55,29 @@
+
+
+ Zotero is an Open Source tool that lets you organise your bibliography, syncing it with the cloud. Unlike other alternatives such as Mendeley, Zotero can upload the attachments and data to a private cloud via WebDav.
+If you use nginx as your web server, know that even though it provides partial support for webdav, Zotero needs more than that.
+
-
- I’ve finally decided to set up a decent personal page. I have settled for github-pages because I like the idea of keeping my site in a repository and having someone else host and deploy it for me. The site will be really simple, mostly static files. Thanks to Github, Jekyll will automatically generate static pages for my posts every time I commit anything new to this repository.
-
+
+ I’ve finally decided to set up a decent personal page. I have settled for github-pages because I like the idea of keeping my site in a repository and having someone else host and deploy it for me. The site will be really simple, mostly static files. Thanks to Github, Jekyll will automatically generate static pages for my posts every time I commit anything new to this repository.
+
+ Linux user
+ Android dev and user
+ Github user
+ GitLab user
+ StackExchange fan
+ Music lover
+ Movie fan
+ Always on a PC
+ Night owl
+ CLI user
+ I love languages
+ I love programming
+
diff --git a/posts/index.xml b/posts/index.xml
index 971fefc..1605ea5 100644
--- a/posts/index.xml
+++ b/posts/index.xml
@@ -6,6 +6,10 @@
Recent content in Posts on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
-
+
\ No newline at end of file
diff --git a/project/index.html b/project/index.html
index c8664a0..6fa4414 100644
--- a/project/index.html
+++ b/project/index.html
@@ -116,6 +116,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/apache/index.xml b/tags/apache/index.xml
index 4995b41..b9170f4 100644
--- a/tags/apache/index.xml
+++ b/tags/apache/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Tue, 09 Dec 2014 12:12:12 +0000
+ Tue, 09 Dec 2014 12:12:12 +0000
+
+
+
+
Zotero
/post/2014-12-09-zotero/
@@ -48,4 +52,4 @@ a WSGI application with the name <em>application</em>. Hence, wsgi:a
-
+
\ No newline at end of file
diff --git a/tags/apache/page/1/index.html b/tags/apache/page/1/index.html
index f9ac2cd..9aba95e 100644
--- a/tags/apache/page/1/index.html
+++ b/tags/apache/page/1/index.html
@@ -1 +1 @@
-/tags/apache/
\ No newline at end of file
+/tags/apache/
\ No newline at end of file
diff --git a/tags/arch/index.html b/tags/arch/index.html
index 2a9fc57..052d72c 100644
--- a/tags/arch/index.html
+++ b/tags/arch/index.html
@@ -129,6 +129,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/arch/index.xml b/tags/arch/index.xml
index fd6daf6..2fd1401 100644
--- a/tags/arch/index.xml
+++ b/tags/arch/index.xml
@@ -6,7 +6,11 @@
Recent content in arch on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
Linux
/cheatsheet/linux/
@@ -18,4 +22,4 @@
-
+
\ No newline at end of file
diff --git a/tags/arch/page/1/index.html b/tags/arch/page/1/index.html
index c44b261..97c0bbb 100644
--- a/tags/arch/page/1/index.html
+++ b/tags/arch/page/1/index.html
@@ -1 +1 @@
-/tags/arch/
\ No newline at end of file
+/tags/arch/
\ No newline at end of file
diff --git a/tags/config/index.html b/tags/config/index.html
index f39b623..b4f6793 100644
--- a/tags/config/index.html
+++ b/tags/config/index.html
@@ -135,6 +135,17 @@ These are some useful notes to get Ubuntu installed in your surface go, as of Su
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/config/index.xml b/tags/config/index.xml
index 1b18819..cc192f3 100644
--- a/tags/config/index.xml
+++ b/tags/config/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Sat, 01 Jun 2019 00:00:01 +0000
+ Sat, 01 Jun 2019 00:00:01 +0000
+
+
+
+
Linux on the Microsoft Surface Go
/post/2019-05-01-surface-go/
@@ -19,4 +23,4 @@ These are some useful notes to get Ubuntu installed in your surface go, as of Su
-
+
\ No newline at end of file
diff --git a/tags/config/page/1/index.html b/tags/config/page/1/index.html
index 79a7f20..b160f31 100644
--- a/tags/config/page/1/index.html
+++ b/tags/config/page/1/index.html
@@ -1 +1 @@
-/tags/config/
\ No newline at end of file
+/tags/config/
\ No newline at end of file
diff --git a/tags/dotfiles/index.html b/tags/dotfiles/index.html
index 8a4cbbe..0f89c05 100644
--- a/tags/dotfiles/index.html
+++ b/tags/dotfiles/index.html
@@ -135,6 +135,17 @@ As part of moving to emacs, I starting using the incredibly useful gh.el. When y
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/dotfiles/index.xml b/tags/dotfiles/index.xml
index 73560c0..db071eb 100644
--- a/tags/dotfiles/index.xml
+++ b/tags/dotfiles/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Fri, 10 Apr 2015 17:47:00 +0000
+ Fri, 10 Apr 2015 17:47:00 +0000
+
+
+
+
Sharing dotfiles
/post/2015-04-10-github-dotfiles/
@@ -19,4 +23,4 @@ As part of moving to emacs, I starting using the incredibly useful gh.el. When y
-
+
\ No newline at end of file
diff --git a/tags/dotfiles/page/1/index.html b/tags/dotfiles/page/1/index.html
index 1147229..d5410a5 100644
--- a/tags/dotfiles/page/1/index.html
+++ b/tags/dotfiles/page/1/index.html
@@ -1 +1 @@
-/tags/dotfiles/
\ No newline at end of file
+/tags/dotfiles/
\ No newline at end of file
diff --git a/tags/emacs/index.html b/tags/emacs/index.html
index 51beefa..d8e0135 100644
--- a/tags/emacs/index.html
+++ b/tags/emacs/index.html
@@ -133,6 +133,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/emacs/index.xml b/tags/emacs/index.xml
index 1d5c15e..e019d2d 100644
--- a/tags/emacs/index.xml
+++ b/tags/emacs/index.xml
@@ -6,7 +6,11 @@
Recent content in emacs on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
Emacs
/cheatsheet/emacs/
@@ -17,4 +21,4 @@
-
+
\ No newline at end of file
diff --git a/tags/emacs/page/1/index.html b/tags/emacs/page/1/index.html
index 2452935..dc952aa 100644
--- a/tags/emacs/page/1/index.html
+++ b/tags/emacs/page/1/index.html
@@ -1 +1 @@
-/tags/emacs/
\ No newline at end of file
+/tags/emacs/
\ No newline at end of file
diff --git a/tags/git/index.html b/tags/git/index.html
index 519d324..c290b7f 100644
--- a/tags/git/index.html
+++ b/tags/git/index.html
@@ -184,6 +184,17 @@ repository, just use:
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/git/index.xml b/tags/git/index.xml
index 67778e6..dcb3b68 100644
--- a/tags/git/index.xml
+++ b/tags/git/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Fri, 10 Apr 2015 17:47:00 +0000
+ Fri, 10 Apr 2015 17:47:00 +0000
+
+
+
+
Sharing dotfiles
/post/2015-04-10-github-dotfiles/
@@ -38,4 +42,4 @@ As part of moving to emacs, I starting using the incredibly useful gh.el. When y
-
+
\ No newline at end of file
diff --git a/tags/git/page/1/index.html b/tags/git/page/1/index.html
index 4701ff5..0432cba 100644
--- a/tags/git/page/1/index.html
+++ b/tags/git/page/1/index.html
@@ -1 +1 @@
-/tags/git/
\ No newline at end of file
+/tags/git/
\ No newline at end of file
diff --git a/tags/github/index.html b/tags/github/index.html
index f058a48..572cc2a 100644
--- a/tags/github/index.html
+++ b/tags/github/index.html
@@ -179,6 +179,17 @@ As part of moving to emacs, I starting using the incredibly useful gh.el. When y
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/github/index.xml b/tags/github/index.xml
index 363dc23..6bc2266 100644
--- a/tags/github/index.xml
+++ b/tags/github/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Fri, 10 Apr 2015 17:47:00 +0000
+ Fri, 10 Apr 2015 17:47:00 +0000
+
+
+
+
Sharing dotfiles
/post/2015-04-10-github-dotfiles/
@@ -37,4 +41,4 @@ As part of moving to emacs, I starting using the incredibly useful gh.el. When y
-
+
\ No newline at end of file
diff --git a/tags/github/page/1/index.html b/tags/github/page/1/index.html
index 4cd1dcf..d99716f 100644
--- a/tags/github/page/1/index.html
+++ b/tags/github/page/1/index.html
@@ -1 +1 @@
-/tags/github/
\ No newline at end of file
+/tags/github/
\ No newline at end of file
diff --git a/tags/gunicorn/index.html b/tags/gunicorn/index.html
index 19f6c36..91c7edf 100644
--- a/tags/gunicorn/index.html
+++ b/tags/gunicorn/index.html
@@ -158,6 +158,17 @@ a WSGI application with the name application. Hence, wsgi:application.<
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/gunicorn/index.xml b/tags/gunicorn/index.xml
index 69a9cb8..299b88a 100644
--- a/tags/gunicorn/index.xml
+++ b/tags/gunicorn/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Thu, 09 Oct 2014 10:00:00 +0000
+ Thu, 09 Oct 2014 10:00:00 +0000
+
+
+
+
Proxies with Apache and python
/post/2014-10-09-proxies/
@@ -38,4 +42,4 @@ a WSGI application with the name <em>application</em>. Hence, wsgi:a
-
+
\ No newline at end of file
diff --git a/tags/gunicorn/page/1/index.html b/tags/gunicorn/page/1/index.html
index 57cef7f..4edcf3b 100644
--- a/tags/gunicorn/page/1/index.html
+++ b/tags/gunicorn/page/1/index.html
@@ -1 +1 @@
-/tags/gunicorn/
\ No newline at end of file
+/tags/gunicorn/
\ No newline at end of file
diff --git a/tags/heroku/index.html b/tags/heroku/index.html
index 7c0e237..d2ecce6 100644
--- a/tags/heroku/index.html
+++ b/tags/heroku/index.html
@@ -134,6 +134,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/iot/index.xml b/tags/iot/index.xml
index 267ec72..1d17ccd 100644
--- a/tags/iot/index.xml
+++ b/tags/iot/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Sun, 06 Jan 2019 10:00:00 +0000
+ Sun, 06 Jan 2019 10:00:00 +0000
+
+
+
+
Controlling Zigbee devices with MQTT
/post/2019-01-06-zigbee2mqtt/
@@ -19,4 +23,4 @@ If you’re anything like me, you’re probably a sucker for IoT
-
+
\ No newline at end of file
diff --git a/tags/iot/page/1/index.html b/tags/iot/page/1/index.html
index e4bc0de..8b01d33 100644
--- a/tags/iot/page/1/index.html
+++ b/tags/iot/page/1/index.html
@@ -1 +1 @@
-/tags/iot/
\ No newline at end of file
+/tags/iot/
\ No newline at end of file
diff --git a/tags/javascript/index.html b/tags/javascript/index.html
index dbdd701..2370d1b 100644
--- a/tags/javascript/index.html
+++ b/tags/javascript/index.html
@@ -158,6 +158,17 @@
+
+
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
+ Linux user
+ Android dev and user
+ Github user
+ GitLab user
+ StackExchange fan
+ Music lover
+ Movie fan
+ Always on a PC
+ Night owl
+ CLI user
+ I love languages
+ I love programming
+
+
+
+
+
+
+
diff --git a/tags/keyboard/index.xml b/tags/keyboard/index.xml
new file mode 100644
index 0000000..3fa9ae4
--- /dev/null
+++ b/tags/keyboard/index.xml
@@ -0,0 +1,26 @@
+
+
+
+ keyboard on Balkian's site
+ /tags/keyboard/
+ Recent content in keyboard on Balkian's site
+ Hugo -- gohugo.io
+ en-us
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+
+
+
+
+ Logitech MX Keys for Mac on Linux
+ /post/2021-10-29-logitech-mx-keys-mac/
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+ /post/2021-10-29-logitech-mx-keys-mac/
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
+
+
+
\ No newline at end of file
diff --git a/tags/keyboard/page/1/index.html b/tags/keyboard/page/1/index.html
new file mode 100644
index 0000000..91cac87
--- /dev/null
+++ b/tags/keyboard/page/1/index.html
@@ -0,0 +1 @@
+/tags/keyboard/
\ No newline at end of file
diff --git a/tags/linux/index.html b/tags/linux/index.html
index 2f37830..ed36a36 100644
--- a/tags/linux/index.html
+++ b/tags/linux/index.html
@@ -55,6 +55,27 @@
+
+
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
diff --git a/tags/linux/index.xml b/tags/linux/index.xml
index 302cb02..4add648 100644
--- a/tags/linux/index.xml
+++ b/tags/linux/index.xml
@@ -7,7 +7,21 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Sat, 01 Jun 2019 00:00:01 +0000
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+
+
+
+
+ Logitech MX Keys for Mac on Linux
+ /post/2021-10-29-logitech-mx-keys-mac/
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+ /post/2021-10-29-logitech-mx-keys-mac/
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
+
Linux on the Microsoft Surface Go
/post/2019-05-01-surface-go/
@@ -29,4 +43,4 @@ These are some useful notes to get Ubuntu installed in your surface go, as of Su
-
+
\ No newline at end of file
diff --git a/tags/linux/page/1/index.html b/tags/linux/page/1/index.html
index d75b293..82150f6 100644
--- a/tags/linux/page/1/index.html
+++ b/tags/linux/page/1/index.html
@@ -1 +1 @@
-/tags/linux/
\ No newline at end of file
+/tags/linux/
\ No newline at end of file
diff --git a/tags/lisp/index.html b/tags/lisp/index.html
index 5518b99..548ce09 100644
--- a/tags/lisp/index.html
+++ b/tags/lisp/index.html
@@ -133,6 +133,17 @@
+
diff --git a/tags/lisp/index.xml b/tags/lisp/index.xml
index 43097c6..0ca6e3a 100644
--- a/tags/lisp/index.xml
+++ b/tags/lisp/index.xml
@@ -6,7 +6,11 @@
Recent content in lisp on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
Emacs
/cheatsheet/emacs/
@@ -17,4 +21,4 @@
-
+
\ No newline at end of file
diff --git a/tags/lisp/page/1/index.html b/tags/lisp/page/1/index.html
index 00e5e88..1dbe46b 100644
--- a/tags/lisp/page/1/index.html
+++ b/tags/lisp/page/1/index.html
@@ -1 +1 @@
-/tags/lisp/
\ No newline at end of file
+/tags/lisp/
\ No newline at end of file
diff --git a/tags/logitech/index.html b/tags/logitech/index.html
new file mode 100644
index 0000000..488135f
--- /dev/null
+++ b/tags/logitech/index.html
@@ -0,0 +1,209 @@
+
+
+
+
+
+ Balkian's site - logitech
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
+ Linux user
+ Android dev and user
+ Github user
+ GitLab user
+ StackExchange fan
+ Music lover
+ Movie fan
+ Always on a PC
+ Night owl
+ CLI user
+ I love languages
+ I love programming
+
+
+
+
+
+
+
diff --git a/tags/logitech/index.xml b/tags/logitech/index.xml
new file mode 100644
index 0000000..bceaaee
--- /dev/null
+++ b/tags/logitech/index.xml
@@ -0,0 +1,26 @@
+
+
+
+ logitech on Balkian's site
+ /tags/logitech/
+ Recent content in logitech on Balkian's site
+ Hugo -- gohugo.io
+ en-us
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+
+
+
+
+ Logitech MX Keys for Mac on Linux
+ /post/2021-10-29-logitech-mx-keys-mac/
+ Fri, 29 Oct 2021 00:00:01 +0000
+
+ /post/2021-10-29-logitech-mx-keys-mac/
+ I recently got Logitech MX Keys for Mac keyboard at work. The German version, to be more precise. This version was three times cheaper than the Windows equivalent with either US or ES layout. Since I touch type anyway, I thought it was a bargain.
+As soon as I plugged it in, I realized there were some glaring issues with the keyboard.
+
+
+
+
\ No newline at end of file
diff --git a/tags/logitech/page/1/index.html b/tags/logitech/page/1/index.html
new file mode 100644
index 0000000..cd7dc7a
--- /dev/null
+++ b/tags/logitech/page/1/index.html
@@ -0,0 +1 @@
+/tags/logitech/
\ No newline at end of file
diff --git a/tags/mqtt/index.html b/tags/mqtt/index.html
index 1a5b6f3..0a7d0a5 100644
--- a/tags/mqtt/index.html
+++ b/tags/mqtt/index.html
@@ -135,6 +135,17 @@ If you’re anything like me, you’re probably a sucker for IoT devices. For a
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/mqtt/index.xml b/tags/mqtt/index.xml
index 6516357..d946737 100644
--- a/tags/mqtt/index.xml
+++ b/tags/mqtt/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Sun, 06 Jan 2019 10:00:00 +0000
+ Sun, 06 Jan 2019 10:00:00 +0000
+
+
+
+
Controlling Zigbee devices with MQTT
/post/2019-01-06-zigbee2mqtt/
@@ -19,4 +23,4 @@ If you’re anything like me, you’re probably a sucker for IoT
-
+
\ No newline at end of file
diff --git a/tags/mqtt/page/1/index.html b/tags/mqtt/page/1/index.html
index ee4a855..4d4e1e2 100644
--- a/tags/mqtt/page/1/index.html
+++ b/tags/mqtt/page/1/index.html
@@ -1 +1 @@
-/tags/mqtt/
\ No newline at end of file
+/tags/mqtt/
\ No newline at end of file
diff --git a/tags/nginx/index.html b/tags/nginx/index.html
index 924bd94..559468c 100644
--- a/tags/nginx/index.html
+++ b/tags/nginx/index.html
@@ -137,6 +137,17 @@ If you use nginx as your web server, know that even though it provides partial s
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/nginx/index.xml b/tags/nginx/index.xml
index e3696e7..b5f3aca 100644
--- a/tags/nginx/index.xml
+++ b/tags/nginx/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Tue, 09 Dec 2014 12:12:12 +0000
+ Tue, 09 Dec 2014 12:12:12 +0000
+
+
+
+
Zotero
/post/2014-12-09-zotero/
@@ -19,4 +23,4 @@ If you use nginx as your web server, know that even though it provides partial s
-
+
\ No newline at end of file
diff --git a/tags/nginx/page/1/index.html b/tags/nginx/page/1/index.html
index 285c114..61faa4e 100644
--- a/tags/nginx/page/1/index.html
+++ b/tags/nginx/page/1/index.html
@@ -1 +1 @@
-/tags/nginx/
\ No newline at end of file
+/tags/nginx/
\ No newline at end of file
diff --git a/tags/org/index.html b/tags/org/index.html
index f4138e6..283d408 100644
--- a/tags/org/index.html
+++ b/tags/org/index.html
@@ -133,6 +133,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/org/index.xml b/tags/org/index.xml
index 5032558..10ee139 100644
--- a/tags/org/index.xml
+++ b/tags/org/index.xml
@@ -6,7 +6,11 @@
Recent content in org on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
Emacs
/cheatsheet/emacs/
@@ -17,4 +21,4 @@
-
+
\ No newline at end of file
diff --git a/tags/org/page/1/index.html b/tags/org/page/1/index.html
index a0f44cc..cca160a 100644
--- a/tags/org/page/1/index.html
+++ b/tags/org/page/1/index.html
@@ -1 +1 @@
-/tags/org/
\ No newline at end of file
+/tags/org/
\ No newline at end of file
diff --git a/tags/productivity/index.html b/tags/productivity/index.html
index 33a5c29..f298b3a 100644
--- a/tags/productivity/index.html
+++ b/tags/productivity/index.html
@@ -133,6 +133,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/productivity/index.xml b/tags/productivity/index.xml
index d4d03d5..15f958a 100644
--- a/tags/productivity/index.xml
+++ b/tags/productivity/index.xml
@@ -6,7 +6,11 @@
Recent content in productivity on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
Emacs
/cheatsheet/emacs/
@@ -17,4 +21,4 @@
-
+
\ No newline at end of file
diff --git a/tags/productivity/page/1/index.html b/tags/productivity/page/1/index.html
index 44ba0d8..409e2ca 100644
--- a/tags/productivity/page/1/index.html
+++ b/tags/productivity/page/1/index.html
@@ -1 +1 @@
-/tags/productivity/
\ No newline at end of file
+/tags/productivity/
\ No newline at end of file
diff --git a/tags/programming/index.html b/tags/programming/index.html
index 1d9be01..2252411 100644
--- a/tags/programming/index.html
+++ b/tags/programming/index.html
@@ -129,6 +129,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/programming/index.xml b/tags/programming/index.xml
index f0a25c8..b7c769a 100644
--- a/tags/programming/index.xml
+++ b/tags/programming/index.xml
@@ -6,7 +6,11 @@
Recent content in programming on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
Python
/cheatsheet/python/
@@ -19,4 +23,4 @@
-
+
\ No newline at end of file
diff --git a/tags/programming/page/1/index.html b/tags/programming/page/1/index.html
index f35bca8..425c13b 100644
--- a/tags/programming/page/1/index.html
+++ b/tags/programming/page/1/index.html
@@ -1 +1 @@
-/tags/programming/
\ No newline at end of file
+/tags/programming/
\ No newline at end of file
diff --git a/tags/proxy/index.html b/tags/proxy/index.html
index 5713c08..a3104a7 100644
--- a/tags/proxy/index.html
+++ b/tags/proxy/index.html
@@ -158,6 +158,17 @@ a WSGI application with the name application. Hence, wsgi:application.<
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/proxy/index.xml b/tags/proxy/index.xml
index ba3c5f0..822ac68 100644
--- a/tags/proxy/index.xml
+++ b/tags/proxy/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Thu, 09 Oct 2014 10:00:00 +0000
+ Thu, 09 Oct 2014 10:00:00 +0000
+
+
+
+
Proxies with Apache and python
/post/2014-10-09-proxies/
@@ -38,4 +42,4 @@ a WSGI application with the name <em>application</em>. Hence, wsgi:a
-
+
\ No newline at end of file
diff --git a/tags/proxy/page/1/index.html b/tags/proxy/page/1/index.html
index 5fb3d8c..796882c 100644
--- a/tags/proxy/page/1/index.html
+++ b/tags/proxy/page/1/index.html
@@ -1 +1 @@
-/tags/proxy/
\ No newline at end of file
+/tags/proxy/
\ No newline at end of file
diff --git a/tags/pypi/index.html b/tags/pypi/index.html
index 6fef30c..c99e24a 100644
--- a/tags/pypi/index.html
+++ b/tags/pypi/index.html
@@ -134,6 +134,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/pypi/index.xml b/tags/pypi/index.xml
index 76fe9b0..4de0af3 100644
--- a/tags/pypi/index.xml
+++ b/tags/pypi/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Sat, 27 Sep 2014 10:00:00 +0000
+ Sat, 27 Sep 2014 10:00:00 +0000
+
+
+
+
Publishing on PyPi
/post/2014-09-23-publishing-to-pypi/
@@ -18,4 +22,4 @@
-
+
\ No newline at end of file
diff --git a/tags/pypi/page/1/index.html b/tags/pypi/page/1/index.html
index c1cc2d1..ee9cf03 100644
--- a/tags/pypi/page/1/index.html
+++ b/tags/pypi/page/1/index.html
@@ -1 +1 @@
-/tags/pypi/
\ No newline at end of file
+/tags/pypi/
\ No newline at end of file
diff --git a/tags/python/index.html b/tags/python/index.html
index 82f69ce..eadb1cb 100644
--- a/tags/python/index.html
+++ b/tags/python/index.html
@@ -247,6 +247,17 @@ a WSGI application with the name application. Hence, wsgi:application.<
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/rpi/index.xml b/tags/rpi/index.xml
index bca55ba..d6f3a54 100644
--- a/tags/rpi/index.xml
+++ b/tags/rpi/index.xml
@@ -6,7 +6,11 @@
Recent content in rpi on Balkian's siteHugo -- gohugo.ioen-us
- This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+ This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
+
+
+
+
Raspberry Pi
/cheatsheet/rpi/
@@ -18,4 +22,4 @@
-
+
\ No newline at end of file
diff --git a/tags/rpi/page/1/index.html b/tags/rpi/page/1/index.html
index 9b84ddf..91e06cd 100644
--- a/tags/rpi/page/1/index.html
+++ b/tags/rpi/page/1/index.html
@@ -1 +1 @@
-/tags/rpi/
\ No newline at end of file
+/tags/rpi/
\ No newline at end of file
diff --git a/tags/ruby/index.html b/tags/ruby/index.html
index bd08ffe..1cb180e 100644
--- a/tags/ruby/index.html
+++ b/tags/ruby/index.html
@@ -138,6 +138,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/ruby/index.xml b/tags/ruby/index.xml
index 4559163..0bb858f 100644
--- a/tags/ruby/index.xml
+++ b/tags/ruby/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Thu, 22 Aug 2013 14:14:22 +0000
+ Thu, 22 Aug 2013 14:14:22 +0000
+
+
+
+
Creating my web
/post/2013-08-17-creating-my-web/
@@ -18,4 +22,4 @@
-
+
\ No newline at end of file
diff --git a/tags/ruby/page/1/index.html b/tags/ruby/page/1/index.html
index c75d1b9..e1d1435 100644
--- a/tags/ruby/page/1/index.html
+++ b/tags/ruby/page/1/index.html
@@ -1 +1 @@
-/tags/ruby/
\ No newline at end of file
+/tags/ruby/
\ No newline at end of file
diff --git a/tags/starters/index.html b/tags/starters/index.html
index de61051..d254839 100644
--- a/tags/starters/index.html
+++ b/tags/starters/index.html
@@ -138,6 +138,17 @@
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/starters/index.xml b/tags/starters/index.xml
index 8f39d02..6ff4b83 100644
--- a/tags/starters/index.xml
+++ b/tags/starters/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Thu, 22 Aug 2013 14:14:22 +0000
+ Thu, 22 Aug 2013 14:14:22 +0000
+
+
+
+
Creating my web
/post/2013-08-17-creating-my-web/
@@ -18,4 +22,4 @@
-
+
\ No newline at end of file
diff --git a/tags/starters/page/1/index.html b/tags/starters/page/1/index.html
index 92ab479..efd305f 100644
--- a/tags/starters/page/1/index.html
+++ b/tags/starters/page/1/index.html
@@ -1 +1 @@
-/tags/starters/
\ No newline at end of file
+/tags/starters/
\ No newline at end of file
diff --git a/tags/surface-go/index.html b/tags/surface-go/index.html
index e0a9616..4faba23 100644
--- a/tags/surface-go/index.html
+++ b/tags/surface-go/index.html
@@ -135,6 +135,17 @@ These are some useful notes to get Ubuntu installed in your surface go, as of Su
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/surface-go/index.xml b/tags/surface-go/index.xml
index 75f8197..c357da6 100644
--- a/tags/surface-go/index.xml
+++ b/tags/surface-go/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Sat, 01 Jun 2019 00:00:01 +0000
+ Sat, 01 Jun 2019 00:00:01 +0000
+
+
+
+
Linux on the Microsoft Surface Go
/post/2019-05-01-surface-go/
@@ -19,4 +23,4 @@ These are some useful notes to get Ubuntu installed in your surface go, as of Su
-
+
\ No newline at end of file
diff --git a/tags/surface-go/page/1/index.html b/tags/surface-go/page/1/index.html
index f841c90..100befc 100644
--- a/tags/surface-go/page/1/index.html
+++ b/tags/surface-go/page/1/index.html
@@ -1 +1 @@
-/tags/surface-go/
\ No newline at end of file
+/tags/surface-go/
\ No newline at end of file
diff --git a/tags/uwsgi/index.html b/tags/uwsgi/index.html
index b7d971c..15852e6 100644
--- a/tags/uwsgi/index.html
+++ b/tags/uwsgi/index.html
@@ -158,6 +158,17 @@ a WSGI application with the name application. Hence, wsgi:application.<
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/uwsgi/index.xml b/tags/uwsgi/index.xml
index f5a30ad..1662137 100644
--- a/tags/uwsgi/index.xml
+++ b/tags/uwsgi/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Thu, 09 Oct 2014 10:00:00 +0000
+ Thu, 09 Oct 2014 10:00:00 +0000
+
+
+
+
Proxies with Apache and python
/post/2014-10-09-proxies/
@@ -38,4 +42,4 @@ a WSGI application with the name <em>application</em>. Hence, wsgi:a
-
+
\ No newline at end of file
diff --git a/tags/uwsgi/page/1/index.html b/tags/uwsgi/page/1/index.html
index 12849e3..b5adf63 100644
--- a/tags/uwsgi/page/1/index.html
+++ b/tags/uwsgi/page/1/index.html
@@ -1 +1 @@
-/tags/uwsgi/
\ No newline at end of file
+/tags/uwsgi/
\ No newline at end of file
diff --git a/tags/webdav/index.html b/tags/webdav/index.html
index 2fb020b..b055967 100644
--- a/tags/webdav/index.html
+++ b/tags/webdav/index.html
@@ -137,6 +137,17 @@ If you use nginx as your web server, know that even though it provides partial s
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/webdav/index.xml b/tags/webdav/index.xml
index 5896165..0f243e9 100644
--- a/tags/webdav/index.xml
+++ b/tags/webdav/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Tue, 09 Dec 2014 12:12:12 +0000
+ Tue, 09 Dec 2014 12:12:12 +0000
+
+
+
+
Zotero
/post/2014-12-09-zotero/
@@ -19,4 +23,4 @@ If you use nginx as your web server, know that even though it provides partial s
-
+
\ No newline at end of file
diff --git a/tags/webdav/page/1/index.html b/tags/webdav/page/1/index.html
index 04d8257..e4eb112 100644
--- a/tags/webdav/page/1/index.html
+++ b/tags/webdav/page/1/index.html
@@ -1 +1 @@
-/tags/webdav/
\ No newline at end of file
+/tags/webdav/
\ No newline at end of file
diff --git a/tags/zigbee/index.html b/tags/zigbee/index.html
index 80d09c3..dd25aa8 100644
--- a/tags/zigbee/index.html
+++ b/tags/zigbee/index.html
@@ -135,6 +135,17 @@ If you’re anything like me, you’re probably a sucker for IoT devices. For a
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/zigbee/index.xml b/tags/zigbee/index.xml
index 543de0d..70cd158 100644
--- a/tags/zigbee/index.xml
+++ b/tags/zigbee/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Sun, 06 Jan 2019 10:00:00 +0000
+ Sun, 06 Jan 2019 10:00:00 +0000
+
+
+
+
Controlling Zigbee devices with MQTT
/post/2019-01-06-zigbee2mqtt/
@@ -19,4 +23,4 @@ If you’re anything like me, you’re probably a sucker for IoT
-
+
\ No newline at end of file
diff --git a/tags/zigbee/page/1/index.html b/tags/zigbee/page/1/index.html
index 04eea1c..d0763ee 100644
--- a/tags/zigbee/page/1/index.html
+++ b/tags/zigbee/page/1/index.html
@@ -1 +1 @@
-/tags/zigbee/
\ No newline at end of file
+/tags/zigbee/
\ No newline at end of file
diff --git a/tags/zotero/index.html b/tags/zotero/index.html
index c4f991a..540b3af 100644
--- a/tags/zotero/index.html
+++ b/tags/zotero/index.html
@@ -137,6 +137,17 @@ If you use nginx as your web server, know that even though it provides partial s
+
-
-github
-
-git
-
-dotfiles
-
-
-
-
diff --git a/tags/zotero/index.xml b/tags/zotero/index.xml
index c1f43ca..09867f3 100644
--- a/tags/zotero/index.xml
+++ b/tags/zotero/index.xml
@@ -7,7 +7,11 @@
Hugo -- gohugo.ioen-usThis work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
- Tue, 09 Dec 2014 12:12:12 +0000
+ Tue, 09 Dec 2014 12:12:12 +0000
+
+
+
+
Zotero
/post/2014-12-09-zotero/
@@ -19,4 +23,4 @@ If you use nginx as your web server, know that even though it provides partial s
-
+
\ No newline at end of file
diff --git a/tags/zotero/page/1/index.html b/tags/zotero/page/1/index.html
index 69c73ba..8a16825 100644
--- a/tags/zotero/page/1/index.html
+++ b/tags/zotero/page/1/index.html
@@ -1 +1 @@
-/tags/zotero/
\ No newline at end of file
+/tags/zotero/
\ No newline at end of file