Difference between revisions of "Programming language cook book"
| m (→letscncrypt) |  (→ssh) | ||
| (17 intermediate revisions by the same user not shown) | |||
| Line 1: | Line 1: | ||
| =Mostly just for me to remember stuff= | =Mostly just for me to remember stuff= | ||
| − | I might use a command once, then not again for years. Hopefully I can jog my memory quickly here. | + | I might use a command once, then not again for years. Hopefully I can jog my memory quickly here. YMMV | 
| + | |||
| + | ==ssh== | ||
| + | ===linux=== | ||
| + | <source lang="bash"> | ||
| + | # ssh -o StrictHostKeyChecking=no 192.168.1.2 | ||
| + | </source> | ||
| + | |||
| + | |||
| + | ===MS Windows=== | ||
| + | <source lang="powershell"> | ||
| + | rem I used this to copy  keys to linux hosts 'cause `ssh-copy-id` wasn't working for me in powershell. | ||
| + | cat C:\Users\jhalb\.ssh\id_rsa | ssh jeffa@rodaw "cat >> ~/.ssh/authorized_keys" | ||
| + | </source> | ||
| ==Python== | ==Python== | ||
| Line 36: | Line 49: | ||
| ===Resources=== | ===Resources=== | ||
| * [https://www.mediawiki.org/wiki/Manual:Short_URL Short URLs] at Mediwiki | * [https://www.mediawiki.org/wiki/Manual:Short_URL Short URLs] at Mediwiki | ||
| + | ===utility=== | ||
| + | <source lang=bash> | ||
| + | # VirtualHost configuration: | ||
| + | apachectl -S | ||
| + | # Check .conf syntax | ||
| + | apachectl configtest | ||
| + | # What modules loaded? | ||
| + | httpd -M | ||
| + | apachectl -M | ||
| + | </source> | ||
| + | |||
| ===Redirect site root to wiki=== | ===Redirect site root to wiki=== | ||
| This works to redirect to www.somedomain.tld from www.somedomain.tld/w - basically to point the root to your wiki as home / first page.   | This works to redirect to www.somedomain.tld from www.somedomain.tld/w - basically to point the root to your wiki as home / first page.   | ||
| Line 66: | Line 90: | ||
| </VirtualHost> | </VirtualHost> | ||
| </source> | </source> | ||
| + | |||
| + | ==Mediawiki== | ||
| + | |||
| + | |||
| + | |||
| ===Visual Editor=== | ===Visual Editor=== | ||
| ====parsoid==== | ====parsoid==== | ||
| Line 148: | Line 177: | ||
| </source> | </source> | ||
| − | + | ||
| + | |||
| + | |||
| ===Display unformated like code snippets=== | ===Display unformated like code snippets=== | ||
| lang= text bash csharp cpp php xml py javascript (or js) | lang= text bash csharp cpp php xml py javascript (or js) | ||
| Line 258: | Line 289: | ||
| echo `hostname` `cat /etc/*elease*` "this is some blah blah testing body text" | mail -s "Testing 1 2 3" somebody@somewhere.tld | echo `hostname` `cat /etc/*elease*` "this is some blah blah testing body text" | mail -s "Testing 1 2 3" somebody@somewhere.tld | ||
| </source> | </source> | ||
| − | Find a message ID  | + | Find a message ID.   | 
| <source lang="bash"> | <source lang="bash"> | ||
| [root@redacted cron.d]# mailq | [root@redacted cron.d]# mailq | ||
| Line 267: | Line 298: | ||
| -- 0 Kbytes in 1 Request. | -- 0 Kbytes in 1 Request. | ||
| + | # Read it. | ||
| + | [root@dediserve1 conf]# postcat -q A9D1061AF9 | ||
| + | .... | ||
| + | # Delete it. | ||
| [root@dediserve1 cron.d]# postsuper -d B077861458 | [root@dediserve1 cron.d]# postsuper -d B077861458 | ||
| postsuper: B077861458: removed | postsuper: B077861458: removed | ||
| Line 279: | Line 314: | ||
| https://crt.sh/?q=dediserve1.jhalbrecht.net | https://crt.sh/?q=dediserve1.jhalbrecht.net | ||
| </source> | </source> | ||
| + | <source lang=bash> | ||
| + | [root@thehost]# certbot certificates | ||
| + | [root@thehost]# certbot delete # prompted for certs to remove | ||
| + | [root@thehost]# certbot delete --cert-name delthisdname  | ||
| + | [root@thehost]#  | ||
| + | [root@thehost]#  | ||
| + | [root@thehost]#  | ||
| + | [root@thehost]#  | ||
| + | |||
| + | </source> | ||
| + | |||
| ===stuff...=== | ===stuff...=== | ||
| <source lang="bash"> | <source lang="bash"> | ||
| Line 289: | Line 335: | ||
| systemctl cat bacula-fd will display the current bacula-fd.service file | systemctl cat bacula-fd will display the current bacula-fd.service file | ||
| + | |||
| + | ===iptables=== | ||
| + | <source lang=bash> | ||
| + | iptables -L --line-numbers | ||
| + | iptables -D INPUT 3 | ||
| + | |||
| + | iptables -L | ||
| + | iptables -S | ||
| + | |||
| + | |||
| + | service iptables save | ||
| + | |||
| + | |||
| + | |||
| + | </source> | ||
| + | |||
| + | ==Debian 9== | ||
| + | ===Install=== | ||
| + | I'm attempting to install Stretch on a pair of 4TB drives in a Raid 1 configuration. | ||
| + | ====Some linke and notes==== | ||
| + | * [https://outflux.net/blog/archives/2018/04/19/uefi-booting-and-raid1/ UEFI booting and RAID1] | ||
| + | * [https://wiki.debian.org/UEFI Disk partitioning: MS-DOS and GPT] | ||
| + | |||
| + | ==Windows== | ||
| + | ===hosts and flush=== | ||
| + | I like to put the dns of the new site in hosts before I change name service enabling to verify proper operation first. | ||
| + | |||
| + | Elevate your privileges to Administrator | ||
| + | |||
| + | Edit c:\Windows\System32\Drivers\etc\hosts | ||
| + | |||
| + | ipconfig /flushdns | ||
| + | |||
| + | Once done testing don't forget to remove temporary ip from hosts | ||
| + | |||
| + | ===Network shares mostly samba=== | ||
| + | <syntaxhighlight lang="bash"> | ||
| + | # Samba stuff you probably want to remember | ||
| + | smbclient -L \\192.168.1.122 -U wmctv | ||
| + | mount -t cifs -o username=wmctv //192.168.1.122/wmctv /tmp/wmctv | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | <syntaxhighlight lang="DOS"> | ||
| + | PS C:\Users\jhalb> net use | ||
| + | New connections will be remembered. | ||
| + | |||
| + | Status       Local     Remote                    Network | ||
| + | |||
| + | ------------------------------------------------------------------------------- | ||
| + | OK                     \\192.168.1.122\tns1snap  Microsoft Windows Network | ||
| + | OK                     \\debbie\IPC$             Microsoft Windows Network | ||
| + | The command completed successfully. | ||
| + | |||
| + | PS C:\Users\jhalb> net use /delete \\192.168.1.122\tns1snap | ||
| + | \\192.168.1.122\tns1snap was deleted successfully. | ||
| + | |||
| + | PS C:\Users\jhalb> net use | ||
| + | New connections will be remembered. | ||
| + | |||
| + | Status       Local     Remote                    Network | ||
| + | |||
| + | ------------------------------------------------------------------------------- | ||
| + | OK                     \\debbie\IPC$             Microsoft Windows Network | ||
| + | The command completed successfully. | ||
| + | |||
| + | PS C:\Users\jhalb> net use \\192.168.1.122\work /user:uwork uwork | ||
| + | The command completed successfully. | ||
| + | |||
| + | PS C:\Users\jhalb> | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | ==Not yet organized== | ||
| + | Stuff I need to integrate into some order but I'm busy with other stuff and don't want to forget | ||
| + | * journalctl -b -u fail2ban | ||
| + | * fail2ban-client status | ||
| + | ** fail2ban-client status jail_name | ||
| + | ===disk stuff=== | ||
| + | ====is grub installed?==== | ||
| + | <source lang="bash"> | ||
| + | [root@seven ~]# dd if=/dev/sda bs=1 count=512 | grep -aob GRUB | ||
| + | 378:GRUB | ||
| + | 512+0 records in | ||
| + | 512+0 records out | ||
| + | 512 bytes (512 B) copied, 0.00301491 s, 170 kB/s | ||
| + | [root@seven ~]# | ||
| + | </source> | ||
| + | ====install boot on /dev/sdb==== | ||
| + | <source lang="bash"> | ||
| + | [root@seven ~]# grub2-install /dev/sdb | ||
| + | Installing for i386-pc platform. | ||
| + | grub2-install: warning: Couldn't find physical volume `(null)'. Some modules may be missing from core image.. | ||
| + | grub2-install: warning: Couldn't find physical volume `(null)'. Some modules may be missing from core image.. | ||
| + | Installation finished. No error reported. | ||
| + | [root@seven ~]# | ||
| + | </source> | ||
Latest revision as of 11:27, 6 June 2023
Contents
Mostly just for me to remember stuff
I might use a command once, then not again for years. Hopefully I can jog my memory quickly here. YMMV
ssh
linux
# ssh -o StrictHostKeyChecking=no 192.168.1.2
MS Windows
rem I used this to copy  keys to linux hosts 'cause `ssh-copy-id` wasn't working for me in powershell.
cat C:\Users\jhalb\.ssh\id_rsa | ssh jeffa@rodaw "cat >> ~/.ssh/authorized_keys"
Python
I wanted a json utc datetime for a MQTT payload. Found the arrow module that is much like moment.js for javascript.
import arrow
print (arrow.get(arrow.utcnow()).for_json()
results in: "2015-08-27T15:03:07.427351+00:00" I'd like to trim it further and replace the +00:00 with Z. ??? and less precision on the seconds.
Documentation for ISO 8601
vim
comment a block
What's a quick way to comment/uncomment lines in Vim? (Stack overflow)
ctl v (at start of block)
down arrow (to end of block)
shift I, #
  or
: s/^/# <- more likely
esc
global search and replace
:
%s/findString/replaceString/g
Apache
Resources
- Short URLs at Mediwiki
utility
# VirtualHost configuration:
apachectl -S
# Check .conf syntax
apachectl configtest
# What modules loaded?
httpd -M
apachectl -M
Redirect site root to wiki
This works to redirect to www.somedomain.tld from www.somedomain.tld/w - basically to point the root to your wiki as home / first page.
<VirtualHost *:80>
     RewriteEngine on
     RewriteRule ^/*$ %{DOCUMENT_ROOT}/w/index.php [L]
</VirtualHost>
MediaWiki Short URLs
<VirtualHost *:443>
        ServerName www.redacted.info
        ServerAlias redacted.info
        DocumentRoot /var/www/redacted.info
        CustomLog       /var/log/httpd/redacted.info-access.log combined
        ErrorLog        /var/log/httpd/redacted.info-error.log
        Include /etc/letsencrypt/options-ssl-apache.conf
        SSLCertificateFile /etc/letsencrypt/live/redacted.com/cert.pem
        SSLCertificateKeyFile /etc/letsencrypt/live/redacted.com/privkey.pem
        Include /etc/letsencrypt/options-ssl-apache.conf
        SSLCertificateChainFile /etc/letsencrypt/live/redacted.com/chain.pem
        RewriteEngine on
        RewriteRule ^/*$ %{DOCUMENT_ROOT}/w/index.php [L]
        alias /wiki /var/www/redacted.info/w/index.php
        # Redirect / to Main Page
        RewriteRule ^/*$ %{DOCUMENT_ROOT}/w/index.php [L]
</VirtualHost>
Mediawiki
Visual Editor
parsoid
install start stop status
[root@myhost parsoid]#  systemctl daemon-reload  # Do this if when you make changes to a service file
[root@myhost parsoid]#  systemctl start parsoid  # start
[root@myhost parsoid]#  systemctl status parsoid # check status
[root@myhost parsoid]#  systemctl enable parsoid # start parsoid on boot
systemd service file.
[Unit]
Description=Mediawiki Parsoid web service on node.js
Documentation=http://www.mediawiki.org/wiki/Parsoid
Wants=local-fs.target network.target
After=local-fs.target network.target
[Install]
WantedBy=multi-user.target
[Service]
Type=simple
User=nobody
Group=nobody
WorkingDirectory=/opt/parsoid
EnvironmentFile=-/etc/parsoid/parsoid.env
ExecStart=/usr/bin/node /opt/parsoid/bin/server.js
KillMode=process
Restart=on-success
PrivateTmp=true
StandardOutput=syslog
stunnel
# groupadd -g 51 stunnel
# useradd -c "stunnel Daemon" -d /var/run/stunnel -g stunnel -s /bin/false -u 51 stunnel
/etc/stunnel/stunnel.conf
cert = /etc/letsencrypt/live/redacted/fullchain.pem
key = /etc/letsencrypt/live/recacted/privkey.pem
chroot = /var/run/stunnel
setuid = stunnel
setgid = stunnel
pid = /stunnel.pid
[parsoid]
accept  = 8143
connect = 8142
/lib/systemd/system/stunnel.service
[Unit]
Description=SSL tunnel for network daemons
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
Alias=stunnel.target
[Service]
Type=forking
ExecStartPre=-/usr/bin/mkdir /var/run/stunnel
ExecStartPre=/usr/bin/chown -R stunnel:stunnel /var/run/stunnel/
ExecStartPre=-/bin/chmod 700 /var/run/stunnel
ExecStart=/usr/bin/stunnel /etc/stunnel/stunnel.conf
ExecStop=/usr/bin/killall -9 stunnel
RuntimeDirectory=stunnel
# Give up if ping don't get an answer
TimeoutSec=600
Restart=always
#PrivateTmp=false
PrivateTmp=false
EnvironmentFile=-/etc/stunnel/stunnel.conf
#PermissionsStartOnly=true
# RemainAfterExit=yes
Display unformated like code snippets
lang= text bash csharp cpp php xml py javascript (or js) <source lang="bash"> code snippet </source>
My Simple Template
{{ blockquote| text here }}
upgrade and move
- upgrade php to allow mediawiki upgrade
- upgrade mediawik to allow for contact page, VisualEditor etc...
- Implement short URLs for better SEO and they're pretty.
current soon to be old wiki version info
Installed software
Product	Version
MediaWiki	1.21.1
PHP	5.3.3 (apache2handler)
MySQL	5.1.73
Entry point URLs
Entry point	URL
Article path	/wiki/index.php/$1
Script path	/wiki
index.php	/wiki/index.php
api.php	/wiki/api.php
load.php	/wiki/load.php
Installed extensions
Special pages
ContactPage (Version 2.2)	Contact form for visitors	Daniel Kinzler and Sam Reed
Renameuser	Adds a special page to rename a user (need renameuser right)	Ævar Arnfjörð Bjarmason and Aaron Schulz
Parser hooks
ParserFunctions (Version 1.5.1)	Enhance parser with logical functions	Tim Starling, Robert Rohde, Ross McClure and Juraj Simlovic
SyntaxHighlight (Version 1.0.8.11)	Provides syntax highlighting <syntaxhighlight> using GeSHi - Generic Syntax Highlighter	Brion Vibber, Tim Starling, Rob Church and Niklas Laxström
Media handlers
PDF Handler	Handler for viewing PDF files in image mode.	Martin Seidel and Mike Połtyn
Other
Gadgets	Lets users select custom CSS and JavaScript gadgets in their preferences	Daniel Kinzler and Max Semenik
WikiEditor (Version 0.3.1)	Provides an extendable wikitext editing interface and many feature-providing modules	Trevor Parscal, Roan Kattouw, Nimish Gautam and Adam Miller
Parser extension tags
<gallery>, <nowiki>, <pre>, <source> and <syntaxhighlight>
Parser function hooks
anchorencode, basepagename, basepagenamee, canonicalurl, canonicalurle, defaultsort, displaytitle, expr, filepath, formatdate, formatnum, fullpagename, fullpagenamee, fullurl, fullurle, gender, grammar, if, ifeq, iferror, ifexist, ifexpr, int, language, lc, lcfirst, localurl, localurle, namespace, namespacee, namespacenumber, ns, nse, numberingroup, numberofactiveusers, numberofadmins, numberofarticles, numberofedits, numberoffiles, numberofpages, numberofusers, numberofviews, padleft, padright, pagename, pagenamee, pagesincategory, pagesize, plural, protectionlevel, rel2abs, special, speciale, subjectpagename, subjectpagenamee, subjectspace, subjectspacee, subpagename, subpagenamee, switch, tag, talkpagename, talkpagenamee, talkspace, talkspacee, time, timel, titleparts, uc, ucfirst and urlencode
Fedora fc.22
I opened up node.js on port 3000 with this command.
firewall-cmd --permanent --add-port=3000/tcp
# be sure to reload
 firewall-cmd --reload
# tail a log with colored warnings
#> tail -f /var/log/maillog|egrep --ignore-case  --line-buffered --color=auto 'reject|ERROR|WARN|$'
7-zip
I wanted to create a .zip file for my FDDSE project from the command line. Perhaps in a batch file.
7z a -tzip FDDSE.zip FDDSE
VS 2015 IISExpress
.vs\config\applicationhost.config
%userprofile%\Documents\IISExpress\
netsh http show urlacl
netsh http add urlacl url=http://localhost:60262/ user=everyone
netsh http delete urlacl url=http://*:60262/
I 'ended' Microsoft.VsHub.Server.HttpHostx64.exe with TaskManager
// punch a hole in the firewall
// oopps just noticed I'm running public profile at home on nat. Another toDo
C:\Users\jeffa>netsh advfirewall firewall add rule name="IISExpressWeb" dir=in protocol=tcp localport=60262 profile=private remoteip=localsubnet action=allow
Ok.
C:\Users\jeffa>netsh advfirewall firewall add rule name="IISExpressWeb" dir=in protocol=tcp localport=60262 profile=public remoteip=localsubnet action=allow
Ok.
CentOS 7
Nifty resources
- How to set up a mail server on a GNU / Linux system
- MYSQL_TABLE(5) man page HEY! Finish reading this! Yea you Jeff!
yum etc...
- yum list installed
- repoquery --list php56u
- yum search all php-imap
- yum install php56u-imap
- rpm -qi postfix # show currently installed info
bacula
-  bconsole
- status client
 
smtp etc...
mailq
postfix flush
postmap -q anexample.com  mysql:/afilenameWithQuery.cf
dovecot -n ; display configuration / check configuration syntax
echo `hostname` `cat /etc/*elease*` "this is some blah blah testing body text" | mail -s "Testing 1 2 3" somebody@somewhere.tld
Find a message ID.
[root@redacted cron.d]# mailq
-Queue ID-  --Size-- ----Arrival Time---- -Sender/Recipient-------
B077861458      758 Sat Jan 20 08:17:22  apache@redacted.net
(connect to example.com[2606:2800:220:1:248:1893:25c8:1946]:25: Network is unreachable)
                                         you@example.com
-- 0 Kbytes in 1 Request.
# Read it.
[root@dediserve1 conf]# postcat -q A9D1061AF9
....
# Delete it.
[root@dediserve1 cron.d]# postsuper -d B077861458
postsuper: B077861458: removed
postsuper: Deleted: 1 message
[root@redacted cron.d]# mailq
Mail queue is empty
[root@redacted cron.d]#
letscncrypt
https://crt.sh/?q=dediserve1.jhalbrecht.net
[root@thehost]# certbot certificates
[root@thehost]# certbot delete # prompted for certs to remove
[root@thehost]# certbot delete --cert-name delthisdname 
[root@thehost]# 
[root@thehost]# 
[root@thehost]# 
[root@thehost]#
stuff...
find ./ -exec ls -l {} + | less
sed -i 's/findstring/replacestring/g' *
systemctl
edit /etc/systemd/system.conf add LogLevel=debug for increased logging when debugging systemctl start something
systemctl cat bacula-fd will display the current bacula-fd.service file
iptables
iptables -L --line-numbers
iptables -D INPUT 3
iptables -L
iptables -S
service iptables save
Debian 9
Install
I'm attempting to install Stretch on a pair of 4TB drives in a Raid 1 configuration.
Some linke and notes
Windows
hosts and flush
I like to put the dns of the new site in hosts before I change name service enabling to verify proper operation first.
Elevate your privileges to Administrator
Edit c:\Windows\System32\Drivers\etc\hosts
ipconfig /flushdns
Once done testing don't forget to remove temporary ip from hosts
# Samba stuff you probably want to remember
smbclient -L \\192.168.1.122 -U wmctv
mount -t cifs -o username=wmctv //192.168.1.122/wmctv /tmp/wmctv
PS C:\Users\jhalb> net use
New connections will be remembered.
Status       Local     Remote                    Network
-------------------------------------------------------------------------------
OK                     \\192.168.1.122\tns1snap  Microsoft Windows Network
OK                     \\debbie\IPC$             Microsoft Windows Network
The command completed successfully.
PS C:\Users\jhalb> net use /delete \\192.168.1.122\tns1snap
\\192.168.1.122\tns1snap was deleted successfully.
PS C:\Users\jhalb> net use
New connections will be remembered.
Status       Local     Remote                    Network
-------------------------------------------------------------------------------
OK                     \\debbie\IPC$             Microsoft Windows Network
The command completed successfully.
PS C:\Users\jhalb> net use \\192.168.1.122\work /user:uwork uwork
The command completed successfully.
PS C:\Users\jhalb>
Not yet organized
Stuff I need to integrate into some order but I'm busy with other stuff and don't want to forget
- journalctl -b -u fail2ban
-  fail2ban-client status
- fail2ban-client status jail_name
 
disk stuff
is grub installed?
[root@seven ~]# dd if=/dev/sda bs=1 count=512 | grep -aob GRUB
378:GRUB
512+0 records in
512+0 records out
512 bytes (512 B) copied, 0.00301491 s, 170 kB/s
[root@seven ~]#
install boot on /dev/sdb
[root@seven ~]# grub2-install /dev/sdb
Installing for i386-pc platform.
grub2-install: warning: Couldn't find physical volume `(null)'. Some modules may be missing from core image..
grub2-install: warning: Couldn't find physical volume `(null)'. Some modules may be missing from core image..
Installation finished. No error reported.
[root@seven ~]#

