Python client¶
Installation¶
Open a terminal and run (Requires Python 3.9+):
pip install bframelib
Usage¶
bframelib
is a client that sits on top of a duckdb connection. Within the client is an interpreter that injects SQL based on the specified bframe views that are referenced (e.g. bframe.invoices
). Additional options are set within the library config and can control branching, system time and more.
Below is a short example to show the most direct usage of bframelib
.
from bframelib import Client
config = {
"org_id": 1,
"env_id": 1,
"branch_id": 1,
"rating_range": ['2025-01-01', '2026-01-01']
}
# The client will create a duckdb connection if it is not provided
bf = Client(config)
# Set up your source data (bframe uses duckdb if a source is not specified)
bf.execute("""
-- Set up the tenant
INSERT INTO src.organizations (id, name) values (1, 'Your business');
INSERT INTO src.environments (id, org_id, name) values (1, 1, 'PROD');
INSERT INTO src.branches (id, org_id, env_id, name) values (1, 1, 1, 'main');
-- Create customer
INSERT INTO src.customers (org_id, env_id, branch_id, id, durable_id, name) values (1, 1, 1, 1, 'abc', 'Customer name');
-- Create product
INSERT INTO src.products (org_id, env_id, branch_id, id, name, ptype) values (1, 1, 1, 1, 'Item', 'FIXED');
-- Create contract and prices
INSERT INTO src.contracts (org_id, env_id, branch_id, id, durable_id, customer_id, started_at, ended_at, effective_at) values (1, 1, 1, 1, 'abc_contract', 'abc', '2025-01-01', '2026-01-01', '2025-01-01');
INSERT INTO src.contract_prices (org_id, env_id, branch_id, id, product_uid, contract_uid, price, invoice_delivery, invoice_schedule) values (1, 1, 1, 1, 1, 1, '10.00', 'ARREARS', 1);
""")
# Generate invoices
res = bf.execute("""
SELECT
contract_id,
invoice_delivery,
started_at,
ended_at,
status,
total
FROM bframe.invoices
ORDER BY ended_at
""")
print(res.fetch_df().to_string())
# contract_id invoice_delivery started_at ended_at status total
# 0 abc_contract ARREARS 2025-01-01 2025-02-01 DRAFT 10.0
# 1 abc_contract ARREARS 2025-02-01 2025-03-01 DRAFT 10.0
# 2 abc_contract ARREARS 2025-03-01 2025-04-01 DRAFT 10.0
# 3 abc_contract ARREARS 2025-04-01 2025-05-01 DRAFT 10.0
# 4 abc_contract ARREARS 2025-05-01 2025-06-01 DRAFT 10.0
# 5 abc_contract ARREARS 2025-06-01 2025-07-01 DRAFT 10.0
# 6 abc_contract ARREARS 2025-07-01 2025-08-01 DRAFT 10.0
# 7 abc_contract ARREARS 2025-08-01 2025-09-01 DRAFT 10.0
# 8 abc_contract ARREARS 2025-09-01 2025-10-01 DRAFT 10.0
# 9 abc_contract ARREARS 2025-10-01 2025-11-01 DRAFT 10.0
# 10 abc_contract ARREARS 2025-11-01 2025-12-01 DRAFT 10.0
# 11 abc_contract ARREARS 2025-12-01 2026-01-01 DRAFT 10.0
API¶
The bframelib
is composed of a Client
and Interpreter
. The Client
is the primary interface for library users and the Interpreter
is the engine that powers the business logic. Both are exposed through the library but only more advanced use cases will utilize the interpreter directly.
Source
¶
A named tuple that represents a source.
__init__(src_type, connect_sql, init_schema)
¶
The initialization of the named tuple.
Parameters:
src_type
- An enum string to represent the source that is being attach. Possible values include (‘core’, ‘branch’, ‘events’).connect_sql
- A SQL string that is executed to assign the specified source. The function expects anATTACH
statement using the duckdb SQL dialect. An example of what this could look like:"ATTACH ':memory:' AS src;"
init_schema
- A boolean with a default value ofFalse
. If set toTrue
the source database attached will have the bframe schema executed on it.
Client
¶
A class that represents the bframe library interface for a duckdb connection.
config
¶
A property to view the current configuration options.
Returns: A dictionary of the library configurations that have been set.
__init__(config, sources, con)
¶
The initialization of the Client
class.
Parameters:
config
- A dictionary containing configuration options. Detailed option definitions can be found here.sources
- A list ofSource
tuples to be set. If no list is passed a default core source will be passed.con
- A pre-initializedduckdb connection
. If this is not present a new connection will be created.
set_config(config_updates)
¶
A function to set configuration options.
Parameters:
config_updates
- A dictionary containing one or more updates to the library config. Detailed option definitions can be found here.
Returns: Void
execute(query)
¶
A function to interpret bframe SQL and execute it on the given duckdb connection.
Parameters:
query
- A string containing one or more SQL statements.
Returns:
A DuckDBPyConnection
that holds the results of the executed SQL statement.
get_price_span_date_range(product_types)
¶
A function to pull the maximum time range of the currently configured invoices. This can enable effective use of event source partitions (e.g. only sourcing events that are needed for invoice generation).
Parameters:
product_types
- A tuple that contains one or more product types
Returns: A tuple with the first element representing the minimum start date of all invoices and the second element representing maximum end date of all invoices.
set_source(Source)
¶
A function to set the src
database bframe pulls data from. It will detach the existing src
during execution.
Parameters:
connect_sql
- A SQL string that is executed to assign thesrc
database. The function expects anATTACH
statement using the duckdb SQL dialect. An example of what this could look like:"ATTACH ':memory:' AS src;"
init_schema
- A boolean with a default value ofFalse
. If set toTrue
thesrc
database attached will have the bframe schema executed on it.
Returns: Void
interpreter.add_table_template(name, template)
¶
A function on the stored Interpreter
class that sets a user defined view.
Parameters:
name
- A string that represents the view name (e.g.bframe.YOUR_NAME_HERE
)template
- SQL that represents the view itself
Returns: Void