appwrite-utils-cli 0.9.62 → 0.9.64

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.
package/README.md CHANGED
@@ -124,6 +124,7 @@ This updated CLI ensures that developers have robust tools at their fingertips t
124
124
 
125
125
  ## Changelog
126
126
 
127
+ - 0.9.64: Fixed string attribute requiring xdefault
127
128
  - 0.9.61: Remove fileURLToPath -- should hopefully fix windows
128
129
  - 0.9.60: Fix init command to repository URL
129
130
  - 0.9.59: Fix to Windows path names for loading config
@@ -2,7 +2,7 @@ import path from "path";
2
2
  import fs from "fs";
3
3
  import {} from "appwrite-utils";
4
4
  import { register } from "tsx/esm/api"; // Import the register function
5
- import { fileURLToPath } from "node:url";
5
+ import { pathToFileURL } from "node:url";
6
6
  /**
7
7
  * Recursively searches for a file named 'appwriteConfig.ts' starting from the given directory.
8
8
  * @param dir The directory to start the search from.
@@ -15,12 +15,12 @@ export const findAppwriteConfig = (dir) => {
15
15
  const files = fs.readdirSync(dir, { withFileTypes: true });
16
16
  for (const file of files) {
17
17
  if (file.isDirectory() && file.name !== "node_modules") {
18
- const result = findAppwriteConfig(path.resolve(dir, file.name));
18
+ const result = findAppwriteConfig(path.join(dir, file.name));
19
19
  if (result)
20
20
  return result;
21
21
  }
22
22
  else if (file.name === "appwriteConfig.ts") {
23
- return path.resolve(dir, file.name);
23
+ return path.join(dir, file.name);
24
24
  }
25
25
  }
26
26
  return null;
@@ -35,13 +35,15 @@ export const loadConfig = async (configDir) => {
35
35
  try {
36
36
  const configPath = path.join(configDir, "appwriteConfig.ts");
37
37
  console.log(`Loading config from: ${configPath}`);
38
- const config = (await import(configPath)).default;
38
+ const configUrl = pathToFileURL(configPath).href;
39
+ const config = (await import(configUrl)).default;
39
40
  const collectionsDir = path.join(configDir, "collections");
40
41
  const collectionFiles = fs.readdirSync(collectionsDir);
41
42
  config.collections = [];
42
43
  for (const file of collectionFiles) {
43
44
  const filePath = path.join(collectionsDir, file);
44
- const collectionModule = (await import(filePath)).default;
45
+ const fileUrl = pathToFileURL(filePath).href;
46
+ const collectionModule = (await import(fileUrl)).default;
45
47
  config.collections.push(collectionModule);
46
48
  }
47
49
  return config;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "appwrite-utils-cli",
3
3
  "description": "Appwrite Utility Functions to help with database management, data conversion, data import, migrations, and much more. Meant to be used as a CLI tool, I do not recommend installing this in frontend environments.",
4
- "version": "0.9.62",
4
+ "version": "0.9.64",
5
5
  "main": "src/main.ts",
6
6
  "type": "module",
7
7
  "repository": {
@@ -158,7 +158,7 @@ export const createOrUpdateAttribute = async (
158
158
  finalAttribute.key,
159
159
  finalAttribute.size,
160
160
  finalAttribute.required || false,
161
- (finalAttribute.xdefault as string) || undefined,
161
+ finalAttribute.xdefault || undefined,
162
162
  finalAttribute.array || false,
163
163
  finalAttribute.encrypted
164
164
  )
@@ -171,7 +171,7 @@ export const createOrUpdateAttribute = async (
171
171
  collection.$id,
172
172
  finalAttribute.key,
173
173
  finalAttribute.required || false,
174
- (finalAttribute.xdefault as string) || undefined
174
+ finalAttribute.xdefault || undefined
175
175
  )
176
176
  );
177
177
  }
@@ -2,7 +2,7 @@ import path from "path";
2
2
  import fs from "fs";
3
3
  import { type AppwriteConfig, type Collection } from "appwrite-utils";
4
4
  import { register } from "tsx/esm/api"; // Import the register function
5
- import { fileURLToPath } from "node:url";
5
+ import { pathToFileURL } from "node:url";
6
6
 
7
7
  /**
8
8
  * Recursively searches for a file named 'appwriteConfig.ts' starting from the given directory.
@@ -17,10 +17,10 @@ export const findAppwriteConfig = (dir: string): string | null => {
17
17
 
18
18
  for (const file of files) {
19
19
  if (file.isDirectory() && file.name !== "node_modules") {
20
- const result = findAppwriteConfig(path.resolve(dir, file.name));
20
+ const result = findAppwriteConfig(path.join(dir, file.name));
21
21
  if (result) return result;
22
22
  } else if (file.name === "appwriteConfig.ts") {
23
- return path.resolve(dir, file.name);
23
+ return path.join(dir, file.name);
24
24
  }
25
25
  }
26
26
 
@@ -40,7 +40,8 @@ export const loadConfig = async (
40
40
  try {
41
41
  const configPath = path.join(configDir, "appwriteConfig.ts");
42
42
  console.log(`Loading config from: ${configPath}`);
43
- const config = (await import(configPath)).default as AppwriteConfig;
43
+ const configUrl = pathToFileURL(configPath).href;
44
+ const config = (await import(configUrl)).default as AppwriteConfig;
44
45
 
45
46
  const collectionsDir = path.join(configDir, "collections");
46
47
  const collectionFiles = fs.readdirSync(collectionsDir);
@@ -49,7 +50,8 @@ export const loadConfig = async (
49
50
 
50
51
  for (const file of collectionFiles) {
51
52
  const filePath = path.join(collectionsDir, file);
52
- const collectionModule = (await import(filePath)).default as Collection;
53
+ const fileUrl = pathToFileURL(filePath).href;
54
+ const collectionModule = (await import(fileUrl)).default as Collection;
53
55
  config.collections.push(collectionModule);
54
56
  }
55
57