Skip to content

Instantly share code, notes, and snippets.

View hbasria's full-sized avatar

Basri hbasria

  • base9.tech
  • ///soak.massing.glory
View GitHub Profile
@hbasria
hbasria / docker_volume_rm.sh
Created March 8, 2016 12:59
docker volume rm
docker volume rm $(docker volume ls -qf dangling=true)
@hbasria
hbasria / raw_as_qs.py
Created January 29, 2016 14:03 — forked from carymrobbins/raw_as_qs.py
Django - convert RawQuerySet to QuerySet
from django.db import connection, models
class MyManager(Manager):
def raw_as_qs(self, raw_query, params=()):
"""Execute a raw query and return a QuerySet. The first column in the
result set must be the id field for the model.
:type raw_query: str | unicode
:type params: tuple[T] | dict[str | unicode, T]
:rtype: django.db.models.query.QuerySet
"""
SELECT * FROM tree
left join (
SELECT
generate_series as id,
case
when generate_series = 0 then 'CREATED'
when generate_series = 1 then 'PENDING'
when generate_series = 2 then 'RECEIVED'
when generate_series = 3 then 'STARTED'
when generate_series = 4 then 'RETRY'
@hbasria
hbasria / gist:f8e21c3bda47bd00d339
Created November 18, 2015 16:05 — forked from lttlrck/gist:9628955
rename git branch locally and remotely
git branch -m old_branch new_branch # Rename branch locally
git push origin :old_branch # Delete the old branch
git push --set-upstream origin new_branch # Push the new branch, set local branch to track the new remote
@hbasria
hbasria / redis_bulk.sh
Created October 27, 2015 07:24 — forked from egemenyildiz/redis_bulk.sh
[LUA] Redis bulk/batch operation scripts (rename, delete)
# Bulk deletes keys start with "prefix"
EVAL "for i, name in ipairs(redis.call('KEYS', 'prefix*')) do redis.call('DEL', name); end" 0
# Bulk renames keys start with "prefix" to "postfix".
# e.g. prefixwithtail -> postfixwithtail
EVAL "for i, name in ipairs(redis.call('KEYS', 'prefix*')) do local x = string.gsub(name, 'pre', 'post'); redis.call('RENAME', name, x); end" 0
@hbasria
hbasria / knife cheat
Last active August 29, 2015 14:27 — forked from ipedrazas/knife cheat
Hello!
# knife cheat
## Search Examples
knife search "name:ip*"
knife search "platform:ubuntu*"
knife search "platform:*" -a macaddress
knife search "platform:ubuntu*" -a uptime
knife search "platform:ubuntu*" -a virtualization.system
knife search "platform:ubuntu*" -a network.default_gateway
CREATE OR REPLACE FUNCTION is_private_ip(p_prefix inet) RETURNS boolean AS
$BODY$
BEGIN
RETURN (
SELECT
CASE
WHEN '10.0.0.0/8'::inet >> p_prefix::inet
OR '192.168.0.0/16'::inet >> p_prefix::inet
OR '172.16.0.0/12'::inet >> p_prefix::inet THEN True
--select deps_save_and_drop_dependencies('public','test_table')
--select deps_restore_dependencies('public','test_table')
--select * from deps_saved_ddl
create table deps_saved_ddl
(
deps_id serial primary key,
deps_view_schema varchar(255),
#result = dict_items(response, 'Body/findResponse/result/Interface')
def dict_items(dict, path, separator='/'):
for item in path.split(separator):
if item in dict:
dict = dict[item]
if type(dict) is str and len(dict)<=0:
return None
else:
WITH weeks AS (
SELECT distinct date_trunc('week', dates)::date AS start,
daterange(date_trunc('week', dates)::date, (date_trunc('week', dates) + interval '7 days')::date) week
FROM generate_series(date '2013-01-01', now(), '1 day')
dates ORDER BY 1
)
SELECT weeks.start,
count(whatever.*) as count
FROM whatever
JOIN weeks