Skip to content

Commit

Permalink
Undo regexp work to revisit on a separate PR
Browse files Browse the repository at this point in the history
  • Loading branch information
samayer12 committed Nov 22, 2024
1 parent 70c1178 commit 257c4b8
Show file tree
Hide file tree
Showing 4 changed files with 15 additions and 22 deletions.
8 changes: 4 additions & 4 deletions src/lib/capability.ts
Original file line number Diff line number Diff line change
Expand Up @@ -345,9 +345,9 @@ export class Capability implements CapabilityExport {
return { ...commonChain, WithName, WithNameRegex };
}

function InNamespaceRegex(...namespaces: string[]): BindingWithName<T> {
function InNamespaceRegex(...namespaces: RegExp[]): BindingWithName<T> {
Log.debug(`Add regex namespaces filter ${namespaces}`, prefix);
binding.filters.regexNamespaces.push(...namespaces);
binding.filters.regexNamespaces.push(...namespaces.map(regex => regex.source));
return { ...commonChain, WithName, WithNameRegex };
}

Expand All @@ -357,9 +357,9 @@ export class Capability implements CapabilityExport {
return commonChain;
}

function WithNameRegex(regexName: string): BindingFilter<T> {
function WithNameRegex(regexName: RegExp): BindingFilter<T> {
Log.debug(`Add regex name filter ${regexName}`, prefix);
binding.filters.regexName = regexName;
binding.filters.regexName = regexName.source;
return commonChain;
}

Expand Down
23 changes: 8 additions & 15 deletions src/lib/filter/adjudicators.ts
Original file line number Diff line number Diff line change
Expand Up @@ -117,11 +117,8 @@ export const definesNameRegex = pipe(definedNameRegex, equals(""), not);
export const definedNamespaces = pipe(binding => binding?.filters?.namespaces, defaultTo([]));
export const definesNamespaces = pipe(definedNamespaces, equals([]), not);

export const definedNamespaceRegexes = pipe(
(binding: Binding): string[] => binding.filters.regexNamespaces,
defaultTo<string[]>([]),
);
export const definesNamespaceRegexes = pipe(definedNamespaceRegexes, equals([] as string[]), not);
export const definedNamespaceRegexes = pipe(binding => binding?.filters?.regexNamespaces, defaultTo([]));
export const definesNamespaceRegexes = pipe(definedNamespaceRegexes, equals([]), not);

export const definedAnnotations = pipe((binding: Partial<Binding>) => binding?.filters?.annotations, defaultTo({}));
export const definesAnnotations = pipe(definedAnnotations, equals({}), not);
Expand Down Expand Up @@ -205,16 +202,12 @@ export const mismatchedNamespace = allPass([
export const mismatchedNamespaceRegex = allPass([
// Check if `definesNamespaceRegexes` returns true
pipe(nthArg(0), definesNamespaceRegexes),

// Check if no regex matches
(binding: Binding, kubernetesObject: KubernetesObject) => {
// Convert definedNamespaceRegexes(binding) from string[] to RegExp[]
const regexArray = definedNamespaceRegexes(binding).map(regexStr => new RegExp(regexStr));

// Check if no regex matches the namespace of the Kubernetes object
const result = not(any((regEx: RegExp) => regEx.test(carriedNamespace(kubernetesObject)), regexArray));
return result;
},
pipe((binding, kubernetesObject) =>
pipe(
any((regEx: string) => new RegExp(regEx).test(carriedNamespace(kubernetesObject))),
not,
)(definedNamespaceRegexes(binding)),
),
]);

export const metasMismatch = pipe(
Expand Down
2 changes: 1 addition & 1 deletion src/lib/helpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -237,7 +237,7 @@ export function generateWatchNamespaceError(
return err.replace(/\.([^ ])/g, ". $1");
}

// namespaceComplianceValidator ensures that capability binds respect ignored and capability namespaces
// namespaceComplianceValidator ensures that capability bindings respect ignored and capability namespaces
export function namespaceComplianceValidator(capability: CapabilityExport, ignoredNamespaces?: string[]) {
const { namespaces: capabilityNamespaces, bindings, name } = capability;
const bindingNamespaces: string[] = bindings.flatMap((binding: Binding) => binding.filters.namespaces);
Expand Down
4 changes: 2 additions & 2 deletions src/lib/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -143,14 +143,14 @@ export type BindingWithName<T extends GenericClass> = BindingFilter<T> & {
/** Only apply the action if the resource name matches the specified name. */
WithName: (name: string) => BindingFilter<T>;
/** Only apply the action if the resource name matches the specified regex name. */
WithNameRegex: (name: string) => BindingFilter<T>;
WithNameRegex: (name: RegExp) => BindingFilter<T>;
};

export type BindingAll<T extends GenericClass> = BindingWithName<T> & {
/** Only apply the action if the resource is in one of the specified namespaces.*/
InNamespace: (...namespaces: string[]) => BindingWithName<T>;
/** Only apply the action if the resource is in one of the specified regex namespaces.*/
InNamespaceRegex: (...namespaces: string[]) => BindingWithName<T>;
InNamespaceRegex: (...namespaces: RegExp[]) => BindingWithName<T>;
};

export type CommonActionChain<T extends GenericClass> = MutateActionChain<T> & {
Expand Down

0 comments on commit 257c4b8

Please sign in to comment.