Metadata-Version: 2.1
Name: spellbook
Version: 1.1.5
Summary: store and search command lines
Home-page: https://github.com/donpiekarz/spellbook
Download-URL: https://github.com/donpiekarz/spellbook/tarball/1.1.5
Author: Bartlomiej Piekarski
Author-email: bartlomiej.piekarski@gmail.com
License: BSD
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: System Administrators
Classifier: Intended Audience :: End Users/Desktop
Classifier: Intended Audience :: Science/Research
Classifier: Topic :: System :: Shells
Classifier: Topic :: System :: System Shells
Classifier: License :: OSI Approved :: BSD License
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.6
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.2
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Provides-Extra: with_dropbox

=========
spellbook
=========

store and search command lines

-------
problem
-------

.. image:: http://imgs.xkcd.com/comics/tar.png




The inspiration is user experience in opennssl command line tool.
In one of my previous project I was working with openssl command line tool.
In the examples below I will use openssl to show you how to use spellbook.

the quickest start
==================

install spellbook:

.. code::

    $ pip install spellbook


create first spellbook, called aux:

.. code::

    $ spellbook aux create


add spell to your spellbook:

.. code::

    $ spellbook aux add "tar -xvzf file.tar.gz" "extract tar.gz archive"

search for it:

.. code::

    $ spellbook aux search tar
    tar -xvzf file.tar.gz


documentation
=============
The idea is to create 'book' for openssl.


create your first spellbook, called openssl:

.. code:: 

    $ spellbook openssl create

then create spellbook for linux:

.. code:: 

    $ spellbook linux create


add
---

add some data to it, three ways are possible:

format:

.. code:: 

    $ spellbook <book_name> add [command [description]]

add with command and description:

.. code:: 

    $ spellbook openssl add "openssl rand 16 -hex" "generate random 16 bytes and encode as hex"
    openssl rand 16 -hex::generate random 16 bytes and encode as hex

add with only command:

.. code:: 

    $ spellbook openssl add "openssl asn1parse -in 3msg.enc.der -inform der"
    provide description>> show asn1 encoded file
    openssl asn1parse -in 3msg.enc.der -inform der::show asn1 encoded file

add without command:

.. code:: 

    $ spellbook openssl add
    provide command>> openssl des3 -d -in 3msg.enc.msg -K `xxd -p 3msg.dec.key` -iv `xxd -p 3msg.iv`
    provide description>> decode file using des3 with key and iv
    openssl des3 -d -in 3msg.enc.msg -K `xxd -p 3msg.dec.key` -iv `xxd -p 3msg.iv`::decode file using des3 with key and iv

add something to linux book:

.. code:: 

    $ spellbook linux add "tar -xvzf file.tar.gz" "extract tar.gz archive"
    tar -xvzf file.tar.gz::extract tar.gz archive


search
------

search in book openssl:

.. code:: 

    $ spellbook openssl search rand
    openssl rand 16 -hex

or in all books ( - means all ):

.. code:: 

    $ spellbook - search extract
    tar -xvzf file.tar.gz

search any word:

.. code:: 

    $ spellbook - search openssl d
    openssl rand 16 -hex
    openssl asn1parse -in 3msg.enc.der -inform der
    openssl des3 -d -in 3msg.enc.msg -K `xxd -p 3msg.dec.key` -iv `xxd -p 3msg.iv`

or full pharse:

.. code:: 

    $ spellbook - search "openssl d"
    openssl des3 -d -in 3msg.enc.msg -K `xxd -p 3msg.dec.key` -iv `xxd -p 3msg.iv`


list
----

list all spells:

.. code:: 

    $ spellbook openssl list
    openssl rand 16 -hex    ::>>    generate random 16 bytes and encode as hex
    openssl asn1parse -in 3msg.enc.der -inform der  ::>>    show asn1 encoded file
    openssl des3 -d -in 3msg.enc.msg -K `xxd -p 3msg.dec.key` -iv `xxd -p 3msg.iv`  ::>>    decode file using des3 with key and iv


dropbox support
===============

just install dropbox or install spellbook with dropbox

.. code::

    $ pip install spellbook[with_dropbox]
    or
    $ pip install spellbook dropbox





connect to dropbox
------------------

.. code::

    $ spellbook - connectdb
    1. Go to: https://www.dropbox.com/1/oauth2/authorize?response_type=code&client_id=ow3gosk8pb9bhkr
    2. Click "Allow" (you might have to log in first)
    3. Copy the authorization code.
    provide the authorization code here>> oh4dTc9F_fgAAAAAAAAC3fovgKZ7cPL65mS5Ajxevug
    successfully linked account:  DonPiekarz

sync spellbooks with dropbox
----------------------------

all spellbooks will be synchronized with yours dropbox account

.. code::

    $ spellbook - sync



future work
===========

* some hack to end parse arguments
* refactoring


