Skip to content

Commit

Permalink
feat: Select versions of demos & stacks (#340)
Browse files Browse the repository at this point in the history
* wip: Add release selection to demo command

Also removes the unused --offline flag. Feel free to ignore that.

* add --release arg to stacks

* Update rust/stackablectl/src/cmds/demo.rs

Co-authored-by: Techassi <[email protected]>

* refactor 'latest_release' and address PR feedback

* refactor 'latest_release' and address PR feedback

* add changelog entry

* add changelog entry

* chore: Restructure changelog

* refactor: Simplify List type

This add a Deref impl for the List type, which removed the need to call
.inner() to retrieve the IndexMap. Instead IndexMap's methods can now
be used by deref'ing.

Also, the SpecIter trait now consumes self, which removes two superflous
calls to .clone().

* chore: Remove unused regex dependency

---------

Co-authored-by: Techassi <[email protected]>
  • Loading branch information
labrenbe and Techassi authored Dec 18, 2024
1 parent 15cd9ea commit e3ed80e
Show file tree
Hide file tree
Showing 27 changed files with 251 additions and 267 deletions.
3 changes: 0 additions & 3 deletions docs/modules/stackablectl/partials/commands/cache.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,6 @@ Options:
Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
'$HOME/.cache/stackablectl' when not explicitly set.
--offline
Do not request any remote files via the network
-h, --help
Print help (see a summary with '-h')
Expand Down
3 changes: 0 additions & 3 deletions docs/modules/stackablectl/partials/commands/completions.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,6 @@ Options:
Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
'$HOME/.cache/stackablectl' when not explicitly set.
--offline
Do not request any remote files via the network
-h, --help
Print help (see a summary with '-h')
Expand Down
4 changes: 2 additions & 2 deletions docs/modules/stackablectl/partials/commands/demo.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,8 @@ Options:
Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
'$HOME/.cache/stackablectl' when not explicitly set.
--offline
Do not request any remote files via the network
--release <RELEASE>
Target a specific Stackable release
-h, --help
Print help (see a summary with '-h')
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,9 +37,6 @@ Options:
Defaults to the image of the target container if not specified.
--offline
Do not request any remote files via the network
-h, --help
Print help (see a summary with '-h')
Expand Down
3 changes: 0 additions & 3 deletions docs/modules/stackablectl/partials/commands/index.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,6 @@ Options:
Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
'$HOME/.cache/stackablectl' when not explicitly set.
--offline
Do not request any remote files via the network
-h, --help
Print help (see a summary with '-h')
Expand Down
3 changes: 0 additions & 3 deletions docs/modules/stackablectl/partials/commands/operator.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,6 @@ Options:
Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
'$HOME/.cache/stackablectl' when not explicitly set.
--offline
Do not request any remote files via the network
-h, --help
Print help (see a summary with '-h')
Expand Down
3 changes: 0 additions & 3 deletions docs/modules/stackablectl/partials/commands/release.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,6 @@ Options:
Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
'$HOME/.cache/stackablectl' when not explicitly set.
--offline
Do not request any remote files via the network
-h, --help
Print help (see a summary with '-h')
Expand Down
4 changes: 2 additions & 2 deletions docs/modules/stackablectl/partials/commands/stack.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,8 @@ Options:
Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
'$HOME/.cache/stackablectl' when not explicitly set.
--offline
Do not request any remote files via the network
--release <RELEASE>
Target a specific Stackable release
-h, --help
Print help (see a summary with '-h')
Expand Down
3 changes: 0 additions & 3 deletions docs/modules/stackablectl/partials/commands/stacklet.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -25,9 +25,6 @@ Options:
Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
'$HOME/.cache/stackablectl' when not explicitly set.
--offline
Do not request any remote files via the network
-h, --help
Print help (see a summary with '-h')
Expand Down
41 changes: 8 additions & 33 deletions extra/completions/_stackablectl

Large diffs are not rendered by default.

98 changes: 65 additions & 33 deletions extra/completions/stackablectl.bash

Large diffs are not rendered by default.

41 changes: 8 additions & 33 deletions extra/completions/stackablectl.elv

Large diffs are not rendered by default.

43 changes: 9 additions & 34 deletions extra/completions/stackablectl.fish

Large diffs are not rendered by default.

41 changes: 8 additions & 33 deletions extra/completions/stackablectl.nu

Large diffs are not rendered by default.

5 changes: 1 addition & 4 deletions extra/man/stackablectl.1

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

25 changes: 12 additions & 13 deletions rust/stackable-cockpit/src/common/list.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use std::marker::PhantomData;
use std::{marker::PhantomData, ops::Deref};

use indexmap::IndexMap;
use serde::{Deserialize, Serialize};
Expand All @@ -18,7 +18,7 @@ pub enum Error {
}

pub trait SpecIter<S> {
fn inner(&self) -> &IndexMap<String, S>;
fn inner(self) -> IndexMap<String, S>;
}

/// A [`List`] describes a list of specs. The list can contain any specs, for
Expand Down Expand Up @@ -54,7 +54,7 @@ where
.context(FileTransferSnafu)?;

for (spec_name, spec) in specs.inner() {
map.insert(spec_name.clone(), spec.clone());
map.insert(spec_name, spec);
}
}

Expand All @@ -63,17 +63,16 @@ where
inner: map,
})
}
}

/// Returns a reference to the inner [`IndexMap`]
pub fn inner(&self) -> &IndexMap<String, S> {
&self.inner
}
impl<L, S> Deref for List<L, S>
where
L: for<'a> Deserialize<'a> + Serialize + SpecIter<S>,
S: for<'a> Deserialize<'a> + Serialize + Clone,
{
type Target = IndexMap<String, S>;

/// Returns an optional reference to a single spec of type `S` by `name`
pub fn get<T>(&self, name: T) -> Option<&S>
where
T: AsRef<str>,
{
self.inner.get(name.as_ref())
fn deref(&self) -> &Self::Target {
&self.inner
}
}
4 changes: 2 additions & 2 deletions rust/stackable-cockpit/src/platform/demo/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ pub struct DemosV2 {
}

impl SpecIter<DemoSpec> for DemosV2 {
fn inner(&self) -> &IndexMap<String, DemoSpec> {
&self.demos
fn inner(self) -> IndexMap<String, DemoSpec> {
self.demos
}
}

Expand Down
7 changes: 2 additions & 5 deletions rust/stackable-cockpit/src/platform/release/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,9 @@ pub struct Releases {
}

impl SpecIter<ReleaseSpec> for Releases {
fn inner(&self) -> &IndexMap<String, ReleaseSpec> {
&self.releases
fn inner(self) -> IndexMap<String, ReleaseSpec> {
self.releases
}
}

pub type ReleaseList = crate::common::list::List<Releases, ReleaseSpec>;

#[derive(Default)]
pub struct Release {}
4 changes: 2 additions & 2 deletions rust/stackable-cockpit/src/platform/stack/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ pub struct StacksV2 {
}

impl SpecIter<StackSpec> for StacksV2 {
fn inner(&self) -> &IndexMap<String, StackSpec> {
&self.stacks
fn inner(self) -> IndexMap<String, StackSpec> {
self.stacks
}
}

Expand Down
10 changes: 10 additions & 0 deletions rust/stackablectl/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,16 @@ All notable changes to this project will be documented in this file.

## [Unreleased]

### Added

- Add new argument `--release` that allows installing a specific version of a demo or stack ([#340]).

### Removed

- Remove argument `--offline` that was not implemented yet ([#340]).

[#340]: https://github.com/stackabletech/stackable-cockpit/pull/340

## [24.11.1] - 2024-11-20

### Added
Expand Down
3 changes: 0 additions & 3 deletions rust/stackablectl/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -35,9 +35,6 @@ Options:
Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
'$HOME/.cache/stackablectl' when not explicitly set.
--offline
Do not request any remote files via the network
-h, --help
Print help (see a summary with '-h')
Expand Down
46 changes: 24 additions & 22 deletions rust/stackablectl/src/cli/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,20 +8,19 @@ use tracing::{debug, instrument, Level};
use stackable_cockpit::{
constants::{HELM_REPO_NAME_DEV, HELM_REPO_NAME_STABLE, HELM_REPO_NAME_TEST},
helm,
platform::demo::List,
utils::path::{
IntoPathOrUrl, IntoPathsOrUrls, ParsePathsOrUrls, PathOrUrl, PathOrUrlParseError,
},
xfer::{cache::Settings, Client},
xfer::cache::Settings,
};

use crate::{
args::{CommonFileArgs, CommonRepoArgs},
cmds::{cache, completions, debug, demo, operator, release, stack, stacklet},
constants::{
ENV_KEY_DEMO_FILES, ENV_KEY_RELEASE_FILES, ENV_KEY_STACK_FILES, REMOTE_DEMO_FILE,
REMOTE_RELEASE_FILE, REMOTE_STACK_FILE, USER_DIR_APPLICATION_NAME,
USER_DIR_ORGANIZATION_NAME, USER_DIR_QUALIFIER,
DEMOS_REPOSITORY_DEMOS_SUBPATH, DEMOS_REPOSITORY_STACKS_SUBPATH, DEMOS_REPOSITORY_URL_BASE,
ENV_KEY_DEMO_FILES, ENV_KEY_RELEASE_FILES, ENV_KEY_STACK_FILES, REMOTE_RELEASE_FILE,
USER_DIR_APPLICATION_NAME, USER_DIR_ORGANIZATION_NAME, USER_DIR_QUALIFIER,
},
output::{ErrorContext, Output, ResultContext},
};
Expand Down Expand Up @@ -74,10 +73,6 @@ Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually
)]
pub no_cache: bool,

/// Do not request any remote files via the network
#[arg(long, global = true)]
pub offline: bool,

#[command(flatten)]
pub files: CommonFileArgs,

Expand All @@ -90,27 +85,34 @@ Cached files are saved at '$XDG_CACHE_HOME/stackablectl', which is usually

impl Cli {
/// Returns a list of demo files, consisting of entries which are either a path or URL. The list of files combines
/// the default demo file URL, [`REMOTE_DEMO_FILE`], files provided by the ENV variable [`ENV_KEY_DEMO_FILES`], and
/// lastly, files provided by the CLI argument `--demo-file`.
pub fn get_demo_files(&self) -> Result<Vec<PathOrUrl>, PathOrUrlParseError> {
let mut files = get_files(REMOTE_DEMO_FILE, ENV_KEY_DEMO_FILES)?;
/// the default demo file URL constructed from [`DEMOS_REPOSITORY_URL_BASE`] and the provided branch, files provided
/// by the ENV variable [`ENV_KEY_DEMO_FILES`], and lastly, files provided by the CLI argument `--demo-file`.
pub fn get_demo_files(&self, branch: &str) -> Result<Vec<PathOrUrl>, PathOrUrlParseError> {
let branch_url = format!(
"{base}/{branch}/{demos}",
base = DEMOS_REPOSITORY_URL_BASE,
demos = DEMOS_REPOSITORY_DEMOS_SUBPATH
);

let mut files = get_files(&branch_url, ENV_KEY_DEMO_FILES)?;

let arg_files = self.files.demo_files.clone().into_paths_or_urls()?;
files.extend(arg_files);

Ok(files)
}

pub async fn get_demo_list(&self, transfer_client: &Client) -> List {
let files = self.get_demo_files().unwrap();
List::build(&files, transfer_client).await.unwrap()
}

/// Returns a list of stack files, consisting of entries which are either a path or URL. The list of files combines
/// the default stack file URL, [`REMOTE_STACK_FILE`], files provided by the ENV variable [`ENV_KEY_STACK_FILES`],
/// and lastly, files provided by the CLI argument `--stack-file`.
pub fn get_stack_files(&self) -> Result<Vec<PathOrUrl>, PathOrUrlParseError> {
let mut files = get_files(REMOTE_STACK_FILE, ENV_KEY_STACK_FILES)?;
/// the default stack file URL constructed from [`DEMOS_REPOSITORY_URL_BASE`] and the provided branch, files provided
/// by the ENV variable [`ENV_KEY_STACK_FILES`], and lastly, files provided by the CLI argument `--stack-file`.
pub fn get_stack_files(&self, branch: &str) -> Result<Vec<PathOrUrl>, PathOrUrlParseError> {
let branch_url = format!(
"{base}/{branch}/{stacks}",
base = DEMOS_REPOSITORY_URL_BASE,
stacks = DEMOS_REPOSITORY_STACKS_SUBPATH
);

let mut files = get_files(&branch_url, ENV_KEY_STACK_FILES)?;

let arg_files = self.files.stack_files.clone().into_paths_or_urls()?;
files.extend(arg_files);
Expand Down
Loading

0 comments on commit e3ed80e

Please sign in to comment.