Metadata-Version: 2.1
Name: bitccl
Version: 0.4.0
Summary: The BitCCL scripting language compiler package
Home-page: https://github.com/bitcartcc/bitccl
Author: MrNaif2018
Author-email: chuff184@gmail.com
License: MIT
Description: <p align="center">
          <a href="https://bitcartcc.com"><img src="https://raw.githubusercontent.com/bitcartcc/bitccl/master/logo.png" alt="BitCCL"></a>
        </p>
        
        ---
        
        ![GitHub Workflow Status](https://img.shields.io/github/workflow/status/bitcartcc/bitccl/test?style=flat-square)
        ![Codecov](https://img.shields.io/codecov/c/github/bitcartcc/bitccl?style=flat-square)
        ![PyPI](https://img.shields.io/pypi/v/bitccl?style=flat-square)
        ![PyPI - Downloads](https://img.shields.io/pypi/dm/bitccl?style=flat-square)
        
        ---
        
        BitCCL is a [BitcartCC](https://bitcartcc.com) scripting language used for automating checkout flow and more.
        
        It is currently in alpha stage, being separated from the [main BitcartCC repository](https://github.com/bitcartcc/bitcart).
        
        ## Architechture
        
        BitCCL is basically Python, but:
        
        - Safe, with disabled import system
        - Robust, with many built-in functions
        - Optimized for running in BitcartCC environment
        
        Language file extension is `.bccl`.
        
        ## Running
        
        ```
        pip install -r requirements.txt
        ./compiler example.bitccl
        ```
        
        ## Built-in functions
        
        Current built-in functions list can be always seen in `functions.py` file.
        
        Table of built-in functions:
        
        | Signature                                 | Description                                                                                                                           | Return value                                         |
        | ----------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------- |
        | `add_event_listener(event, func)`         | Adds event listener `func` to be called when `event` is dispatched                                                                    | None                                                 |
        | `@on(event)`                              | A decorator used for registering functions to be called when `event` is dispatched. Example: `@on(ProductBought(1)) def func(): pass` | Wrapper function                                     |
        | `dispatch_event(event, *args, **kwargs)`  | Dispatch `event`, optionally passing positional or named arguments to event handlers                                                  | None                                                 |
        | `template(name, data={})`                 | Render template `name`, optionally passing `data` to it                                                                               | Template text on success, empty string("") otherwise |
        | `send_email(to, subject, text)`           | Sends email to email address `to`, with `subject` and `text`. Uses email server configuration from `config.json`                      | True on success, False otherwise                     |
        | `password(length=SECURE_PASSWORD_LENGTH)` | Generate cryptographically unique password of `length` if provided, otherwise uses safe enough length.                                | Generated password                                   |
        
        Also a http client is available.
        
        To send http request with it, use:
        
        `http.method(url)`
        
        To send HTTP method (get, post, delete, patch, etc.) to url.
        You can also optionally pass additional query parameters (params argument), request body data (data argument),
        files (files argument), headers (headers argument), cookies (cookie argument) and more.
        
        Here is how the most complex request might look like:
        
        ```python
        http.method(url, params={}, headers={}, cookies={}, auth=None, allow_redirects=True, cert="", verify=True, timeout=5.0)
        ```
        
        All arguments except for url are optional.
        
        After sending a request, you can retrieve response data:
        
        If res is response got from calling `http.method(...)`, then:
        
        `res.text` will return text data from response (for example, html)
        
        `res.content` will return binary data from response (for example, file contents)
        
        `res.json()` will return json data from response (for example, when accessing different web APIs)
        
        Response status code can be got as `res.status_code`.
        
        For convenience, you are provided with http request codes to easily check if request is successful without remembering the numbers.
        
        For example, `http_codes.OK` is status code 200 (success).
        So, to check if request has succeeded, you can check like so:
        
        ```python
        res = http.get("https://example.com")
        if res.status_code == http_codes.OK:
            print("Success")
        ```
        
        For additional information about built-in http client, you can read it's full [documentation](https://www.python-httpx.org/quickstart)
        
        Also, [BitcartCC SDK](https://sdk.bitcartcc.com) is available to use.
        
        To access coins without xpub to get transaction, fiat rate or anything else not requiring a wallet, you can access each coin by
        it's lowercase symbol, for example:
        
        ```python
        print(btc.rate())
        print(ltc.rate())
        print(bch.rate())
        print(xrg.rate())
        print(bsty.rate())
        ```
        
        **Note**: running coins' commands require it's daemon running if you are not using BitCCL from BitcartCC deployment.
        
        To perform operations requiring a wallet, use upper-case coin symbol, passing xpub/ypub/zpub/xprv/yprv/zprv/electrum seed in it:
        
        ```python
        coin = BTC(xpub="my xpub")
        print(coin.balance())
        # or if using only once:
        print(BTC(xpub="my xpub").balance())
        ```
        
        ## Built-in events
        
        Refer to [events.md](events.md).
        
        It is generated automatically from BitCCL code.
        
        ## Plugin system
        
        If using BitCCL programmatically, you can extend it's execution context with plugins.
        
        Pass a list of plugin-like objects to `run` function, like so:
        
        ```python
        from bitccl import run
        
        run("print(x)", plugins=[TestPlugin()])
        ```
        
        Each plugin can be anything: class, object, module object, it must have two methods:
        
        `startup()` method returning dictionary, which will be used to update execution context with new variables
        
        `shutdown(context)` method which should perform a clean-up of injected variables if needed
        
        Here's TestPlugin code from above's example:
        
        ```python
        class TestPlugin:
            def startup(self):
                return {"x": 5}
        
            def shutdown(self, context):
                pass
        ```
        
        ## How does BitCCL secure the users
        
        BitCCL uses [RestrictedPython](https://pypi.org/project/RestrictedPython/) project with some modifications.
        
        Before executing arbitrary code, which could possibly be copied by a merchant from unknown source, we parse it into AST tree.
        
        Then, by AST transformation, we delete dangerous operations or replace them to non-existing names (for example getattr to `_getattr_`)
        
        The following code:
        
        ```python
        x.foo = x.foo + x[0]
        ```
        
        is transformed to:
        
        ```python
        _write(x).foo = _getattr(x, 'foo') + _getitem(x, 0)
        ```
        
        That way, our built-in functions have access to what they need, but user code is restricted.
        
        If some dangerous operations are found at AST transforming stage, `CompilationRestrictedError` is raised with a list of errors.
        
        That way, in many cases code won't even be executed if it is dangerous.
        
        Afterwards, we execute the bytecode with a pretty limited `globals` object, with safer replacements for built-in functions.
        
        3 main points making it secure:
        
        - Imports are disabled (`import os; os.removedirs("/")` or similar won't work)
        - The main one: accessing magic attributes is disallowed, like `__class__`, `__base__`, `__subclasses__` and similar
          It is not useful for user code, but opens many possible security holes
          The worst example is this:
        
          ```python
          print((1).__class__.__base__.__subclasses__())
          ```
        
          It could be used to access any class in your program, but accessing `__class__` and further is disallowed.
          It also disallowed such cases as `template.__globals__['os'].listdir('/')` and many others
        
        - Also, by providing a limited amount of globals, unsafe ones are excluded, so you are provided only with useful, but safe tools
        
        ## Contributing
        
        You can contribute to BitCCL language by suggesting new built-in functions and events to be added, as well as any ideas for improving it.
        Open an [issue](https://github.com/bitcartcc/bitccl/issues/new/choose) to suggest new features
        
        Also see our [contributing guidelines](CONTRIBUTING.md).
        
        ## Copyright and License
        
        Copyright (C) 2020 MrNaif2018
        
        Licensed under the [MIT license](LICENSE)
        
Keywords: bitcartcc,bitccl,programminglanguage,compiler
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Requires-Python: >=3.8
Description-Content-Type: text/markdown
