clear-skies-akeyless-custom-producer


Nameclear-skies-akeyless-custom-producer JSON
Version 1.1.3 PyPI version JSON
download
home_pagehttps://github.com/cmancone/clearskies-akeyless-custom-producer
Summaryclearskies handlers for hosting Akeyless custom producer endpoints
upload_time2023-10-05 17:46:45
maintainer
docs_urlNone
authorConor Mancone
requires_python>=3.8,<4.0
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # clearskies-akeyless-custom-producer

Contains clearskies handlers that should make it very easy to create custom producers for Akeyless.

There are a variety of ways to manage custom producers for Akeyless.  The strategy utilized in this library is aimed at creating a stateless set of producer endpoints.  This works because you can store a payload in the customer producer in Akeless, and then Akeyless will provide this to the custom producer endpoint when it calls them.  As a result, the custom producer endpoints make use of the data provided in the payload rather than storing any secrets themselves.  This dramatically simplifies management of the endpoints.  In addition, this removes the need to manage authentication and authorization.  The reason is because Akeyless will only call your endpoint and pass along the payload in the event that it received a properly authorized request.  Therefore, the payload will only be present for authorized users, and since the custom producer endpoints don't store any credentials on their own, they are incapable of fulfilling requests on their own without being called properly by Akeyless.

This assumes that the payload stored in the custom producer is in JSON format.  Note, however, that this is merely a convention of this library: Akeyless does nothing to enforce valid JSON in payloads, so you must ensure that your payloads are properly formatted yourself.

# Installation, Documentation, and Usage

To install:

```
pip3 install clear-skies-akeyless-custom-producer
```

# Default Mode

There are a few options for managing credentials.  The "default" mode involves passing along two methods: one to create new credentials and one to revoke new credentials.  Your methods will be called as necessary.  You can request any named dependency injection parameters as needed.  In addition, you can request the `payload` parameter in your function and will receive the full payload data as a dictionary, or you can specify individual keys from the payload.  Your create function then uses the given data to create a new credential and returns the details as a dictionary.

In order to support later rotation of credentials, Akeyless requires that you specify an id for the new credential.  The revoke function will be called and this id will be provided back so that you can revoke a credential when it should expire.  To support this, an additional parameter is provided to the revoke function.  On top of `payload` and the various properties of the payload, your delete function should also provide the `id_to_delete` parameter which will contain the id of the credential that must be deleted.

Here's an example where an API call is used to create/revoke a credential with two parameters: `key` (the id) and `secret`.

```
import clearskies
from clearskies_akeyless_custom_producer.handlers import NoInput
def create(key, secret, requests):
    return requests.post(
        'https://key-generator.example.com',
        headers={
            'x-api-key': key,
            'x-api-secret': secret,
        }
    ).json()

def revoke(key, secret, requests, id_to_delete):
    return requests.delete(
        'https://key-generator.example.com/' + id_to_delete,
        headers={
            'x-api-key': key,
            'x-api-secret': secret,
        }
    )

custom_producer = clearskies.application(
    NoInput,
    {
        "create_callable": create,
        "revoke_callable": revoke,
        "id_column_name": "key",
    }
)
```
and then you can just attach your application to the appropriate context and execute it:

```
wsgi = clearskies.contexts.wsgi(custom_producer)
def application(env, start_response):
    return wsgi(env, start_response)
```

This will generate three endpoints:

 1. `/sync/create`
 2. `/sync/revoke`
 3. `/sync/rotate`

Which are where you point the akeyless custom producer.  Note that for rotation, it will call your create endpoint to make a new credential and then use the new credential to call the revoke endpoint for the old credential.

# Alternate Modes

### No Revoke

Sometimes you may not be able to revoke a credential (for instance, if issuing JWTs).  You can then just turn off the revoke step by setting `"can_revoke": False` in the configuration.  Akeyless requires a revoke step, so it will still be published by the handler, but it won't take any action.  Finally, since there is no attempt to revoke credentials, it's not necessary to track credential ids, so `id_column_name` is no longer required in this case:

```
custom_producer = clearskies.application(
    NoInput,
    {
        "create_callable": create,
        "can_revoke": False,
    }
)
```

### Custom Rotation

In some cases rotation is as simple as generating a new credential in the "usual" way and deleting the old credential.  This is the "default" usage describe above, and so there is no need for an explicit rotation step.  However, in some cases there may be a separate process for rotation, in which case you can provide a `rotate_callable`:

```
def rotate(requests, key, secret):
    return requests.patch(
        'https://key-generator.example.com/',
        headers={
            'x-api-key': key,
            'x-api-secret': secret,
        }
    ).json()

custom_producer = clearskies.application(
    NoInput,
    {
        "create_callable": create,
        "rotate_callable": rotate,
        "revoke_callable": revoke,
        "id_column_name": "key",
    }
)
```

### No Rotation

Sometimes rotation simply isn't possible, in which case you can completely disable it:

```
custom_producer = clearskies.application(
    NoInput,
    {
        "create_callable": create,
        "revoke_callable": revoke,
        "can_rotate": False,
        "id_column_name": "key",
    }
)
```

# With Input

Akeyless provides an option for allowing the client to pass additional input to the custom produccer which it can use when issuing credentials.  It's important to be very careful when processing user input in these cases, to ensure that users can't arbitrarily adjust the permissions of the generated credentials.  Still, if you want to allow users to impact the credential generation process, you can do that using the `WithInput` handler (which doesn't exist yet).

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/cmancone/clearskies-akeyless-custom-producer",
    "name": "clear-skies-akeyless-custom-producer",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.8,<4.0",
    "maintainer_email": "",
    "keywords": "",
    "author": "Conor Mancone",
    "author_email": "cmancone@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/47/1f/5d0b709efc6a9ec4d9bc7d257643a00ad080201fde7741f4afbede365a39/clear_skies_akeyless_custom_producer-1.1.3.tar.gz",
    "platform": null,
    "description": "# clearskies-akeyless-custom-producer\n\nContains clearskies handlers that should make it very easy to create custom producers for Akeyless.\n\nThere are a variety of ways to manage custom producers for Akeyless.  The strategy utilized in this library is aimed at creating a stateless set of producer endpoints.  This works because you can store a payload in the customer producer in Akeless, and then Akeyless will provide this to the custom producer endpoint when it calls them.  As a result, the custom producer endpoints make use of the data provided in the payload rather than storing any secrets themselves.  This dramatically simplifies management of the endpoints.  In addition, this removes the need to manage authentication and authorization.  The reason is because Akeyless will only call your endpoint and pass along the payload in the event that it received a properly authorized request.  Therefore, the payload will only be present for authorized users, and since the custom producer endpoints don't store any credentials on their own, they are incapable of fulfilling requests on their own without being called properly by Akeyless.\n\nThis assumes that the payload stored in the custom producer is in JSON format.  Note, however, that this is merely a convention of this library: Akeyless does nothing to enforce valid JSON in payloads, so you must ensure that your payloads are properly formatted yourself.\n\n# Installation, Documentation, and Usage\n\nTo install:\n\n```\npip3 install clear-skies-akeyless-custom-producer\n```\n\n# Default Mode\n\nThere are a few options for managing credentials.  The \"default\" mode involves passing along two methods: one to create new credentials and one to revoke new credentials.  Your methods will be called as necessary.  You can request any named dependency injection parameters as needed.  In addition, you can request the `payload` parameter in your function and will receive the full payload data as a dictionary, or you can specify individual keys from the payload.  Your create function then uses the given data to create a new credential and returns the details as a dictionary.\n\nIn order to support later rotation of credentials, Akeyless requires that you specify an id for the new credential.  The revoke function will be called and this id will be provided back so that you can revoke a credential when it should expire.  To support this, an additional parameter is provided to the revoke function.  On top of `payload` and the various properties of the payload, your delete function should also provide the `id_to_delete` parameter which will contain the id of the credential that must be deleted.\n\nHere's an example where an API call is used to create/revoke a credential with two parameters: `key` (the id) and `secret`.\n\n```\nimport clearskies\nfrom clearskies_akeyless_custom_producer.handlers import NoInput\ndef create(key, secret, requests):\n    return requests.post(\n        'https://key-generator.example.com',\n        headers={\n            'x-api-key': key,\n            'x-api-secret': secret,\n        }\n    ).json()\n\ndef revoke(key, secret, requests, id_to_delete):\n    return requests.delete(\n        'https://key-generator.example.com/' + id_to_delete,\n        headers={\n            'x-api-key': key,\n            'x-api-secret': secret,\n        }\n    )\n\ncustom_producer = clearskies.application(\n    NoInput,\n    {\n        \"create_callable\": create,\n        \"revoke_callable\": revoke,\n        \"id_column_name\": \"key\",\n    }\n)\n```\nand then you can just attach your application to the appropriate context and execute it:\n\n```\nwsgi = clearskies.contexts.wsgi(custom_producer)\ndef application(env, start_response):\n    return wsgi(env, start_response)\n```\n\nThis will generate three endpoints:\n\n 1. `/sync/create`\n 2. `/sync/revoke`\n 3. `/sync/rotate`\n\nWhich are where you point the akeyless custom producer.  Note that for rotation, it will call your create endpoint to make a new credential and then use the new credential to call the revoke endpoint for the old credential.\n\n# Alternate Modes\n\n### No Revoke\n\nSometimes you may not be able to revoke a credential (for instance, if issuing JWTs).  You can then just turn off the revoke step by setting `\"can_revoke\": False` in the configuration.  Akeyless requires a revoke step, so it will still be published by the handler, but it won't take any action.  Finally, since there is no attempt to revoke credentials, it's not necessary to track credential ids, so `id_column_name` is no longer required in this case:\n\n```\ncustom_producer = clearskies.application(\n    NoInput,\n    {\n        \"create_callable\": create,\n        \"can_revoke\": False,\n    }\n)\n```\n\n### Custom Rotation\n\nIn some cases rotation is as simple as generating a new credential in the \"usual\" way and deleting the old credential.  This is the \"default\" usage describe above, and so there is no need for an explicit rotation step.  However, in some cases there may be a separate process for rotation, in which case you can provide a `rotate_callable`:\n\n```\ndef rotate(requests, key, secret):\n    return requests.patch(\n        'https://key-generator.example.com/',\n        headers={\n            'x-api-key': key,\n            'x-api-secret': secret,\n        }\n    ).json()\n\ncustom_producer = clearskies.application(\n    NoInput,\n    {\n        \"create_callable\": create,\n        \"rotate_callable\": rotate,\n        \"revoke_callable\": revoke,\n        \"id_column_name\": \"key\",\n    }\n)\n```\n\n### No Rotation\n\nSometimes rotation simply isn't possible, in which case you can completely disable it:\n\n```\ncustom_producer = clearskies.application(\n    NoInput,\n    {\n        \"create_callable\": create,\n        \"revoke_callable\": revoke,\n        \"can_rotate\": False,\n        \"id_column_name\": \"key\",\n    }\n)\n```\n\n# With Input\n\nAkeyless provides an option for allowing the client to pass additional input to the custom produccer which it can use when issuing credentials.  It's important to be very careful when processing user input in these cases, to ensure that users can't arbitrarily adjust the permissions of the generated credentials.  Still, if you want to allow users to impact the credential generation process, you can do that using the `WithInput` handler (which doesn't exist yet).\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "clearskies handlers for hosting Akeyless custom producer endpoints",
    "version": "1.1.3",
    "project_urls": {
        "Homepage": "https://github.com/cmancone/clearskies-akeyless-custom-producer",
        "Repository": "https://github.com/cmancone/clearskies-akeyless-custom-producer"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "9532c1dfa7985135d64196239a21b14d151882e4febdf7dc1e4882a1fb4e60ea",
                "md5": "710dbffc30c0560e14a3a29c58fb488b",
                "sha256": "041cca89389187c3064833f66888824df4cf674fd24e71209ad1d15921414db9"
            },
            "downloads": -1,
            "filename": "clear_skies_akeyless_custom_producer-1.1.3-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "710dbffc30c0560e14a3a29c58fb488b",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8,<4.0",
            "size": 10404,
            "upload_time": "2023-10-05T17:46:42",
            "upload_time_iso_8601": "2023-10-05T17:46:42.241587Z",
            "url": "https://files.pythonhosted.org/packages/95/32/c1dfa7985135d64196239a21b14d151882e4febdf7dc1e4882a1fb4e60ea/clear_skies_akeyless_custom_producer-1.1.3-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "471f5d0b709efc6a9ec4d9bc7d257643a00ad080201fde7741f4afbede365a39",
                "md5": "c5dbecd3429887f47ca3a49ec564e6e4",
                "sha256": "338fd18409b635b0ea08d7db53664dedafa401fb64d3463a5614623571647434"
            },
            "downloads": -1,
            "filename": "clear_skies_akeyless_custom_producer-1.1.3.tar.gz",
            "has_sig": false,
            "md5_digest": "c5dbecd3429887f47ca3a49ec564e6e4",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8,<4.0",
            "size": 9644,
            "upload_time": "2023-10-05T17:46:45",
            "upload_time_iso_8601": "2023-10-05T17:46:45.219303Z",
            "url": "https://files.pythonhosted.org/packages/47/1f/5d0b709efc6a9ec4d9bc7d257643a00ad080201fde7741f4afbede365a39/clear_skies_akeyless_custom_producer-1.1.3.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-10-05 17:46:45",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "cmancone",
    "github_project": "clearskies-akeyless-custom-producer",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "clear-skies-akeyless-custom-producer"
}
        
Elapsed time: 0.12919s