Metadata-Version: 2.1
Name: remote-config
Version: 0.1.5
Summary: Remote config and feature toggle based on Consul.
Home-page: https://github.com/lojaintegrada/remote-config
Author: Loja Integrada
Author-email: suporte@lojaintegrada.com.br
License: MIT
Description: # Remote Config
        
        Essa biblioteca tem como funcionalidade capturar os mapeamentos de features ativas por clusters e disponibilizar em memória, juntamente com as variáveis de ambientes lá registradas.
        
        ## Clusters
        
        O mapeamento dos clusters ficarão listadas dentro da pasta `clusters` que se encontra na pasta `general` na raiz do Key / Value.
        
        Para cada cluster se faz necessário criar uma key com o nome do cluster ex: `cluster-google-merchant`
        
        Contendo a lista de id's das lojas no seguinte formato:
        
        ```json
        {
          "ids": [123, 456]
        }
        ```
        
        ## Feature Toggle
        
        O mapeamento dos clusters ficarão listadas dentro da pasta `feature-toggle` que se encontra na pasta `general` na raiz do Key / Value.
        
        Para cada feature se faz necessário criar uma key com o nome da feature ex: `google-merchant`
        
        O valor dentro desta key deve ser no formato do JSON a baixo:
        
        ```json
        {
          "enable": true,
          "default": false,
          "clusters": ["general/feature-toggle/cluster-google-merchant"]
        }
        ```
        
        A propriedade `enable` define se a feature está ativada para aplicação como um todo.
        
        A propriedade `cluster` define uma lista dos caminhos dos clusters.
        
        A propriedade `default` define o comportamento padrão caso o `enable` esteja false e a loja não esteja em nenhum cluster.
        
        ## Como usar
        
        Inicializando o singleton e já configurando os tempos de atualização de cache
        
        ```python
        from django.conf import settings
        class CoreConfig(AppConfig):
            name = "core"
        
             def ready(self):
                from remote_config import RemoteConfig
                RemoteConfig(host=URL, port=80, token=TOKEN, minutes=5).start()
        ```
        
        Para fazer uma checagem da feature, basta só iniciar o `RemoteConfig` sem as configurações pois elas já forão inicializadas e chamara a função `get_feature` que retornará um boleano
        
        ```python
        RemoteConfig().get_feature('google-merchant', 123)
        ```
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Environment :: Web Environment
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2.7
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Internet
Description-Content-Type: text/markdown
