diff --git a/implementations/rust/ockam/ockam_api/src/cli_state/nodes.rs b/implementations/rust/ockam/ockam_api/src/cli_state/nodes.rs index a1b0bd9bb89..256098dd69d 100644 --- a/implementations/rust/ockam/ockam_api/src/cli_state/nodes.rs +++ b/implementations/rust/ockam/ockam_api/src/cli_state/nodes.rs @@ -18,7 +18,6 @@ use sysinfo::{Pid, ProcessStatus, ProcessesToUpdate, System}; use crate::cli_state::{random_name, NamedVault, Result}; use crate::cli_state::{CliState, CliStateError}; -use crate::cloud::project::Project; use crate::colors::color_primary; use crate::config::lookup::InternetAddress; @@ -27,17 +26,15 @@ use crate::{fmt_warn, ConnectionStatus}; /// The methods below support the creation and update of local nodes impl CliState { /// Create a node, with some optional associated values, and start it - #[instrument(skip_all, fields(node_name = node_name, identity_name = identity_name.clone(), project_name = project_name.clone() - ))] + #[instrument(skip_all, fields(node_name = node_name, identity_name = identity_name.clone()))] pub async fn start_node_with_optional_values( &self, node_name: &str, identity_name: &Option, - project_name: &Option, tcp_listener: Option<&TcpListener>, ) -> Result { let mut node = self - .create_node_with_optional_values(node_name, identity_name, project_name) + .create_node_with_optional_identity(node_name, identity_name) .await?; if node.pid.is_none() { let pid = process::id(); @@ -53,17 +50,12 @@ impl CliState { Ok(node) } - /// Create a node, with some optional associated values: - /// - /// - an identity name. That identity is used by the `NodeManager` to create secure channels - /// - a project name. It is used to create policies on resources provisioned on a node (like a TCP outlet for example) - #[instrument(skip_all, fields(node_name = node_name, identity_name = identity_name.clone(), project_name = project_name.clone() - ))] - pub async fn create_node_with_optional_values( + /// Create a node, with an optional identity name. That identity is used by the `NodeManager` to create secure channels + #[instrument(skip_all, fields(node_name = node_name, identity_name = identity_name.clone()))] + pub async fn create_node_with_optional_identity( &self, node_name: &str, identity_name: &Option, - project_name: &Option, ) -> Result { let identity = match identity_name { Some(name) => self.get_named_identity(name).await?, @@ -72,7 +64,6 @@ impl CliState { let node = self .create_node_with_identifier(node_name, &identity.identifier()) .await?; - self.set_node_project(node_name, project_name).await?; Ok(node) } @@ -134,27 +125,6 @@ impl CliState { Ok(()) } - /// This method can be used to start a local node first - /// then create a project, and associate it to the node - #[instrument(skip_all, fields(node_name = node_name, project_name = project_name.clone()))] - pub async fn set_node_project( - &self, - node_name: &str, - project_name: &Option, - ) -> Result<()> { - let project = match project_name { - Some(name) => Some(self.projects().get_project_by_name(name).await?), - None => self.projects().get_default_project().await.ok(), - }; - - if let Some(project) = project { - self.nodes_repository() - .set_node_project_name(node_name, project.name()) - .await? - }; - Ok(()) - } - /// Remove a node: /// /// - remove it from the repository @@ -381,23 +351,6 @@ impl CliState { } } - /// Return the project associated to a node if there is one - #[instrument(skip_all, fields(node_name = node_name))] - pub async fn get_node_project(&self, node_name: &str) -> Result { - match self - .nodes_repository() - .get_node_project_name(node_name) - .await? - { - Some(project_name) => self.projects().get_project_by_name(&project_name).await, - None => Err(Error::new( - Origin::Api, - Kind::NotFound, - format!("there is no project associated to node {node_name}"), - ))?, - } - } - /// Return the stdout log file used by a node #[instrument(skip_all, fields(node_name = node_name))] pub fn stdout_logs(&self, node_name: &str) -> Result { @@ -701,7 +654,6 @@ impl NodeInfo { #[cfg(test)] mod tests { use super::*; - use crate::cloud::project::models::ProjectModel; use crate::config::lookup::InternetAddress; use std::net::SocketAddr; use std::str::FromStr; @@ -804,7 +756,7 @@ mod tests { // a node can be created with just a name let node = cli - .create_node_with_optional_values("node-1", &None, &None) + .create_node_with_optional_identity("node-1", &None) .await?; let result = cli.get_node(&node.name()).await?; assert_eq!(result.name(), node.name()); @@ -812,44 +764,11 @@ mod tests { // a node can be created with a name and an existing identity let identity = cli.create_identity_with_name("name").await?; let node = cli - .create_node_with_optional_values("node-2", &Some(identity.name()), &None) + .create_node_with_optional_identity("node-2", &Some(identity.name())) .await?; let result = cli.get_node(&node.name()).await?; assert_eq!(result.identifier(), identity.identifier()); - // a node can be created with a name, an existing identity and an existing project - let project = ProjectModel { - id: "project_id".to_string(), - name: "project_name".to_string(), - space_name: "1".to_string(), - access_route: "".to_string(), - users: vec![], - space_id: "1".to_string(), - identity: None, - project_change_history: None, - authority_access_route: None, - authority_identity: None, - okta_config: None, - kafka_config: None, - version: None, - running: None, - operation_id: None, - user_roles: vec![], - }; - cli.projects() - .import_and_store_project(project.clone()) - .await?; - - let node = cli - .create_node_with_optional_values( - "node-4", - &Some(identity.name()), - &Some(project.name.clone()), - ) - .await?; - let result = cli.get_node_project(&node.name()).await?; - assert_eq!(result.name(), &project.name); - Ok(()) } } diff --git a/implementations/rust/ockam/ockam_api/src/cli_state/storage/nodes_repository.rs b/implementations/rust/ockam/ockam_api/src/cli_state/storage/nodes_repository.rs index a1baa338361..c48ec4da73b 100644 --- a/implementations/rust/ockam/ockam_api/src/cli_state/storage/nodes_repository.rs +++ b/implementations/rust/ockam/ockam_api/src/cli_state/storage/nodes_repository.rs @@ -71,12 +71,6 @@ pub trait NodesRepository: Send + Sync + 'static { /// Unset the process id of a node async fn set_no_node_pid(&self, node_name: &str) -> Result<()>; - - /// Associate a node to a project - async fn set_node_project_name(&self, node_name: &str, project_name: &str) -> Result<()>; - - /// Return the name of the project associated to a node - async fn get_node_project_name(&self, node_name: &str) -> Result>; } #[async_trait] @@ -151,12 +145,4 @@ impl NodesRepository for AutoRetry { async fn set_no_node_pid(&self, node_name: &str) -> Result<()> { retry!(self.wrapped.set_no_node_pid(node_name)) } - - async fn set_node_project_name(&self, node_name: &str, project_name: &str) -> Result<()> { - retry!(self.wrapped.set_node_project_name(node_name, project_name)) - } - - async fn get_node_project_name(&self, node_name: &str) -> Result> { - retry!(self.wrapped.get_node_project_name(node_name)) - } } diff --git a/implementations/rust/ockam/ockam_api/src/cli_state/storage/nodes_repository_sql.rs b/implementations/rust/ockam/ockam_api/src/cli_state/storage/nodes_repository_sql.rs index f7b8da3a724..a72f66f06b1 100644 --- a/implementations/rust/ockam/ockam_api/src/cli_state/storage/nodes_repository_sql.rs +++ b/implementations/rust/ockam/ockam_api/src/cli_state/storage/nodes_repository_sql.rs @@ -224,30 +224,6 @@ impl NodesRepository for NodesSqlxDatabase { let query = query("UPDATE node SET pid=NULL WHERE name = $1").bind(node_name); query.execute(&*self.database.pool).await.void() } - - async fn set_node_project_name(&self, node_name: &str, project_name: &str) -> Result<()> { - let query = query( - r#" - INSERT INTO node_project (node_name, project_name) - VALUES ($1, $2) - ON CONFLICT (node_name) - DO UPDATE SET project_name = $2"#, - ) - .bind(node_name) - .bind(project_name); - Ok(query.execute(&*self.database.pool).await.void()?) - } - - async fn get_node_project_name(&self, node_name: &str) -> Result> { - let query = - query("SELECT project_name FROM node_project WHERE node_name = $1").bind(node_name); - let row: Option = query - .fetch_optional(&*self.database.pool) - .await - .into_core()?; - let project_name: Option = row.map(|r| r.get(0)); - Ok(project_name) - } } // Database serialization / deserialization @@ -420,23 +396,6 @@ mod test { .await } - #[tokio::test] - async fn test_node_project() -> Result<()> { - with_dbs(|db| async move { - let repository: Arc = Arc::new(NodesSqlxDatabase::new(db)); - - // a node can be associated to a project name - repository - .set_node_project_name("node_name", "project1") - .await?; - let result = repository.get_node_project_name("node_name").await?; - assert_eq!(result, Some("project1".into())); - - Ok(()) - }) - .await - } - /// HELPERS async fn create_identity() -> Result { let identities = identities().await?; diff --git a/implementations/rust/ockam/ockam_api/src/nodes/service/in_memory_node.rs b/implementations/rust/ockam/ockam_api/src/nodes/service/in_memory_node.rs index 1848d7603bf..7ee8cb2616b 100644 --- a/implementations/rust/ockam/ockam_api/src/nodes/service/in_memory_node.rs +++ b/implementations/rust/ockam/ockam_api/src/nodes/service/in_memory_node.rs @@ -147,7 +147,6 @@ impl InMemoryNode { .start_node_with_optional_values( &defaults.node_name, &Some(identity_name.to_string()), - &project_name, Some(&tcp_listener), ) .await diff --git a/implementations/rust/ockam/ockam_api/src/test_utils/mod.rs b/implementations/rust/ockam/ockam_api/src/test_utils/mod.rs index b4c5b6f0c79..adb0b831cf8 100644 --- a/implementations/rust/ockam/ockam_api/src/test_utils/mod.rs +++ b/implementations/rust/ockam/ockam_api/src/test_utils/mod.rs @@ -70,7 +70,7 @@ pub async fn start_manager_for_tests( let node_name = random_name(); cli_state - .start_node_with_optional_values(&node_name, &None, &None, Some(&tcp_listener)) + .start_node_with_optional_values(&node_name, &None, Some(&tcp_listener)) .await .unwrap(); diff --git a/implementations/rust/ockam/ockam_app_lib/src/enroll/enroll_user.rs b/implementations/rust/ockam/ockam_app_lib/src/enroll/enroll_user.rs index 6f42593f85f..cefb03d0784 100644 --- a/implementations/rust/ockam/ockam_app_lib/src/enroll/enroll_user.rs +++ b/implementations/rust/ockam/ockam_app_lib/src/enroll/enroll_user.rs @@ -208,10 +208,6 @@ impl AppState { .projects() .set_default_project(project.project_id()) .await?; - self.state() - .await - .set_node_project(&node_manager.node_name(), &Some(project.name().to_string())) - .await?; Ok(project) } } diff --git a/implementations/rust/ockam/ockam_app_lib/src/state/mod.rs b/implementations/rust/ockam/ockam_app_lib/src/state/mod.rs index a222cb35592..1f5a18569ba 100644 --- a/implementations/rust/ockam/ockam_app_lib/src/state/mod.rs +++ b/implementations/rust/ockam/ockam_app_lib/src/state/mod.rs @@ -707,7 +707,7 @@ pub(crate) async fn make_node_manager( .into_diagnostic()?; let _ = cli_state - .start_node_with_optional_values(NODE_NAME, &None, &None, Some(&listener)) + .start_node_with_optional_values(NODE_NAME, &None, Some(&listener)) .await?; let trust_options = cli_state diff --git a/implementations/rust/ockam/ockam_command/src/authority/create.rs b/implementations/rust/ockam/ockam_command/src/authority/create.rs index 834edabc321..f43c3fd9310 100644 --- a/implementations/rust/ockam/ockam_command/src/authority/create.rs +++ b/implementations/rust/ockam/ockam_command/src/authority/create.rs @@ -153,7 +153,7 @@ impl CreateCommand { }; opts.state - .create_node_with_optional_values(&self.node_name, &self.identity, &None) + .create_node_with_optional_identity(&self.node_name, &self.identity) .await?; // Construct the arguments list and re-execute the ockam @@ -310,7 +310,7 @@ impl CreateCommand { }; let node = state - .start_node_with_optional_values(&self.node_name, &Some(identity_name), &None, None) + .start_node_with_optional_values(&self.node_name, &Some(identity_name), None) .await?; state .set_tcp_listener_address(&node.name(), &self.tcp_listener_address) diff --git a/implementations/rust/ockam/ockam_command/src/node/create/foreground.rs b/implementations/rust/ockam/ockam_command/src/node/create/foreground.rs index ea50a499708..7c1381bdee8 100644 --- a/implementations/rust/ockam/ockam_command/src/node/create/foreground.rs +++ b/implementations/rust/ockam/ockam_command/src/node/create/foreground.rs @@ -66,12 +66,7 @@ impl CreateCommand { }; let node_info = opts .state - .start_node_with_optional_values( - &node_name, - &self.identity, - &self.trust_opts.project_name, - Some(&tcp_listener), - ) + .start_node_with_optional_values(&node_name, &self.identity, Some(&tcp_listener)) .await?; debug!("node info persisted {node_info:?}"); diff --git a/implementations/rust/ockam/ockam_node/src/storage/database/migrations/node_migrations/sql/postgres/20240613100000_create_database.sql b/implementations/rust/ockam/ockam_node/src/storage/database/migrations/node_migrations/sql/postgres/20240613100000_create_database.sql index dbbdced58cd..992759ae22c 100644 --- a/implementations/rust/ockam/ockam_node/src/storage/database/migrations/node_migrations/sql/postgres/20240613100000_create_database.sql +++ b/implementations/rust/ockam/ockam_node/src/storage/database/migrations/node_migrations/sql/postgres/20240613100000_create_database.sql @@ -24,9 +24,6 @@ CREATE TABLE identity change_history TEXT NOT NULL ); --- Insert the controller identity -INSERT INTO identity VALUES ('I84502ce0d9a0a91bae29026b84e19be69fb4203a6bdd1424c85a43c812772a00', '81825858830101585385f6820181584104ebf9d78281a04f180029c12a74e994386c7c9fee24903f3bfe351497a9952758ee5f4b57d7ed6236ab5082ed85e1ae8c07d5600e0587f652d36727904b3e310df41a656a365d1a7836395d820181584050bf79071ecaf08a966228c712295a17da53994dc781a22103602afe656276ef83ba83a1004845b1e979e0944abff3cd8c7ceef834a8f5eeeca0e8f720fa38f4'); - -- This table some local metadata about identities CREATE TABLE named_identity ( @@ -36,14 +33,6 @@ CREATE TABLE named_identity is_default BOOLEAN DEFAULT FALSE -- boolean indicating if this identity is the default one ); --- This table stores the time when a given identity was enrolled --- In the current project -CREATE TABLE identity_enrollment -( - identifier TEXT NOT NULL UNIQUE, -- Identifier of the identity - enrolled_at INTEGER NOT NULL, -- UNIX timestamp in seconds - email TEXT -- Enrollment email -); -- This table lists attributes associated to a given identity CREATE TABLE identity_attributes @@ -66,12 +55,25 @@ CREATE INDEX identity_identifier_index ON identity_attributes (identifier); CREATE INDEX identity_node_name_index ON identity_attributes (node_name); +-- This table stores credentials as received by the application +CREATE TABLE credential +( + subject_identifier TEXT NOT NULL, + issuer_identifier TEXT NOT NULL, + scope TEXT NOT NULL, + credential BYTEA NOT NULL, + expires_at INTEGER, + node_name TEXT NOT NULL -- node name to isolate credential that each node has +); + +CREATE UNIQUE INDEX credential_issuer_subject_scope_index ON credential (issuer_identifier, subject_identifier, scope); +CREATE UNIQUE INDEX credential_issuer_subject_index ON credential(issuer_identifier, subject_identifier); -- This table stores purpose keys that have been created by a given identity CREATE TABLE purpose_key ( - identifier TEXT NOT NULL, -- Identity identifier - purpose TEXT NOT NULL, -- Purpose of the key: SecureChannels, or Credentials + identifier TEXT NOT NULL, -- Identity identifier + purpose TEXT NOT NULL, -- Purpose of the key: SecureChannels, or Credentials purpose_key_attestation BYTEA NOT NULL -- Encoded attestation: attestation data and attestation signature ); @@ -85,7 +87,7 @@ CREATE UNIQUE INDEX purpose_key_index ON purpose_key (identifier, purpose); CREATE TABLE vault ( name TEXT PRIMARY KEY, -- User-specified name for a vault - path TEXT NULL, -- Path where the vault is saved, This path can the current database path. In that case the vault data is stored in the *-secrets table below + path TEXT NULL, -- If the path is specified, then the secrets are stored in a SQLite file. Otherwise secrets are stored in the *-secrets tables below. is_default BOOLEAN, -- boolean indicating if this vault is the default one (0 means true) is_kms BOOLEAN -- boolean indicating if this vault is a KMS one (0 means true). In that case only key handles are stored in the database ); @@ -94,7 +96,7 @@ CREATE TABLE vault CREATE TABLE signing_secret ( handle BYTEA PRIMARY KEY, -- Secret handle - secret_type TEXT NOT NULL, -- Secret type (EdDSACurve25519 or ECDSASHA256CurveP256) + secret_type TEXT NOT NULL, -- Secret type (EdDSACurve25519 or ECDSASHA256CurveP256) secret BYTEA NOT NULL -- Secret binary ); @@ -105,28 +107,9 @@ CREATE TABLE x25519_secret secret BYTEA NOT NULL -- Secret binary ); - ---------------- --- CREDENTIALS ---------------- - --- This table stores credentials as received by the application -CREATE TABLE credential -( - subject_identifier TEXT NOT NULL, - issuer_identifier TEXT NOT NULL, - scope TEXT NOT NULL, - credential BYTEA NOT NULL, - expires_at INTEGER, - node_name TEXT NOT NULL -- node name to isolate credential that each node has -); - -CREATE UNIQUE INDEX credential_issuer_subject_scope_index ON credential (issuer_identifier, subject_identifier, scope); -CREATE UNIQUE INDEX credential_issuer_subject_index ON credential(issuer_identifier, subject_identifier); - ------------------- +------------- -- AUTHORITY ------------------- +------------- CREATE TABLE authority_member ( @@ -156,6 +139,10 @@ CREATE TABLE authority_enrollment_token CREATE UNIQUE INDEX authority_enrollment_token_one_time_code_index ON authority_enrollment_token(one_time_code); CREATE INDEX authority_enrollment_token_expires_at_index ON authority_enrollment_token(expires_at); +------------ +-- SERVICES +------------ + -- This table stores policies. A policy is an expression which -- can be evaluated against an environment (a list of name/value pairs) -- to assess if a given action can be performed on a given resource @@ -188,6 +175,25 @@ CREATE TABLE resource ); CREATE UNIQUE INDEX resource_index ON resource (node_name, resource_name, resource_type); +-- This table stores the current state of a TCP outlet +CREATE TABLE tcp_outlet_status +( + node_name TEXT NOT NULL, -- Node where that tcp outlet has been created + socket_addr TEXT NOT NULL, -- Socket address that the outlet connects to + worker_addr TEXT NOT NULL, -- Worker address for the outlet itself + payload TEXT, -- Optional status payload + privileged BOOLEAN DEFAULT FALSE -- boolean indicating if the outlet is operating in privileged mode +); + +-- This table stores the current state of a TCP inlet +CREATE TABLE tcp_inlet +( + node_name TEXT NOT NULL, -- Node where that tcp inlet has been created + bind_addr TEXT NOT NULL, -- Input address to connect to + outlet_addr TEXT NOT NULL, -- MultiAddress to the outlet + alias TEXT NOT NULL, -- Alias for that inlet + privileged BOOLEAN DEFAULT FALSE -- boolean indicating if the inlet is operating in privileged mode +); --------- -- NODES @@ -206,80 +212,6 @@ CREATE TABLE node http_server_address TEXT -- Address of the server supporting the HTTP status endpoint for the node ); --- This table stores the project name to use for a given node -CREATE TABLE node_project -( - node_name TEXT PRIMARY KEY, -- Node name - project_name TEXT NOT NULL -- Project name -); - ---------------------------- --- PROJECTS, SPACES, USERS ---------------------------- - --- This table store data about projects as returned by the Controller -CREATE TABLE project -( - project_id TEXT PRIMARY KEY, -- Identifier of the project - project_name TEXT NOT NULL, -- Name of the project - is_default BOOLEAN NOT NULL, -- boolean indicating if this project is the default one (0 means true) - space_id TEXT NOT NULL, -- Identifier of the space associated to the project - space_name TEXT NOT NULL, -- Name of the space associated to the project - project_identifier TEXT, -- optional: identifier of the project identity - access_route TEXT NOT NULL, -- Route used to create a secure channel to the project - authority_change_history TEXT, -- Change history for the authority identity - authority_access_route TEXT, -- Route te the authority associated to the project - version TEXT, -- Orchestrator software version - running BOOLEAN, -- boolean indicating if this project is currently accessible - operation_id TEXT, -- optional id of the operation currently creating the project on the Controller side - project_change_history TEXT -- Change history for the project identity -); - --- This table provides the list of users associated to a given project -CREATE TABLE user_project -( - user_email TEXT NOT NULL, -- User email - project_id TEXT NOT NULL -- Project id -); - --- This table provides additional information for users associated to a project or a space -CREATE TABLE user_role -( - user_id INTEGER NOT NULL, -- User id - project_id TEXT NOT NULL, -- Project id - user_email TEXT NOT NULL, -- User email - role TEXT NOT NULL, -- Role of the user: admin or member - scope TEXT NOT NULL -- Scope of the role: space, project, or service -); - --- This table stores data about spaces as returned by the controller -CREATE TABLE space -( - space_id TEXT PRIMARY KEY, -- Identifier of the space - space_name TEXT NOT NULL, -- Name of the space - is_default BOOLEAN NOT NULL -- boolean indicating if this project is the default one (0 means true) -); - --- This table provides the list of users associated to a given project -CREATE TABLE user_space -( - user_email TEXT NOT NULL, -- User email - space_id TEXT NOT NULL -- Space id -); - --- This table provides additional information for users after they have been authenticated -CREATE TABLE "user" -( - email TEXT PRIMARY KEY, -- User email - sub TEXT NOT NULL, -- (Sub)ject: unique identifier for the user - nickname TEXT NOT NULL, -- User nickname (or handle) - name TEXT NOT NULL, -- User name - picture TEXT NOT NULL, -- Link to a user picture - updated_at TEXT NOT NULL, -- ISO-8601 date: when this user information was last update - email_verified BOOLEAN NOT NULL, -- boolean indicating if the user email has been verified (0 means true) - is_default BOOLEAN NOT NULL -- boolean indicating if this user is the default user locally (0 means true) -); - ------------------- -- SECURE CHANNELS ------------------- @@ -305,55 +237,3 @@ CREATE TABLE aead_secret type TEXT NOT NULL, -- Secret type secret BYTEA NOT NULL -- Secret binary ); - ---------------- --- APPLICATION ---------------- - --- This table stores the current state of an outlet created to expose a service with the desktop application -CREATE TABLE tcp_outlet_status -( - node_name TEXT NOT NULL, -- Node where that tcp outlet has been created - socket_addr TEXT NOT NULL, -- Socket address that the outlet connects to - worker_addr TEXT NOT NULL, -- Worker address for the outlet itself - payload TEXT -- Optional status payload -); - --- This table stores the current state of an inlet created to expose a service with the desktop application -CREATE TABLE tcp_inlet -( - node_name TEXT NOT NULL, -- Node where that tcp inlet has been created - bind_addr TEXT NOT NULL, -- Input address to connect to - outlet_addr TEXT NOT NULL, -- MultiAddress to the outlet - alias TEXT NOT NULL -- Alias for that inlet -); - --- This table stores the list of services that a user has been invited to connect to --- via the desktop application -CREATE TABLE incoming_service -( - invitation_id TEXT PRIMARY KEY, -- Invitation id - enabled BOOLEAN NOT NULL, -- boolean indicating if the user wants to service to be accessible (0 means true) - name TEXT NULL -- Optional user-defined name for the service -); - ----------- --- ADDONS ----------- - --- This table stores the data necessary to configure the Okta addon -CREATE TABLE okta_config -( - project_id TEXT NOT NULL, -- Project id of the project using the addon - tenant_base_url TEXT NOT NULL, -- Base URL of the tenant - client_id TEXT NOT NULL, -- Client id - certificate TEXT NOT NULL, -- Certificate - attributes TEXT -- Comma-separated list of attribute names -); - --- This table stores the data necessary to configure the Kafka addons -CREATE TABLE kafka_config -( - project_id TEXT NOT NULL, -- Project id of the project using the addon - bootstrap_server TEXT NOT NULL -- URL of the bootstrap server -); diff --git a/implementations/rust/ockam/ockam_node/src/storage/database/migrations/node_migrations/sql/sqlite/20250110100000_remove_node_project.sql b/implementations/rust/ockam/ockam_node/src/storage/database/migrations/node_migrations/sql/sqlite/20250110100000_remove_node_project.sql new file mode 100644 index 00000000000..ef18c0d1fab --- /dev/null +++ b/implementations/rust/ockam/ockam_node/src/storage/database/migrations/node_migrations/sql/sqlite/20250110100000_remove_node_project.sql @@ -0,0 +1,2 @@ +-- This table is not used anymore +DROP TABLE node_project; diff --git a/tools/stress-test/src/main.rs b/tools/stress-test/src/main.rs index 0b505681153..983c89ad088 100644 --- a/tools/stress-test/src/main.rs +++ b/tools/stress-test/src/main.rs @@ -180,7 +180,7 @@ impl State { let listener = tcp.listen(&"127.0.0.1:0", options).await?; let _ = cli_state - .start_node_with_optional_values(NODE_NAME, &None, &None, Some(&listener)) + .start_node_with_optional_values(NODE_NAME, &None, Some(&listener)) .await?; let trust_options = cli_state