@crossdelta/infrastructure 0.8.2 → 0.8.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -35,7 +35,7 @@ export declare const resolveStreams: (definitions: StreamDefinition[], policies?
35
35
  */
36
36
  export declare const generateSetupScript: (streams: ResolvedStream[]) => string;
37
37
  /**
38
- * Compute a short hash from stream config for change detection.
39
- * When config changes, the Job name changes → Pulumi recreates it.
38
+ * Compute a short hash from stream config + script for change detection.
39
+ * When config or script template changes, the Job name changes → Pulumi recreates it.
40
40
  */
41
- export declare const computeConfigHash: (streams: ResolvedStream[]) => string;
41
+ export declare const computeConfigHash: (streams: ResolvedStream[], script?: string) => string;
package/dist/index.cjs CHANGED
@@ -1015,7 +1015,7 @@ var generateSetupScript = (streams) => {
1015
1015
  `echo "⏳ Waiting for NATS to become available..."`,
1016
1016
  `RETRIES=0`,
1017
1017
  `MAX_RETRIES=30`,
1018
- `until nats $NATS_OPTS server ping --count 1 > /dev/null 2>&1; do`,
1018
+ `until nats $NATS_OPTS rtt > /dev/null 2>&1; do`,
1019
1019
  ` RETRIES=$((RETRIES + 1))`,
1020
1020
  ` if [ "$RETRIES" -ge "$MAX_RETRIES" ]; then`,
1021
1021
  ` echo "❌ NATS not available after $MAX_RETRIES attempts"`,
@@ -1035,8 +1035,8 @@ var generateSetupScript = (streams) => {
1035
1035
  ].join(`
1036
1036
  `);
1037
1037
  };
1038
- var computeConfigHash = (streams) => {
1039
- const data = JSON.stringify(streams);
1038
+ var computeConfigHash = (streams, script) => {
1039
+ const data = JSON.stringify(streams) + (script ?? "");
1040
1040
  let hash = 0;
1041
1041
  for (let i = 0;i < data.length; i++) {
1042
1042
  const char = data.charCodeAt(i);
@@ -1067,7 +1067,7 @@ var materializeStreams = (provider, namespace, config) => {
1067
1067
  const definitions = collectStreamDefinitions(contracts);
1068
1068
  const resolved = resolveStreams(definitions, policies, defaults);
1069
1069
  const script = generateSetupScript(resolved);
1070
- const configHash = computeConfigHash(resolved);
1070
+ const configHash = computeConfigHash(resolved, script);
1071
1071
  console.log(`\uD83D\uDCCB Collecting stream definitions from contracts...`);
1072
1072
  console.log(`✅ Found ${definitions.length} stream(s):`);
1073
1073
  for (const { stream, subjects } of definitions) {
@@ -1083,7 +1083,7 @@ var materializeStreams = (provider, namespace, config) => {
1083
1083
  "setup.sh": script,
1084
1084
  "streams.json": JSON.stringify(resolved, null, 2)
1085
1085
  }
1086
- }, { provider });
1086
+ }, { provider, deleteBeforeReplace: true });
1087
1087
  const envVars = [{ name: "NATS_URL", value: config.natsUrl }];
1088
1088
  if (config.credentials?.user) {
1089
1089
  envVars.push({ name: "NATS_USER", value: config.credentials.user });
package/dist/index.js CHANGED
@@ -921,7 +921,7 @@ var generateSetupScript = (streams) => {
921
921
  `echo "⏳ Waiting for NATS to become available..."`,
922
922
  `RETRIES=0`,
923
923
  `MAX_RETRIES=30`,
924
- `until nats $NATS_OPTS server ping --count 1 > /dev/null 2>&1; do`,
924
+ `until nats $NATS_OPTS rtt > /dev/null 2>&1; do`,
925
925
  ` RETRIES=$((RETRIES + 1))`,
926
926
  ` if [ "$RETRIES" -ge "$MAX_RETRIES" ]; then`,
927
927
  ` echo "❌ NATS not available after $MAX_RETRIES attempts"`,
@@ -941,8 +941,8 @@ var generateSetupScript = (streams) => {
941
941
  ].join(`
942
942
  `);
943
943
  };
944
- var computeConfigHash = (streams) => {
945
- const data = JSON.stringify(streams);
944
+ var computeConfigHash = (streams, script) => {
945
+ const data = JSON.stringify(streams) + (script ?? "");
946
946
  let hash = 0;
947
947
  for (let i = 0;i < data.length; i++) {
948
948
  const char = data.charCodeAt(i);
@@ -973,7 +973,7 @@ var materializeStreams = (provider, namespace, config) => {
973
973
  const definitions = collectStreamDefinitions(contracts);
974
974
  const resolved = resolveStreams(definitions, policies, defaults);
975
975
  const script = generateSetupScript(resolved);
976
- const configHash = computeConfigHash(resolved);
976
+ const configHash = computeConfigHash(resolved, script);
977
977
  console.log(`\uD83D\uDCCB Collecting stream definitions from contracts...`);
978
978
  console.log(`✅ Found ${definitions.length} stream(s):`);
979
979
  for (const { stream, subjects } of definitions) {
@@ -989,7 +989,7 @@ var materializeStreams = (provider, namespace, config) => {
989
989
  "setup.sh": script,
990
990
  "streams.json": JSON.stringify(resolved, null, 2)
991
991
  }
992
- }, { provider });
992
+ }, { provider, deleteBeforeReplace: true });
993
993
  const envVars = [{ name: "NATS_URL", value: config.natsUrl }];
994
994
  if (config.credentials?.user) {
995
995
  envVars.push({ name: "NATS_USER", value: config.credentials.user });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@crossdelta/infrastructure",
3
- "version": "0.8.2",
3
+ "version": "0.8.4",
4
4
  "type": "module",
5
5
  "license": "MIT",
6
6
  "publishConfig": {