Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Data further refactor #2574

Closed
wants to merge 84 commits into from
Closed
Show file tree
Hide file tree
Changes from 81 commits
Commits
Show all changes
84 commits
Select commit Hold shift + click to select a range
770ddb6
feat: add Pointer type and make LinkedList outputs optional
dirvine Dec 22, 2024
305d3b5
feat: add Python bindings for ChunkAddress and Pointer types, update …
dirvine Dec 23, 2024
961b08d
refactor: update self_encryption to use streaming API - Replace DataM…
dirvine Dec 24, 2024
aa8ac9c
docs: add architecture documentation and update cargo.toml
dirvine Dec 24, 2024
690727f
refactor: remove WASM support - Remove WASM dependencies and crate-ty…
dirvine Dec 24, 2024
d39a8c4
fix: improve local network testing - Require only one peer when in lo…
dirvine Dec 25, 2024
7523772
refactor(network): Simplify LocalNode implementation
dirvine Dec 25, 2024
d68a1cc
feat(network): update LocalNode to use antnode binary with mDNS disco…
dirvine Dec 26, 2024
393df0f
refactor: make local mode runtime configurable
dirvine Dec 27, 2024
53d4e9e
refactor: improve network interface detection and QUIC support
dirvine Dec 27, 2024
babbb7d
refactor: Update local network to use find_local_ip() and QUIC
dirvine Dec 27, 2024
315d763
refactor: update NetworkBuilder usage to handle local mode and bootst…
dirvine Dec 27, 2024
b567fe9
fix(tests): improve local node test reliability and debugging
dirvine Dec 28, 2024
c17a9d8
refactor: improve error handling and test infrastructure
dirvine Dec 28, 2024
65cb070
refactor(test-utils): use temporary directory for EVM wallet tests
dirvine Dec 28, 2024
1fb4558
refactor: move find_local_ip to ant-bootstrap utils
dirvine Dec 28, 2024
f6e1687
feat: add local test suite and CI workflow
dirvine Dec 29, 2024
f930ce6
fix: update test scripts to handle port conflicts
dirvine Dec 29, 2024
f640081
feat: improve test scripts to handle existing EVM network
dirvine Dec 29, 2024
60a9878
refactor: remove transaction.rs test file
dirvine Dec 29, 2024
b33665c
feat: expose LinkedList types in public API
dirvine Dec 29, 2024
d1bf2ef
refactor: update transaction references to linked list - Replace tran…
dirvine Dec 29, 2024
d5b45c4
feat: add nodejs typescript bindings structure - Add initial TypeScri…
dirvine Dec 29, 2024
5cefb8f
docs: add detailed Node.js bindings documentation - Add installation …
dirvine Dec 29, 2024
5651c73
docs: add comprehensive API documentation and guides for Node.js, Pyt…
dirvine Dec 29, 2024
984b071
docs: set up MkDocs with Material theme and GitHub Actions deployment
dirvine Dec 29, 2024
4c10cf9
docs: update README and add comprehensive contributing guide with doc…
dirvine Dec 29, 2024
5b011e0
docs: add comprehensive data storage guide covering self-encryption a…
dirvine Dec 29, 2024
caab056
docs: add Files, Directories, Archive, and Vault documentation to API…
dirvine Dec 29, 2024
0d35c9c
chore: remove node_modules from git tracking and add to gitignore
dirvine Dec 29, 2024
f62319f
chore: add node_modules to gitignore
dirvine Dec 29, 2024
2842b74
refactor: move local feature to test feature to ensure production bui…
dirvine Dec 29, 2024
db04114
fix: remove node_modules
dirvine Dec 29, 2024
37f369d
fix: update test scripts to use local feature for ant-node and test f…
dirvine Dec 29, 2024
67674a9
fix: update test files to use test feature and fix imports
dirvine Dec 29, 2024
7706528
refactor: improve test-local.sh script with configuration and helper …
dirvine Dec 29, 2024
6e7b83e
feat: add start-local-network.sh script and documentation for local d…
dirvine Dec 29, 2024
70fcb78
docs: add comprehensive payments guide for put operations
dirvine Dec 29, 2024
34e6334
docs: add local development guide to navigation
dirvine Dec 29, 2024
93beb55
docs: remove incorrect Docker requirement and improve local network g…
dirvine Dec 29, 2024
10ff17f
docs: enhance EVM network and monitoring/debugging sections in local …
dirvine Dec 29, 2024
8f71bf5
doc: exclude site packages
dirvine Dec 29, 2024
7432767
docs: add client modes guide and update API documentation
dirvine Dec 29, 2024
7c37839
docs: update mkdocs navigation and fix broken links
dirvine Dec 29, 2024
dc1925d
docs: add comprehensive data types guide and reorganize documentation…
dirvine Dec 29, 2024
03e916a
docs: enhance data types guide with detailed technical information
dirvine Dec 29, 2024
e529c59
docs: update documentation styling to match autonomi.com website design
dirvine Dec 29, 2024
76f87c2
docs: add library documentation and update API references
dirvine Dec 29, 2024
d388783
chore: update mkdocs emoji configuration
dirvine Dec 29, 2024
2b4c8da
chore: simplify mkdocs configuration
dirvine Dec 29, 2024
61580a0
fix: ignore cache files
dirvine Dec 29, 2024
6407abf
docs: add comprehensive development guides for web, quantum security,…
dirvine Dec 29, 2024
a66c726
docs: fix code block styling and broken documentation links
dirvine Dec 29, 2024
f2dff57
docs: update quantum security guide to clarify BLS vs self-encryption…
dirvine Dec 29, 2024
a7372e3
docs: update API documentation styling and content
dirvine Dec 29, 2024
b486f14
docs: reorganize API reference to show all languages together
dirvine Dec 29, 2024
46ca746
docs: fix relative links in API documentation
dirvine Dec 29, 2024
74852a3
docs: update API documentation with improved descriptions and light m…
dirvine Dec 29, 2024
eec2af3
docs: consolidate API documentation into a single file with language …
dirvine Dec 29, 2024
9bb54f4
docs: consolidate API documentation into single file with all languag…
dirvine Dec 29, 2024
d68a912
docs: update mkdocs navigation for consolidated API documentation
dirvine Dec 29, 2024
7715bc3
docs: remove unused documentation files and reorganize structure
dirvine Dec 29, 2024
84781e3
docs: update API reference links to point to consolidated documentation
dirvine Dec 29, 2024
bac89f0
docs: update API documentation to use tabbed code blocks for language…
dirvine Dec 29, 2024
95b5190
docs: update installation and API docs to reflect current implementation
dirvine Dec 29, 2024
15ae771
docs: update navigation to include all guides and improve structure
dirvine Dec 29, 2024
ca49d58
docs: add build from source instructions for all languages
dirvine Dec 29, 2024
0ff4358
docs: add comprehensive API documentation for all components
dirvine Dec 29, 2024
e6a1b21
docs: fix broken links in documentation
dirvine Dec 29, 2024
4163113
doc: update nav
dirvine Dec 29, 2024
f1166dd
docs: reorganize documentation structure and fix links
dirvine Dec 29, 2024
5a8e5b5
fix: moved docs
dirvine Dec 29, 2024
8081818
doc: api nav
dirvine Dec 29, 2024
f858d2e
docs: update self-encryption API docs with streaming operations and c…
dirvine Dec 29, 2024
5da28a6
docs: remove Quick Start guide and references
dirvine Dec 29, 2024
09b81ed
docs: add core concepts to Quick Links section
dirvine Dec 29, 2024
5881159
docs: update main documentation index with improved installation and …
dirvine Dec 29, 2024
bc74e67
doc: docstring nano -> atto
dirvine Dec 30, 2024
c0b6e9a
doc: API ref
dirvine Dec 30, 2024
2faf271
doc: index layout
dirvine Dec 30, 2024
a243be6
chore: update Cargo.lock after rebase
dirvine Dec 30, 2024
79fe678
fix: handle local feature flag in tests and fix record store tests
dirvine Dec 30, 2024
cb6882d
refactor: remove encrypt-records feature flag and make encryption man…
dirvine Dec 30, 2024
81cadb9
refactor: remove fs and encrypted_records feature flags - Remove fs f…
dirvine Dec 30, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 4 additions & 3 deletions .github/workflows/benchmark-prs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,10 +40,11 @@ jobs:
# As normal user won't care much about initial client startup,
# but be more alerted on communication speed during transmission.
# Meanwhile the criterion testing code includes the client startup as well,
# it will be better to execute bench test with `local`,
# to make the measurement results reflect speed improvement or regression more accurately.
# we'll use local feature for ant-node and test feature for autonomi
- name: Build binaries
run: cargo build --release --features local --bin antnode --bin ant
run: |
cargo build --release --features local --bin antnode
cargo build --release --features test --bin ant
timeout-minutes: 30

- name: Start a local network
Expand Down
36 changes: 36 additions & 0 deletions .github/workflows/docs.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
name: Deploy Documentation
on:
push:
branches:
- main
- data_further_refactor
pull_request:
branches:
- main

permissions:
contents: write

jobs:
deploy:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0

- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.11'

- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install mkdocs-material mkdocstrings mkdocstrings-python mkdocs-git-revision-date-localized-plugin

- name: Deploy Documentation
run: |
git config --global user.name "github-actions"
git config --global user.email "[email protected]"
mkdocs gh-deploy --force
57 changes: 57 additions & 0 deletions .github/workflows/test-local.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
name: Local Tests

on:
push:
branches: [ main, develop ]
pull_request:
branches: [ main, develop ]

env:
CARGO_TERM_COLOR: always

jobs:
test:
name: Run Local Tests
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4

- name: Install Rust
uses: dtolnay/rust-toolchain@stable

- name: Cache Dependencies
uses: Swatinem/rust-cache@v2

- name: Install Foundry
uses: foundry-rs/foundry-toolchain@v1

- name: Build ant-node with local feature
run: cargo build -p ant-node --features local

- name: Build evm-testnet
run: cargo build -p evm-testnet

- name: Run Local Tests
run: |
# Kill any existing antnode processes
pkill -f "antnode" || true

# Check if port 4343 is in use
if ! nc -z localhost 4343; then

Check notice

Code scanning / devskim

Accessing localhost could indicate debug code, or could hinder scaling. Note test

Do not leave debug code in production
# Start EVM testnet
RPC_PORT=4343 ./target/debug/evm-testnet --genesis-wallet 0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266 &
EVM_PID=$!

# Wait for EVM testnet to be ready
sleep 5
else
echo "Port 4343 is already in use, assuming EVM network is running..."
fi

# Run tests with test feature
RUST_LOG=trace cargo test -p autonomi --features test -- --nocapture

# Cleanup
kill $EVM_PID || true
pkill -f "antnode" || true
4 changes: 4 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -40,3 +40,7 @@ uv.lock
*.swp

/vendor/
node_modules/
site/
.cache/

177 changes: 74 additions & 103 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -1,136 +1,107 @@
# Contributing to the Safe Network
# Contributing to Autonomi

:tada: Thank you for your interest in contributing to the Safe Network! :tada:
We love your input! We want to make contributing to Autonomi as easy and transparent as possible, whether it's:

This document is a set of guidelines for contributing to the Safe Network. These are guidelines, not rules. This guide is designed to make it easy for you to get involved.
- Reporting a bug
- Discussing the current state of the code
- Submitting a fix
- Proposing new features
- Improving documentation

Notice something amiss? Have an idea for a new feature? Feel free to create an issue in this GitHub repository about anything that you feel could be fixed or improved. Examples include:
## Contributing Documentation

- Bugs, crashes
- Enhancement ideas
- Unclear documentation
- Lack of tutorials and hello world examples
- ... and more
Our documentation is hosted at [https://dirvine.github.io/autonomi/](https://dirvine.github.io/autonomi/) and is built using MkDocs with the Material theme.

See our [Issues and Feature Requests](#issues-and-feature-requests) section below for further information on creating new issues.
### Setting Up Documentation Locally

Of course, after submitting an issue you are free to assign it to yourself and tackle the problem, or pick up any of the other outstanding issues yet to be actioned - see the [Development](#development) section below for more information.
1. Clone the repository:

Further support is available [here](#support).
```bash
git clone https://github.com/dirvine/autonomi.git
cd autonomi
```

This project adheres to the [Contributor Covenant](https://www.contributor-covenant.org/). By participating, we sincerely hope that you honour this code.
2. Install documentation dependencies:

## What we're working on
```bash
pip install mkdocs-material mkdocstrings mkdocstrings-python mkdocs-git-revision-date-localized-plugin
```

The best way to follow our progress is to read the [MaidSafe Dev Updates](https://safenetforum.org/c/development/updates), which are published every week (on Thursdays) on the [Safe Network Forum](https://safenetforum.org/).
3. Run the documentation server locally:

See our [Development Roadmap](https://safenetwork.tech/roadmap/) for more information on our near term development focus and longer term plans.
```bash
mkdocs serve
```

## Issues and Feature Requests
4. Visit `http://127.0.0.1:8000` to see your changes.

Each MaidSafe repository should have a `bug report` and a `feature request` template option when creating a new issue, with guidance and required information specific to that repository detailed within. Opening an issue in each repository will auto-populate your issue with this template.
### Documentation Structure

As per the issue templates, bug reports should clearly lay out the problem, platform(s) experienced on, as well as steps to reproduce the issue. This aids in fixing the issue and validating that the issue has indeed been fixed if the reproduction steps are followed. Feature requests should clearly explain what any proposed new feature would include, resolve or offer.
```
docs/
├── api/ # API Reference
│ ├── nodejs/
│ ├── python/
│ └── rust/
├── guides/ # User Guides
│ ├── local_network.md
│ ├── evm_integration.md
│ └── testing_guide.md
└── getting-started/ # Getting Started
├── installation.md
└── quickstart.md
```

Each issue is labelled by the team depending on its type, typically the standard labels we use are:
### Making Documentation Changes

- `bug`: the issue is a bug in the product
- `feature`: the issue is a new and non-existent feature to be implemented in the product
- `enhancement`: the issue is an enhancement to either an existing feature in the product or to the infrastructure around the development process of the product
- `blocked`: the issue cannot be resolved as it depends on a fix in any of its dependencies
- `good first issue`: an issue considered more accessible for any developer who would like to start contributing
- `help wanted`: an issue considered lower priority for the MaidSafe team, but one that would appear to be suitable for an outside developer who would like to contribute
1. Create a new branch:

These labels are meant as a soft guide, if you want to work on an issue which doesn't have a `good first issue` or `help wanted` label, by all means fill your boots!
```bash
git checkout -b docs/your-feature-name
```

## Development
2. Make your changes to the documentation files in the `docs/` directory.

At MaidSafe, we follow a common development process. We use [Git](https://git-scm.com/) as our [version control system](https://en.wikipedia.org/wiki/Version_control). We develop new features in separate Git branches, raise [pull requests](https://help.github.com/en/articles/about-pull-requests), put them under peer review, and merge them only after they pass QA checks and [continuous integration](https://en.wikipedia.org/wiki/Continuous_integration) (CI). We do not commit directly to the `master` branch.
3. Test your changes locally using `mkdocs serve`.

For useful resources, please see:
4. Commit your changes:

- [Git basics](https://git-scm.com/book/en/v1/Getting-Started-Git-Basics) for Git beginners
- [Git best practices](https://sethrobertson.github.io/GitBestPractices/)
```bash
git add docs/
git commit -m "docs: describe your changes"
```

We ask that if you are working on a particular issue, you ensure that the issue is logged in the GitHub repository and you assign that issue to yourself to prevent duplication of work.
5. Push to your fork and submit a pull request.

### Code Style
## Development Process

In our [Rust Programming Language](https://www.rust-lang.org/) repositories we follow the company-wide code style guide that you can find in the [the Rust Style document](https://github.com/maidsafe/QA/blob/master/Documentation/Rust%20Style.md). You should install `rustfmt` and `clippy` and run them before each of your Git commits.
1. Fork the repo and create your branch from `main`.
2. If you've added code that should be tested, add tests.
3. If you've changed APIs, update the documentation.
4. Ensure the test suite passes.
5. Make sure your code lints.
6. Issue that pull request!

For our non-Rust repositories we follow the standard lint suggestions, pre-linting before commit. We encourage our contributors to use a sensible naming convention, split their files up accordingly, and include accompanying tests.
## Any contributions you make will be under the MIT Software License

### Commits
In short, when you submit code changes, your submissions are understood to be under the same [MIT License](LICENSE) that covers the project. Feel free to contact the maintainers if that's a concern.

We use the [Conventional Commit](https://www.conventionalcommits.org/en/v1.0.0-beta.3/) message style, usually including a scope. You can have a look at the commit history within each repository to see examples of our commits.
## Report bugs using GitHub's [issue tracker](https://github.com/dirvine/autonomi/issues)

All code should be pre-linted before commit. The use of pre-commit Git hooks is highly recommended to catch formatting and linting errors early.
We use GitHub issues to track public bugs. Report a bug by [opening a new issue](https://github.com/dirvine/autonomi/issues/new).

### Pull Requests
## Write bug reports with detail, background, and sample code

If you are a newbie to pull requests (PRs), click [here](https://github.com/firstcontributions/first-contributions) for an easy-to-follow guide (with pictures!).
**Great Bug Reports** tend to have:

We follow the standard procedure for submitting PRs. Please refer to the [official GitHub documentation](https://help.github.com/articles/creating-a-pull-request/) if you are unfamiliar with the procedure. If you still need help, we are more than happy to guide you along!
- A quick summary and/or background
- Steps to reproduce
- Be specific!
- Give sample code if you can.
- What you expected would happen
- What actually happens
- Notes (possibly including why you think this might be happening, or stuff you tried that didn't work)

We are in the process of adding pull request templates to each MaidSafe repository, with guidance specific to that repository detailed within. Opening a PR in each repository will auto-populate your PR with this template. PRs should clearly reference an issue to be tracked on the project board. A PR that implements/fixes an issue is linked using one of the [GitHub keywords](https://help.github.com/articles/closing-issues-using-keywords) - note that these types of PRs will not be added themselves to a project board (to avoid redundancy with the linked issue). However, PRs which were submitted spontaneously and not linked to any existing issue will be added to the project board so they can be tracked, and should go through the same process as any other task/issue.
## License

Pull requests should strive to tackle one issue/feature, and code should be pre-linted before commit.

Each pull request's total lines changed should be <= 200 lines. This is calculated as `lines added` + `lines deleted`. Please split up any PRs which are larger than this, otherwise they may be rejected. A CI check has been added to fail PRs which are larger than 200 lines changed.

Ideally, a multi-commit PR should be a sequence of commits "telling a story", going in atomic and easily reviewable steps from the initial to the final state.

Each PR should be rebased on the latest upstream commit; avoid merging from the upstream branch into the feature branch/PR. This means that a PR will probably see one or more force-pushes to keep up to date with changes in the upstream branch.

Fixes to review comments should preferably be pushed as additional commits to make it easier for the reviewer to see the changes. As a final step once the reviewer is happy the author should consider squashing these fixes with the relevant commit.

Smaller PRs can have their commits squashed together and fast-forward merged, while larger PRs should probably have the chain of commits left intact and fast-forward merged into the upstream branch.

Where appropriate, commits should always contain tests for the code in question.

#### Running tests (CI script)

Submitted PRs are expected to pass continuous integration (CI), which, among other things, runs a test suite on your PR to make sure that your code has not regressed the code base.

#### Code Review

Your PR will be automatically assigned to the team member(s) specified in the `codeowners` file, who may either review the PR himself/herself or assign it to another team member. More often than not, a code submission will be met with review comments and changes requested. It's nothing personal, but nobody's perfect; we leave each other review comments all the time.

Fixes to review comments should preferably be pushed as additional commits to make it easier for the reviewer to see the changes. As a final step once the reviewer is happy the author should consider squashing these fixes with the relevant commit.

### Project board

GitHub project boards are used by the maintainers of the majority of our repositories to keep track of progress and organise development priorities.

There may be one or more active project boards for a repository. Typically, one main project is used to manage all tasks corresponding to the main development stream (normally the `master` branch), while a separate project would be used to manage each proof of concept or milestone, and each of them will track a dedicated development branch.

New features which involve a large number of changes may be developed in a dedicated feature branch, but would normally be tracked on the same main project board as the main development branch (normally `master` branch), re-basing it with the main branch regularly and fully testing the feature on its own branch before it is fully approved and merged into the main branch.

The main project boards typically contain the following Kanban columns to track the status of each development task:

- **To do**: new issues which need to be reviewed and evaluated to decide their priority, add labels, clarify, etc.
- **In Progress**: the task is assigned to a person and it is in progress
- **Needs Review**: the task is considered complete by the assigned developer and so has been sent for peer review
- **Reviewer approved**: the task has been approved by the reviewer(s) and is considered ready to be merged
- **Done**: the PR associated with the task was merged (or the task was completed by any other means)

The project board columns would typically include automation to move the issues between columns upon set actions, for example, if a PR was created which indicated in its description that it resolved a particular issue on the project board (using [GitHub keywords](https://help.github.com/articles/closing-issues-using-keywords)) then that issue would automatically be moved to the `Done` column on the board on PR merge.

## Releases and Changelog

The majority of our repositories have a Continuous Integration, Delivery & Deployment pipeline in place (CI/CD). Any PR raised must pass the automated CI tests and a peer review from a member of the team before being merged. Once merged there is no further manual involvement - the CD process kicks in and automatically increments the versioning according to the [Semantic Versioning specification](https://semver.org/), updates the Changelog, and deploys the latest code as appropriate for that repository. Every PR merged to master will result in a new release.

In repositories where CD has not been implemented yet, the release process is triggered by the maintainers of each repository, also with versioning increments according to the [Semantic Versioning specification](https://semver.org/). Releases are typically generated through our CI setup, which releases upon a trigger commit title (e.g. `Version change...`), or through specific programming language release tools such as `cargo release` or `yarn bump`.

Typically, for non CD repositories we only update/regenerate the [CHANGELOG file](CHANGELOG.md) with the latest changes on a new version release, where all changes since the last release are then added to the changelog file.

If a repository is for a library, or perhaps multiple libraries, then often no release artefact is produced. A tag would always be added to the repository on each release though, these tags can be viewed in the `/releases` page of each repository. Repositories which do produce artefacts, such as `.AppImage`, `.dmg` or `.exe` files, will have the release files available in the repository's `/release` page, or instructions there on how to obtain it.

## Support

Contributors and users can get support through the following official channels:

- GitHub issues: Log an issue in the repository where you require support.
- [Safe Network Forum](https://safenetforum.org/): Join our community forum, say hi, and discuss your support needs and questions with likeminded people.
- [Safe Dev Forum](https://forum.safedev.org/): Need to get technical with other developers? Join our developer forum and post your thoughts and questions.
- [Safe Network chat rooms](https://safenetforum.org/t/safe-network-chat-rooms/26070): The General chat room is a good place to ask for help. There is also a Development chat room for more technical discussion.
By contributing, you agree that your contributions will be licensed under its MIT License.
Loading
Loading