diff --git a/ARIES.md b/ARIES.md
deleted file mode 100644
index e69de29bb2..0000000000
diff --git a/CODEOWNERS b/CODEOWNERS
deleted file mode 100644
index a8782456f1..0000000000
--- a/CODEOWNERS
+++ /dev/null
@@ -1,4 +0,0 @@
-# SPDX-License-Identifier: Apache-2.0
-
-# Aries Framework RS Maintainers
-* @hyperledger/aries-vcx-maintainers
diff --git a/MAINTAINERS.md b/MAINTAINERS.md
index 96d091b540..210286a973 100644
--- a/MAINTAINERS.md
+++ b/MAINTAINERS.md
@@ -1,8 +1,8 @@
## Maintainers
### Active Maintainers
-| name | Github | Discord |
-|----------------|------------------------------------------------|----------------|
-| Patrik Stas | [@Patrik-Stas](https://github.com/Patrik-Stas) | Patrik Stas#7722 |
-| Miroslav Kovar | [@mirgee](https://github.com/mirgee) | mirgee#3763 |
-| Artem Minorov | [@left-arm](https://github.com/left-arm) | |
+| name | Github | Discord |
+|-----------------|------------------------------------------------|------------------|
+| Patrik Stas | [@Patrik-Stas](https://github.com/Patrik-Stas) | Patrik Stas#7722 |
+| Miroslav Kovar | [@mirgee](https://github.com/mirgee) | mirgee#3763 |
+| George Mulhearn | [@gmulhearn](https://github.com/gmulhearn) | gmulhearn#0356 |
diff --git a/README.md b/README.md
index d44b9d3437..5e7dd5e4a5 100644
--- a/README.md
+++ b/README.md
@@ -2,65 +2,45 @@
![CI build](https://github.com/hyperledger/aries-vcx/workflows/CI/badge.svg)
[![codecov](https://codecov.io/gh/hyperledger/aries-vcx/branch/main/graph/badge.svg)](https://codecov.io/gh/hyperledger/aries-vcx)
-[![Chat](https://raw.githubusercontent.com/hyperledger/chat-assets/master/aries-vcx.svg)](https://discord.com/channels/905194001349627914/955480822675308604)
-
-**Aries-vcx** is Rust library implementing Aries protocols. It can be used to build Aries agents.
-
-AriesVCX currently requires instance of [mediator agency](https://github.com/hyperledger/aries-rfcs/blob/master/concepts/0046-mediators-and-relays/README.md) - in
-particular [NodeVCX Agency](https://github.com/AbsaOSS/vcxagencynode/).
-To get your started with aries-vcx quickly, you can use our deployment at
-`https://ariesvcx.agency.staging.absa.id/agency`
-
-# C-Bindings
-- **libvcx** is library, which provides C-interface to interact with AriesVCX. C-bindings exists for:
- - Java (+Android)
- - iOS,
- - NodeJS
-
-
-# Get started
-The best way to get your hands on.
-* Simple Rust [Agent](./agents/rust/aries-vcx-agent)
-* Simple NodeJS [Agent](./agents/node/vcxagent-core)
-* Android [demo](https://github.com/sktston/vcx-demo-android) (3rd party demo)
-* iOS [demo](https://github.com/sktston/vcx-demo-ios) (3rd party demo)
-* iOS [skeleton project](https://github.com/sktston/vcx-skeleton-ios) (3rd party demo)
-
-# Implemented Aries protocols
-* ✅ Connection Protocol 1.0: [`https://didcomm.org/connections/1.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0160-connection-protocol)
-* ✅ Out of Band 1.0: [`https://didcomm.org/out-of-band/1.1/*`](https://github.com/hyperledger/aries-rfcs/blob/main/features/0434-outofband)
-* ✅ Basic Message 1.0: [`https://didcomm.org/basicmessage/1.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0095-basic-message)
-* ✅ Credential Issuance 1.0 [`https://didcomm.org/issue-credential/1.0/*`](https://github.com/hyperledger/aries-rfcs/blob/master/features/0036-issue-credential)
-* ✅ Credential Presentation 1.0: [`https://didcomm.org/present-proof/1.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0037-present-proof)
-* ✅ Trust Ping 1.0: [`https://didcomm.org/trust_ping/1.0/*`](https://github.com/hyperledger/aries-rfcs/blob/master/features/0048-trust-ping/README.md)
-* ✅ Discover Features 1.0: [`https://didcomm.org/discover-features/1.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0031-discover-features)
-* ✅ Revocation notification 2.0: [`https://didcomm.org/revocation_notification/2.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0031-discover-features)
-
-# Versioning
-- The project currently does not follow semantic versioning. Fow now we are releasing versions `0.x.x`.
-- Although the API is mostly stable, breaking changes still occur in our releases. See changelogs at
+[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
+[![Join the chat at https://chat.hyperledger.org/channel/aries](https://img.shields.io/badge/Chat%20on-Hyperledger%20Chat-blue)](https://chat.hyperledger.org/channel/aries)
+
+## Core crates:
+- [`aries-vcx`](aries_vcx) - **implementation of Hyperledger Aries protocols**
+- `messages` - crate encapsulating Aries message models and builders
+- `diddoc` - crate for working with DIDDocs
+- `agency-client` - client to communicate with [vcx mediator](https://github.com/AbsaOSS/vcxagencynode)
+
+## Additional crates:
+Additionally, you can find here project built on **top of `aries-vcx`**:
+- `agents/rust/aries-vcx-agent` - simple agent implementation in rust on top of `aries-vcx` crate
+- [`libvcx`](libvcx) - built on top of `aries-vcx`, is a particular approach how to use `aries-vcx` on
+ mobile or from other languages.
+
+## Getting started
+- Ask question on [discord](https://discord.com/channels/905194001349627914/955480822675308604)
+- Talk to us on community call starting every Thursday 09:00am UTC via [zoom](https://zoom.us/j/97759680284?pwd=VytRRlJSd3c5NXJ1V25XbUxNU0Jndz09)
+- See high level 2023 roadmap at [ROADMAP_2023.md](ROADMAP_2023.md)
+- Find out what's planned in [issues](https://github.com/hyperledger/aries-vcx/issues)
+ and project [board](https://github.com/orgs/hyperledger/projects/14)
+- We welcome new contributors! Connect with us via the channels above and take a look at [CONTRIBUTING.md](CONTRIBUTING.md)
+
+## Versioning
+- We are currently not following semantic versioning. Version are releasing `0.x.x` versions.
+- Breaking changes to APIs happen occasionally. See full changelogs records at
[releases](https://github.com/hyperledger/aries-vcx/releases) page.
-- See our [roadmap](./ROADMAP.md) for what's coming.
-# Project architecture
-The architecture is evolving - you can compare the diagram below with diagram under [roadmap](./roadmap.md).
+## CI artifacts
+Following artifacts are build with every CI run and release:
-#
+### Github Actions artifacts
+ - *(these are to be found at bottom of Summary page for each CI run)*
+ - `libvcx.so`, `libvcx.dylib` - dynamic library for x86_64 ubuntu, x86_64 darwin)
+ - ios and java wrapper built on top of `libvcx`
-# Artifacts
-Number of artifacts are built for every CI run (unless it's coming from a forked repository due to limitations of Github Actions).
-Artifacts tied with particular release can be found on
- [release page](https://github.com/hyperledger/aries-vcx/releases).
-
-## Artifacts produced:
-- Alpine based docker image with precompiled `libvcx.so`
-- iOS wrapper
-- Android wrapper
-- NodeJS wrapper
+### Images in Github Container Registry
+ - Alpine based Docker image with prebuilt `libvcx`; [ghcr.io/hyperledger/aries-vcx/libvcx:version](https://github.com/orgs/hyperledger/packages?repo_name=aries-vcx)
-#### When looking for artifacts for a particular CI run:
-- NodeJS wrapper is published at [npmjs](https://www.npmjs.com/package/@hyperledger/node-vcx-wrapper)
-- NodeJS agent is published at [npmjs](https://www.npmjs.com/package/@hyperledger/vcxagent-core)
-- Docker images are in [Github Packages](https://github.com/hyperledger/aries-vcx/packages)
-- Mobile artifacts are attached to [CI runs](https://github.com/hyperledger/aries-vcx/actions) (click on particular CI run to
- see the artifacts)
+### Packages on npmjs
+ - NodeJS wrapper - bindings for libvcx; [node-vcx-wrapper](https://www.npmjs.com/package/@hyperledger/node-vcx-wrapper)
+ - Simple NodeJS aries agent for testing; [vcxagent-core](https://www.npmjs.com/package/@hyperledger/vcxagent-core)
diff --git a/ROADMAP.md b/ROADMAP.md
deleted file mode 100644
index f4ffd15540..0000000000
--- a/ROADMAP.md
+++ /dev/null
@@ -1,59 +0,0 @@
-# A short history background
-LibVCX was library donated into IndySDK by Evernym around 2018. At that point of time Aries did not yet
-exist, and the library contained custom proprietary communication protocols of Evernym. In early 2020,
-Evernym has contributed implementation of the main Aries protocols. Later on in summer 2020, Absa has
-decided to fork the library, deleted legacy code and worked on improving code quality. In October 2020,
-Absa's forked version was brought back under Hyperledger umbrella and rebranded to "AriesVCX".
-
-The further development of the library can be split into a few phases, roughly marking important
-architectural milestones.
-
-# Phase 0 - Done ✅
-- We could call the phase from Absa's fork up until return to Hyperledger as Phase 0, the most of the
-code cleanup and code restructuring happened. We have
-- ✅ deleted legacy code,
-- ✅ migrated CI to Github Actions (building docker, ios, android artifacts)
-- ✅ changed library testing approach (favoring integration testing in language wrappers, removing
- encrypted mock inputs on rust-level unit testing)
-- ✅ thinned language wrappers (wrappers should use functions to access data, rather trying to map out
- Rust data structures).
-
-# Phase 1 - Done ✅
-This phase is all about decoupling parts of the library into independent modules. We have decoupled
-the library into 3 pieces.
-- ✅ `mediator agent client` - client for talking to a compatible agencies - the only open source
- implementation available is [vcxagencynode](https://github.com/AbsaOSS/vcxagencynode).
-- ✅ `aries-vcx` - the "glue" between Aries state machines, `libindy` and mediator agent.
-- ✅ `libvcx` - adds memory management and C bindings on top of `aries-vcx` - making it consumable
- on Android, iOS and any programming language.
-
-# Phase 2 - Done ✅
-- ✅ Migration from `libindy` to its fork [vdr-tools](https://gitlab.com/evernym/verity/vdr-tools).
-- ✅ Removal of blocking calls to `vdr-tools`
-- ✅ Support for public DID-based connection invitations
-- ✅ Support for [out-of-band protocol](https://github.com/hyperledger/aries-rfcs/tree/master/features/0434-outofband)
-- ✅ Implement testing backchannel for aries-vcx. [Test runs](https://github.com/hyperledger/aries-agent-test-harness/actions)
-- ✅ Removal of global state from `aries-vcx`
-- ✅ Support wallet multi-tenancy on aries-vcx level
-
-# Phase 2 - In progress 🚧 / Planned
-- ✅ Extract `aries-vcx::messages` module into `aries-messages` crate
-- ✅ Implement simple aries agent on top aries-vcx
-- ✅ Implement `aries-vcx - AFJ` AATH back-channel pair
-- 🚧 Remove FFI layer between `aries-vcx --- vdr-tools`
-- 🚧 Concise `aries-vcx` public crate API
-- Update public agents' API to enable for receiving messages directly, without a mediator intermediary.
-- Update connection protocol implementation to make use of mediator optional
-- Extract `aries-vcx::protocols` module into `aries-protocols` crate
-- Extract `aries-vcx::did_doc` module into `did-doc` crate
-- Publish crates to crates.io
-- Implement `did-exchange` protocol
-- Add support for full did format, such as `did:sov`, `did:peer`
-- Unify approach for Aries FSM interface across protocols
-- Abstract away concept "wallet handle" and "pool handle" from `aries-vcx` codebase
-
-# Phase 3
-- Use `indy-vdr` to facilitate ledger calls
-
-# Future vision architecture diagram
-#
diff --git a/ROADMAP_2023.md b/ROADMAP_2023.md
new file mode 100644
index 0000000000..998d8ce3ff
--- /dev/null
+++ b/ROADMAP_2023.md
@@ -0,0 +1,35 @@
+# Roadmap 2023
+
+### Modularization
+This is one of the main themes for 2023. We'll start by publishing smaller sub-crates on crates.io,
+such as crates encompassing aries messages, ddo resolver or diddoc. We hope this would attract
+more users and contributors who might be interested in smaller parts of the codebase if not the
+entire aries-vcx crate.
+
+### Credx libs support
+We are currently at point where [credx](https://github.com/hyperledger/indy-shared-rs/) libs can
+be used with holder, prover and verifier, but missing support for issuer on top of credx.
+Once that is done, we'll move step further to
+[anoncreds-rs](https://github.com/hyperledger/anoncreds-rs) and
+[Aries Askar](https://github.com/hyperledger/aries-askar) wallet.
+
+### Ledger agnosticity
+Following up the spin-off Hyperledger Anoncreds as separate project, we expect issuer's anchoring
+their DIDs, CredDefs etc. on ledgers other than Indy. We'll be following developments in this
+area and start enabling support for non-indy credentials, although this is arguably much
+wider community effort. The first action step forward will be implementing DDO resolver
+interface and support for an additional method other than did:sov
+
+### Community engagement
+In second half of 2022 we've started to put much more focus on community - increased discord
+presence, decreased time to review PRs, started weekly community calls - it didn't take long
+till we could observe increase in contributors and discord activity. We would like to
+maintaining this culture and activities, but also further become more inviting to new
+contributors by improving documentation, lowering barriers starting an aries-vcx
+project off the ground.
+
+### And more
+widening aries protocol support (didexchange, newer version of issuance and presentation protocols);
+increasing AATH coverage, enhancing code quality, testing speed, coverage; exploring didcomm 2.0;
+starting of new projects on top of aries-vcx (pickup protocol compliant mediator,
+cli tools) - are also on the list.
diff --git a/aries_vcx/README.md b/aries_vcx/README.md
new file mode 100644
index 0000000000..93eda2ac5e
--- /dev/null
+++ b/aries_vcx/README.md
@@ -0,0 +1,69 @@
+# Aries-vcx
+Crate implementing Hyperledger Aries protocols and building blocks for building Aries agents for
+both mobile (typically in role of holder, prover) and server use-cases (issuer and verifier).
+
+# Getting started
+Aries-vcx is library, not a framework. We strive to be not too opinionated and simply provide building block for whatever
+you want to build.
+
+Generally, the crate allows you to
+- create encrypted wallet,
+- read/write from/to Indy ledger,
+- establish didcomm connections and exchange messages,
+- create and process Aries messages to drive Aries protocols.
+
+Have look at [aries-vcx-agent](../agents/rust/aries-vcx-agent) for inspiration how aries-vcx can be used.
+
+# Message mediation
+If you are building mobile agent, you will generally require mediator service, which will receive
+messages on device's behalf - sort of like a mail server.
+
+It's possible to opt into integrated message mediator using `MediatedConnection` `impl`, which
+speaks the language of [vcxagency-node](https://github.com/AbsaOSS/vcxagencynode) mediator service.
+
+# Verify on your machine
+### Stage 1 - unit tests
+- First we need to get unit tests working on your machine. These don't require any external services to run.
+```
+cargo test --features "general_test" -- --test-threads=1
+```
+If you run into an errors
+- On OSX, try to install following packages with:
+ ```sh
+ brew install zmq
+ brew install pkg-config
+ ```
+- On ubuntu, you will likely need following packages:
+ ```sh
+ sudo apt-get update -y
+ sudo apt-get install -y libsodium-dev libssl-dev libzmq3-dev
+ ```
+
+### Stage 2 - integration tests
+Next up you will need integration tests running. These tests must pointed again some Indy ledger.
+You'll get best result by running a pool of Indy nodes on your machine. You can start a pool of 4 nodes
+in docker container like this
+```sh
+docker run --name indylocalhost -p 9701-9708:9701-9708 -d pstas/indypool-localhost:1.15.0-localhost
+```
+If you are running on arm64, you can specify option `--platform linux/amd64`, as the image above was
+originally built for `x86_64` architecture.
+
+Now you should be ready to run integration tests:
+```
+cargo test --features "pool_tests" -- --test-threads=1
+```
+
+## Implemented Aries protocols
+* ✅ Connection Protocol 1.0: [`https://didcomm.org/connections/1.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0160-connection-protocol)
+* ✅ Out of Band 1.0: [`https://didcomm.org/out-of-band/1.1/*`](https://github.com/hyperledger/aries-rfcs/blob/main/features/0434-outofband)
+* ✅ Basic Message 1.0: [`https://didcomm.org/basicmessage/1.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0095-basic-message)
+* ✅ Credential Issuance 1.0 [`https://didcomm.org/issue-credential/1.0/*`](https://github.com/hyperledger/aries-rfcs/blob/master/features/0036-issue-credential)
+* ✅ Credential Presentation 1.0: [`https://didcomm.org/present-proof/1.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0037-present-proof)
+* ✅ Trust Ping 1.0: [`https://didcomm.org/trust_ping/1.0/*`](https://github.com/hyperledger/aries-rfcs/blob/master/features/0048-trust-ping/README.md)
+* ✅ Discover Features 1.0: [`https://didcomm.org/discover-features/1.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0031-discover-features)
+* ✅ Revocation notification 2.0: [`https://didcomm.org/revocation_notification/2.0/*`](https://github.com/hyperledger/aries-rfcs/tree/master/features/0031-discover-features)
+
+## Architecture
+
+
diff --git a/docs/architecture/all_architecture_040123.drawio b/docs/architecture/all_architecture_040123.drawio
new file mode 100644
index 0000000000..99d3ded22e
--- /dev/null
+++ b/docs/architecture/all_architecture_040123.drawio
@@ -0,0 +1 @@
+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
\ No newline at end of file
diff --git a/docs/architecture/ariesvcx_architecture_040123.png b/docs/architecture/ariesvcx_architecture_040123.png
new file mode 100644
index 0000000000..a64d6ec9c2
Binary files /dev/null and b/docs/architecture/ariesvcx_architecture_040123.png differ
diff --git a/docs/architecture/libvcx_architecture_040123.png b/docs/architecture/libvcx_architecture_040123.png
new file mode 100644
index 0000000000..8007bf9ae4
Binary files /dev/null and b/docs/architecture/libvcx_architecture_040123.png differ
diff --git a/docs/build-general.md b/docs/build-general.md
deleted file mode 100644
index 40fc59b928..0000000000
--- a/docs/build-general.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# Building libvcx
-
-## 1. Build libvcx
-Lets build libvcx itself now. Enter into [libvcx directory](../libvcx) of this repo and run
-```
-cargo build --release
-```
-The build libraries will be located relatively to build directory in `./target/release`. On OSX, move `.dylib` library
-into `/usr/local/lib`. On linux, move them to `/usr/lib`.
-
-## 2. Run some code
-Now you are ready to write code consuming libvcx API. Pick your language from [list of demos](https://github.com/AbsaOSS/libvcx#get-started)
-and follow its instructions.
diff --git a/docs/vcx_arch.md b/docs/vcx_arch.md
deleted file mode 100644
index dccc49886c..0000000000
--- a/docs/vcx_arch.md
+++ /dev/null
@@ -1,45 +0,0 @@
-libVCX Architecture Choices
-=====
-No persistent storage
------
-libvcx does not have its own storage. While libindy wallet secrets are stored in the libindy wallet,
-libvxc objects are not stored by libvcx. Instead, each object can be serialized for storage by the user of libvcx.
-When the object is needed it can be deserialized. This allows users of libvcx to manage objects themselves
-inside long-running applications. libindy has recently introduced a non-secrets API for general storage and
-libvcx may use this in the future for object storage.
-
-Must initialize library with configuration
------
-Each process that uses libvcx must first initalize the library with "vcx_init()". Every call after
-will use . includes things such as agency urls and wallet name. To switch
-configurations the user must either exit the process and start over or call "vcx_shutdown()".
-
-Thread each API call with callback
------
-Each call to libvcx run on separate thread picked up from thread pool. Number of threads in pool is configurable.
-
-No explicit contract for libindy objects
------
-libindy objects such as credentials, credential_offers, proofs, proof_requests, etc are represented by
-libvcx as strings and not objects. In the future this may change if needed and possible.
-
-libindy overlap
------
-There are some convenience functions that overlap with libindy. These are the creation of schemas and
-credential definition and wallet non-secrets. In most cases the overlap is a simplification of the libindy API.
-
-Thin wrappers
------
-Wrappers are meant to be as thin as possible, in other words, they should have as little logic as possible
-and should simply wrap the rust code. They should be idiomatic and make sense to developers familiar with
-the specific language of the wrapper.
-
-Error codes
------
-This area will need work once it has been migrated to the indy-sdk. There should be a plan for error-code unification.
-
-"Microledger" architecture
------
-DIDs are not stored on the ledger, neither for the initial invitations nor for the pairwise connections.
-The ledger is used for schemas, credential definitions and proving credentials.
-
diff --git a/libvcx/README.md b/libvcx/README.md
new file mode 100644
index 0000000000..92fa43d1bd
--- /dev/null
+++ b/libvcx/README.md
@@ -0,0 +1,40 @@
+# Libvcx
+- Libvcx is library built on top of `aries-vcx`, which provides a particular approach how to
+ build bindings for other languages.
+- The library is split in 2 modules:
+
+### `api_vcx` module
+Layer on top of `aries-vcx` which provides `u32` "handle" reference API. When you
+create a new object, this layer gives you back `u32` reference to that object, which is how you
+work with it.
+
+This was historically feasibly approach for building FFI interfaces. Arguably, nowadays
+there's more modern approaches to FFI, for example via [uniffi](https://mozilla.github.io/uniffi-rs/).
+
+### `api_c` module
+Built on top of `api_vcx`, provides runtime executor (tokio) and FFI interface. Java and iOS wrapper
+are linked to this interface.
+
+# Get started
+If you wish to use iOS or Android wrapper, you may find it useful to have look at this 3rd party demos
+* Android [demo](https://github.com/sktston/vcx-demo-android)
+* iOS [demo](https://github.com/sktston/vcx-demo-ios)
+* iOS [skeleton project](https://github.com/sktston/vcx-skeleton-ios)
+These might be somewhat outdated at the moment, nevertheless they may be a good starting point.
+
+# Testing
+Before you try to build/test `libvcx` crate on your machine, make sure yu can buil `aries-vcx` - see
+[aries-vcx README](../aries_vcx/README.md#verify-on-your-machine).
+
+- Run unit tests:
+```
+cargo test --features "general_test" -- --test-threads=1
+```
+- Run integration tests (you need to have Indy pool running)
+```
+TEST_POOL_IP=127.0.0.1 cargo test --features "pool_tests" -- --test-threads=1
+```
+
+## Architecture
+
+
diff --git a/libvcx/readme.md b/libvcx/readme.md
deleted file mode 100644
index 307c798dec..0000000000
--- a/libvcx/readme.md
+++ /dev/null
@@ -1,29 +0,0 @@
-# Testing
-You can filter out tests by specifying features they require / use.
-```
-- general_test :: unit tests which do not require any external component
-- pool_tests :: requires indypool to be running
-- agency_pool_tests :: requires agency and/or indypool
-```
-
-Run quick unit tests:
-```
-cargo test --features "general_test" -- --test-threads=1
-```
-Or specific test:
-```
-cargo test test_init_minimal_with_invalid_agency_config --features "general_test" -- --test-threads=1 -- --exact
-```
-
-Run integration tests:
-```
-TEST_POOL_IP=127.0.0.1 cargo test --features "pool_tests" -- --test-threads=1
-```
-
-## Environment variables
-
-- `WARNLOG_MSGS_RECEIVED` - if set to `true` log received E2E connection messages
-- `DISALLOW_V1` - if set to `true` process panics whenever one of following is attempted:
- - run legacy V1 onboarding
- - create V1 connection
- - create legacy issuer credential object
\ No newline at end of file