ldp-archive-mirror


Nameldp-archive-mirror JSON
Version 0.2.0 PyPI version JSON
download
home_pagehttps://github.com/ovh/ldp-archive-mirror
SummaryThis tools allows you to get a local copy of all your cold stored archives on Logs Data Platform.
upload_time2023-03-10 11:40:18
maintainer
docs_urlNone
authorOVH Group
requires_python
licenseOVH SAS
keywords ldp ovh
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI
coveralls test coverage No coveralls.
            ***********************************
Logs Data Platform - Archive mirror
***********************************

.. image:: https://img.shields.io/pypi/v/ldp-archive-mirror.svg
   :target: https://pypi.python.org/pypi/ldp-archive-mirror/
   :alt: Latest Version

.. image:: https://travis-ci.org/ovh/ldp-archive-mirror.svg?branch=master
   :target: https://travis-ci.org/ovh/ldp-archive-mirror
   :alt: Latest version

This tools allows you to get a local copy of all your cold stored archives on Logs Data Platform::

    [2018-12-14 17:20:00,200 INFO LDP Mirror] Create local DB if not exists
    [2018-12-14 17:20:00,204 INFO LDP Mirror] Looking for new archives of stream e9397556-31d1-4d4d-b2bd-e5367b522cc8
    [2018-12-14 17:20:05,190 INFO LDP Mirror] Service ldp-jb-52560 found for stream e9397556-31d1-4d4d-b2bd-e5367b522cc8
    [2018-12-14 17:20:05,579 INFO LDP Mirror] Archive 9fb75957-2cde-435e-bdd9-6dfd33663f2c added to cache
    [2018-12-14 17:20:05,850 INFO LDP Mirror] Archive 11d8630a-7b38-4fa4-9d7c-dfd17b0b00f6 added to cache
    ...
    [2018-12-14 17:20:08,392 INFO LDP Mirror] Directory mirror/e9397556-31d1-4d4d-b2bd-e5367b522cc8 created
    [2018-12-14 17:20:08,535 INFO LDP Mirror] Archive e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-10.zst missing, download scheduled
    [2018-12-14 17:20:08,635 INFO LDP Mirror] Archive e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-11.zst missing, download scheduled
    ...
    [2018-12-14 17:20:09,535 INFO LDP Mirror] Will retry to download e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-10.zst after 596 seconds
    [2018-12-14 17:20:09,745 INFO LDP Mirror] Will retry to download e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-11.zst after 598 seconds
    ...
    [2018-12-14 17:20:10,927 INFO LDP Mirror] Archive e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-10.zst downloaded
    [2018-12-14 17:20:11,655 INFO LDP Mirror] Sha256 OK on e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-10.zst
    [2018-12-14 17:20:10,927 INFO LDP Mirror] Archive e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-11.zst downloaded
    [2018-12-14 17:20:11,655 INFO LDP Mirror] Sha256 OK on e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-11.zst


Quickstart
==========

First, install **ldp-archive-mirror** using `pip <https://pip.pypa.io/en/stable/>`_::

    pip3 install -U ldp-archive-mirror

Then you can use the binary ``ldp-mirror``::

    usage: ldp-mirror [-h] [--app-key KEY] [--app-secret SECRET]
                  [--consumer-key KEY] [--ovh-region REGION] [--db DIR]
                  [--mirror DIR] [--ldp-host HOST] [--ldp-token TOKEN]
                  [--chunk-size CHUNK] [--gpg-passphrase SECRET]
                  STREAM_ID [STREAM_ID ...]

    LDP archive Mirror CLI - 0.2.0

    positional arguments:
      STREAM_ID            LDP Stream UUIDs

    optional arguments:
      -h, --help              show this help message and exit
      --app-key KEY           OVH application key (default: dcd57be8c9dc53ff)
      --app-secret SECRET     OVH application secret (default: d37f35c27e60be58746e81e3351a84db)
      --consumer-key SECRET   OVH consumer key (default: 819fb70c64f91f797daf0ed3990e5ff0)
      --ovh-region REGION     OVH region (default: ovh-eu)
      --db DIR                Where to place the local sqlite database (default: /data/db)
      --mirror DIR            Where to place your archives (default: /data/mirror)
      --ldp-host HOST         If set, push logs of the current application to given LDP hostname
      --ldp-token TOKEN       If set, push logs of the current application to associated LDP stream token
      --chunk-size CHUNK      Download chunk size in bytes (default: 16384)
      --gpg-passphrase SECRET PGP private key passphrase (default: None)

Setup
=====

1. Create an application
------------------------

To interact with the APIs, the application needs to identify itself using an
``application_key`` and an ``application_secret``. To get them, you need
to register your application. Depending the API you plan to use, visit:

- `OVH Europe <https://eu.api.ovh.com/createApp/>`_
- `OVH US <https://api.ovhcloud.com/createApp/>`_
- `OVH North-America <https://ca.api.ovh.com/createApp/>`_
- `So you Start Europe <https://eu.api.soyoustart.com/createApp/>`_
- `So you Start North America <https://ca.api.soyoustart.com/createApp/>`_
- `Kimsufi Europe <https://eu.api.kimsufi.com/createApp/>`_
- `Kimsufi North America <https://ca.api.kimsufi.com/createApp/>`_

You will get 2 keys, **Application Key** and **Application Secret**.

On the restriction step, we invite you to set the following access rules::

    curl -XPOST -H"X-Ovh-Application: OVH_API_AK" -H "Content-type: application/json" \
    https://eu.api.ovh.com/1.0/auth/credential  -d '{
        "accessRules": [
            {
                "method": "GET",
                "path": "/dbaas/logs"
            },
            {
                "method": "GET",
                "path": "/dbaas/logs/*/encryptionKey/*"
            },
            {
                "method": "GET",
                "path": "/dbaas/logs/*/output/graylog/stream"
            },
            {
                "method": "GET",
                "path": "/dbaas/logs/*/output/graylog/stream/*/archive*"
            },
            {
                "method": "POST",
                "path": "/dbaas/logs/*/output/graylog/stream/*/archive/*/url"
            },
            {
                "method": "GET",
                "path": "/dbaas/logs/*/output/graylog/stream/*/archive/*/encryptionKey"
            }
        ],
        "redirection":"https://www.mywebsite.com/"
    }'

Replace ``OVH_API_AK`` by your **Application Key**.

In the curl response, you will have a validation URL ``validationUrl`` and a **Consumer Key** ``consumerKey``.
Please follow the link ``validationUrl`` and connect your OVH account (use unlimited lifespan).
Once the user has been authenticated, it will be automatically redirected to the URL you entered when the token was created
(*https://www.mywebsite.com/* in the previous example).

Once created, you will obtain an **application key (OVH_API_AK)**, an **application
secret (OVH_API_AS)** and a **consumer key (OVH_API_CK)**

2. Environment variables
------------------------

Default cli values can be set using environment:

============================  ====================  ============================================================================
Cli parameter                 Name                  About
============================  ====================  ============================================================================
--app-key                     OVH_API_AK            OVH application key
--app-secret                  OVH_API_AS            OVH application secret
--consumer-key                OVH_API_CK            OVH customer key
--ovh-region                  OVH_API_REGION        OVH api location. Default: *ovh-eu*
--db                          DB_DIRECTORY          Where to place the local sqlite database. Default: *db*
--mirror                      MIRROR_DIRECTORY      Where to place your archives. Default: *mirror*
--ldp-host                    LDP_HOST              If set, push logs of the current application to given LDP hostname
--ldp-token                   LDP_TOKEN             If set, push logs of the current application to associated LDP stream token
--chunk-size                  CHUNK_SIZE            Download chunk size in bytes
--gpg-passphrase              GPG_PASSPHRASE        PGP private key passphrase
============================  ====================  ============================================================================


3. Launch
---------

Once all the mandatory environment variables set, launch the process like this::

    $ ldp-mirror STREAM_ID [STREAM_ID ...]

This will:

- looks for the LDP service associated with the given **STREAM_ID** (s)
- populate a local cache with all the archives found on the API
- request for each of them a temporary download url
- download the files when unseal time is reached
- decrypt the archives if they are encrypted
- ask every hour the api if a new archive is available

Create docker image from sources
================================

As this application is supposed to be kept alive indefinitely, launching it from a Docker daemon looks obvious.

To build the image form the sources, uses the given ``Makefile``::

    $ git clone https://github.com/ovh/ldp-archive-mirror
    $ cd ldp-archive-mirror
    $ make build-docker

And to run it::

    $ mkdir -p ~/ldp-archive-mirror/db ~/ldp-archive-mirror/mirror
    $ docker run -d \
        --name ldp-archive-mirror \
        --user $(id -u):$(id -g) \
        -v ${HOME}/ldp-archive-mirror/mirror/:/data/mirror \
        -v ${HOME}/ldp-archive-mirror/db:/data/db \
        -v ${HOME}/.gnupg:/data/gnupg \
        -e OVH_API_AK=MY_OVH_AK \
        -e OVH_API_AS=MY_OVH_AS \
        -e OVH_API_CK=MY_OVH_CK \
        -e GPG_PASSPHRASE=MY_GPG_PRIVATE_KEY_PASSPHRASE \
        ldp-archive-mirror --ldp-host graX.logs.ovh.com MY_LDP_STREAM_ID_1 MY_LDP_STREAM_ID_2

Replace ``graX.logs.ovh.com`` by your LDP cluster address, ``MY_LDP_STREAM_ID_1``/``MY_LDP_STREAM_ID_2``/... by your LDP stream id.

Requirements
============

- Python >= 3.6

Project Links
=============

- PyPI: https://pypi.python.org/pypi/ldp-archive-mirror
- Issues: https://github.com/ovh/ldp-archive-mirror/issues

License
=======

`OVH SAS <https://github.com/ovh/ldp-archive-mirror/blob/master/LICENSE>`_

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/ovh/ldp-archive-mirror",
    "name": "ldp-archive-mirror",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "LDP OVH",
    "author": "OVH Group",
    "author_email": "opensource@ovh.net",
    "download_url": "https://files.pythonhosted.org/packages/89/32/663d1ddf64ad32100c18230a7c178f697ff0032cc5f528696f8d5e76e832/ldp-archive-mirror-0.2.0.tar.gz",
    "platform": null,
    "description": "***********************************\nLogs Data Platform - Archive mirror\n***********************************\n\n.. image:: https://img.shields.io/pypi/v/ldp-archive-mirror.svg\n   :target: https://pypi.python.org/pypi/ldp-archive-mirror/\n   :alt: Latest Version\n\n.. image:: https://travis-ci.org/ovh/ldp-archive-mirror.svg?branch=master\n   :target: https://travis-ci.org/ovh/ldp-archive-mirror\n   :alt: Latest version\n\nThis tools allows you to get a local copy of all your cold stored archives on Logs Data Platform::\n\n    [2018-12-14 17:20:00,200 INFO LDP Mirror] Create local DB if not exists\n    [2018-12-14 17:20:00,204 INFO LDP Mirror] Looking for new archives of stream e9397556-31d1-4d4d-b2bd-e5367b522cc8\n    [2018-12-14 17:20:05,190 INFO LDP Mirror] Service ldp-jb-52560 found for stream e9397556-31d1-4d4d-b2bd-e5367b522cc8\n    [2018-12-14 17:20:05,579 INFO LDP Mirror] Archive 9fb75957-2cde-435e-bdd9-6dfd33663f2c added to cache\n    [2018-12-14 17:20:05,850 INFO LDP Mirror] Archive 11d8630a-7b38-4fa4-9d7c-dfd17b0b00f6 added to cache\n    ...\n    [2018-12-14 17:20:08,392 INFO LDP Mirror] Directory mirror/e9397556-31d1-4d4d-b2bd-e5367b522cc8 created\n    [2018-12-14 17:20:08,535 INFO LDP Mirror] Archive e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-10.zst missing, download scheduled\n    [2018-12-14 17:20:08,635 INFO LDP Mirror] Archive e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-11.zst missing, download scheduled\n    ...\n    [2018-12-14 17:20:09,535 INFO LDP Mirror] Will retry to download e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-10.zst after 596 seconds\n    [2018-12-14 17:20:09,745 INFO LDP Mirror] Will retry to download e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-11.zst after 598 seconds\n    ...\n    [2018-12-14 17:20:10,927 INFO LDP Mirror] Archive e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-10.zst downloaded\n    [2018-12-14 17:20:11,655 INFO LDP Mirror] Sha256 OK on e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-10.zst\n    [2018-12-14 17:20:10,927 INFO LDP Mirror] Archive e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-11.zst downloaded\n    [2018-12-14 17:20:11,655 INFO LDP Mirror] Sha256 OK on e9397556-31d1-4d4d-b2bd-e5367b522cc8/2018-12-11.zst\n\n\nQuickstart\n==========\n\nFirst, install **ldp-archive-mirror** using `pip <https://pip.pypa.io/en/stable/>`_::\n\n    pip3 install -U ldp-archive-mirror\n\nThen you can use the binary ``ldp-mirror``::\n\n    usage: ldp-mirror [-h] [--app-key KEY] [--app-secret SECRET]\n                  [--consumer-key KEY] [--ovh-region REGION] [--db DIR]\n                  [--mirror DIR] [--ldp-host HOST] [--ldp-token TOKEN]\n                  [--chunk-size CHUNK] [--gpg-passphrase SECRET]\n                  STREAM_ID [STREAM_ID ...]\n\n    LDP archive Mirror CLI - 0.2.0\n\n    positional arguments:\n      STREAM_ID            LDP Stream UUIDs\n\n    optional arguments:\n      -h, --help              show this help message and exit\n      --app-key KEY           OVH application key (default: dcd57be8c9dc53ff)\n      --app-secret SECRET     OVH application secret (default: d37f35c27e60be58746e81e3351a84db)\n      --consumer-key SECRET   OVH consumer key (default: 819fb70c64f91f797daf0ed3990e5ff0)\n      --ovh-region REGION     OVH region (default: ovh-eu)\n      --db DIR                Where to place the local sqlite database (default: /data/db)\n      --mirror DIR            Where to place your archives (default: /data/mirror)\n      --ldp-host HOST         If set, push logs of the current application to given LDP hostname\n      --ldp-token TOKEN       If set, push logs of the current application to associated LDP stream token\n      --chunk-size CHUNK      Download chunk size in bytes (default: 16384)\n      --gpg-passphrase SECRET PGP private key passphrase (default: None)\n\nSetup\n=====\n\n1. Create an application\n------------------------\n\nTo interact with the APIs, the application needs to identify itself using an\n``application_key`` and an ``application_secret``. To get them, you need\nto register your application. Depending the API you plan to use, visit:\n\n- `OVH Europe <https://eu.api.ovh.com/createApp/>`_\n- `OVH US <https://api.ovhcloud.com/createApp/>`_\n- `OVH North-America <https://ca.api.ovh.com/createApp/>`_\n- `So you Start Europe <https://eu.api.soyoustart.com/createApp/>`_\n- `So you Start North America <https://ca.api.soyoustart.com/createApp/>`_\n- `Kimsufi Europe <https://eu.api.kimsufi.com/createApp/>`_\n- `Kimsufi North America <https://ca.api.kimsufi.com/createApp/>`_\n\nYou will get 2 keys, **Application Key** and **Application Secret**.\n\nOn the restriction step, we invite you to set the following access rules::\n\n    curl -XPOST -H\"X-Ovh-Application: OVH_API_AK\" -H \"Content-type: application/json\" \\\n    https://eu.api.ovh.com/1.0/auth/credential  -d '{\n        \"accessRules\": [\n            {\n                \"method\": \"GET\",\n                \"path\": \"/dbaas/logs\"\n            },\n            {\n                \"method\": \"GET\",\n                \"path\": \"/dbaas/logs/*/encryptionKey/*\"\n            },\n            {\n                \"method\": \"GET\",\n                \"path\": \"/dbaas/logs/*/output/graylog/stream\"\n            },\n            {\n                \"method\": \"GET\",\n                \"path\": \"/dbaas/logs/*/output/graylog/stream/*/archive*\"\n            },\n            {\n                \"method\": \"POST\",\n                \"path\": \"/dbaas/logs/*/output/graylog/stream/*/archive/*/url\"\n            },\n            {\n                \"method\": \"GET\",\n                \"path\": \"/dbaas/logs/*/output/graylog/stream/*/archive/*/encryptionKey\"\n            }\n        ],\n        \"redirection\":\"https://www.mywebsite.com/\"\n    }'\n\nReplace ``OVH_API_AK`` by your **Application Key**.\n\nIn the curl response, you will have a validation URL ``validationUrl`` and a **Consumer Key** ``consumerKey``.\nPlease follow the link ``validationUrl`` and connect your OVH account (use unlimited lifespan).\nOnce the user has been authenticated, it will be automatically redirected to the URL you entered when the token was created\n(*https://www.mywebsite.com/* in the previous example).\n\nOnce created, you will obtain an **application key (OVH_API_AK)**, an **application\nsecret (OVH_API_AS)** and a **consumer key (OVH_API_CK)**\n\n2. Environment variables\n------------------------\n\nDefault cli values can be set using environment:\n\n============================  ====================  ============================================================================\nCli parameter                 Name                  About\n============================  ====================  ============================================================================\n--app-key                     OVH_API_AK            OVH application key\n--app-secret                  OVH_API_AS            OVH application secret\n--consumer-key                OVH_API_CK            OVH customer key\n--ovh-region                  OVH_API_REGION        OVH api location. Default: *ovh-eu*\n--db                          DB_DIRECTORY          Where to place the local sqlite database. Default: *db*\n--mirror                      MIRROR_DIRECTORY      Where to place your archives. Default: *mirror*\n--ldp-host                    LDP_HOST              If set, push logs of the current application to given LDP hostname\n--ldp-token                   LDP_TOKEN             If set, push logs of the current application to associated LDP stream token\n--chunk-size                  CHUNK_SIZE            Download chunk size in bytes\n--gpg-passphrase              GPG_PASSPHRASE        PGP private key passphrase\n============================  ====================  ============================================================================\n\n\n3. Launch\n---------\n\nOnce all the mandatory environment variables set, launch the process like this::\n\n    $ ldp-mirror STREAM_ID [STREAM_ID ...]\n\nThis will:\n\n- looks for the LDP service associated with the given **STREAM_ID** (s)\n- populate a local cache with all the archives found on the API\n- request for each of them a temporary download url\n- download the files when unseal time is reached\n- decrypt the archives if they are encrypted\n- ask every hour the api if a new archive is available\n\nCreate docker image from sources\n================================\n\nAs this application is supposed to be kept alive indefinitely, launching it from a Docker daemon looks obvious.\n\nTo build the image form the sources, uses the given ``Makefile``::\n\n    $ git clone https://github.com/ovh/ldp-archive-mirror\n    $ cd ldp-archive-mirror\n    $ make build-docker\n\nAnd to run it::\n\n    $ mkdir -p ~/ldp-archive-mirror/db ~/ldp-archive-mirror/mirror\n    $ docker run -d \\\n        --name ldp-archive-mirror \\\n        --user $(id -u):$(id -g) \\\n        -v ${HOME}/ldp-archive-mirror/mirror/:/data/mirror \\\n        -v ${HOME}/ldp-archive-mirror/db:/data/db \\\n        -v ${HOME}/.gnupg:/data/gnupg \\\n        -e OVH_API_AK=MY_OVH_AK \\\n        -e OVH_API_AS=MY_OVH_AS \\\n        -e OVH_API_CK=MY_OVH_CK \\\n        -e GPG_PASSPHRASE=MY_GPG_PRIVATE_KEY_PASSPHRASE \\\n        ldp-archive-mirror --ldp-host graX.logs.ovh.com MY_LDP_STREAM_ID_1 MY_LDP_STREAM_ID_2\n\nReplace ``graX.logs.ovh.com`` by your LDP cluster address, ``MY_LDP_STREAM_ID_1``/``MY_LDP_STREAM_ID_2``/... by your LDP stream id.\n\nRequirements\n============\n\n- Python >= 3.6\n\nProject Links\n=============\n\n- PyPI: https://pypi.python.org/pypi/ldp-archive-mirror\n- Issues: https://github.com/ovh/ldp-archive-mirror/issues\n\nLicense\n=======\n\n`OVH SAS <https://github.com/ovh/ldp-archive-mirror/blob/master/LICENSE>`_\n",
    "bugtrack_url": null,
    "license": "OVH SAS",
    "summary": "This tools allows you to get a local copy of all your cold stored archives on Logs Data Platform.",
    "version": "0.2.0",
    "split_keywords": [
        "ldp",
        "ovh"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "8932663d1ddf64ad32100c18230a7c178f697ff0032cc5f528696f8d5e76e832",
                "md5": "4c3c7d32760865d2f152e23da6ab59ff",
                "sha256": "476c53a596280d7a3bbd7884f722f4a8f2adc2a21a1c2916a02f70ee26beb625"
            },
            "downloads": -1,
            "filename": "ldp-archive-mirror-0.2.0.tar.gz",
            "has_sig": false,
            "md5_digest": "4c3c7d32760865d2f152e23da6ab59ff",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 14819,
            "upload_time": "2023-03-10T11:40:18",
            "upload_time_iso_8601": "2023-03-10T11:40:18.847363Z",
            "url": "https://files.pythonhosted.org/packages/89/32/663d1ddf64ad32100c18230a7c178f697ff0032cc5f528696f8d5e76e832/ldp-archive-mirror-0.2.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-03-10 11:40:18",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "github_user": "ovh",
    "github_project": "ldp-archive-mirror",
    "travis_ci": true,
    "coveralls": false,
    "github_actions": false,
    "requirements": [],
    "lcname": "ldp-archive-mirror"
}
        
Elapsed time: 0.04818s