create-fleetbo-project 1.0.40 → 1.0.41
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/install-react-template.js +31 -29
- package/package.json +1 -1
|
@@ -8,33 +8,33 @@ const https = require('https');
|
|
|
8
8
|
// --- Configuration ---
|
|
9
9
|
const repoOwner = 'FleetFleetbo';
|
|
10
10
|
const repoName = 'dev.fleetbo.io';
|
|
11
|
-
const branchName = 'master'; //
|
|
11
|
+
const branchName = 'master'; // Assurez-vous que c'est la bonne branche
|
|
12
12
|
|
|
13
13
|
const repoGitUrl = `https://github.com/${repoOwner}/${repoName}.git`;
|
|
14
14
|
const bootstrapUrl = 'https://us-central1-myapp-259bf.cloudfunctions.net/bootstrapProject';
|
|
15
15
|
|
|
16
|
-
// ---
|
|
16
|
+
// --- Analyse des Arguments ---
|
|
17
17
|
const args = process.argv.slice(2);
|
|
18
18
|
const projectNameArg = args.find(arg => !arg.startsWith('--'));
|
|
19
19
|
const tokenArg = args.find(arg => arg.startsWith('--token='));
|
|
20
20
|
|
|
21
21
|
if (!projectNameArg) {
|
|
22
|
-
console.error('\n❌
|
|
23
|
-
console.log(' Usage: npx create-fleetbo-project <
|
|
22
|
+
console.error('\n❌ Erreur : Veuillez spécifier un nom pour votre projet.');
|
|
23
|
+
console.log(' Usage: npx create-fleetbo-project <nom-du-projet> --token=<votre-token>');
|
|
24
24
|
process.exit(1);
|
|
25
25
|
}
|
|
26
26
|
|
|
27
27
|
const bootstrapToken = tokenArg ? tokenArg.split('=')[1] : null;
|
|
28
28
|
|
|
29
29
|
if (!bootstrapToken) {
|
|
30
|
-
console.error('\n❌
|
|
31
|
-
console.log(' Usage: npx create-fleetbo-project <
|
|
30
|
+
console.error('\n❌ Erreur : Le token d\'amorçage est manquant.');
|
|
31
|
+
console.log(' Usage: npx create-fleetbo-project <nom-du-projet> --token=<votre-token>');
|
|
32
32
|
process.exit(1);
|
|
33
33
|
}
|
|
34
34
|
|
|
35
35
|
const projectName = projectNameArg;
|
|
36
36
|
|
|
37
|
-
// ---
|
|
37
|
+
// --- Fonctions Utilitaires ---
|
|
38
38
|
|
|
39
39
|
function fetchProjectKeys(token) {
|
|
40
40
|
return new Promise((resolve, reject) => {
|
|
@@ -48,10 +48,10 @@ function fetchProjectKeys(token) {
|
|
|
48
48
|
try {
|
|
49
49
|
resolve(JSON.parse(data));
|
|
50
50
|
} catch (e) {
|
|
51
|
-
reject(new Error('
|
|
51
|
+
reject(new Error('Réponse invalide du serveur de clés.'));
|
|
52
52
|
}
|
|
53
53
|
} else {
|
|
54
|
-
const errorMsg = JSON.parse(data).error || `
|
|
54
|
+
const errorMsg = JSON.parse(data).error || `Erreur serveur (code: ${res.statusCode})`;
|
|
55
55
|
reject(new Error(errorMsg));
|
|
56
56
|
}
|
|
57
57
|
});
|
|
@@ -62,55 +62,56 @@ function fetchProjectKeys(token) {
|
|
|
62
62
|
});
|
|
63
63
|
}
|
|
64
64
|
|
|
65
|
-
// ---
|
|
65
|
+
// --- Fonction Principale ---
|
|
66
66
|
|
|
67
67
|
async function setupProject() {
|
|
68
|
-
console.log(`\
|
|
68
|
+
console.log(`\nCréation de votre projet Fleetbo "${projectName}"...`);
|
|
69
69
|
const projectDir = path.join(process.cwd(), projectName);
|
|
70
70
|
|
|
71
71
|
try {
|
|
72
|
-
//
|
|
73
|
-
console.log(' [1/5] 📥
|
|
74
|
-
//
|
|
72
|
+
// Étape 1 : Télécharger la structure de base du projet
|
|
73
|
+
console.log(' [1/5] 📥 Initialisation de la structure du projet...');
|
|
74
|
+
// On redirige la sortie d'erreur (stderr) vers null pour masquer les messages de progression de Git
|
|
75
75
|
execSync(`git clone --depth 1 --branch ${branchName} ${repoGitUrl} "${projectName}" 2> /dev/null`);
|
|
76
76
|
|
|
77
|
-
//
|
|
78
|
-
console.log(' [2/5] ✅
|
|
77
|
+
// Étape 2 : Se déplacer dans le dossier du projet et nettoyer
|
|
78
|
+
console.log(' [2/5] ✅ Structure du projet initialisée. Configuration en cours...');
|
|
79
79
|
process.chdir(projectDir);
|
|
80
80
|
|
|
81
|
-
//
|
|
81
|
+
// Supprimer l'historique Git pour commencer avec un projet propre
|
|
82
82
|
fs.rmSync(path.join(projectDir, '.git'), { recursive: true, force: true });
|
|
83
83
|
|
|
84
|
-
//
|
|
85
|
-
console.log(' [3/5] 🔑
|
|
84
|
+
// Étape 3 : Récupération des clés de projet
|
|
85
|
+
console.log(' [3/5] 🔑 Récupération des clés de projet...');
|
|
86
86
|
const keys = await fetchProjectKeys(bootstrapToken);
|
|
87
87
|
if (!keys.enterpriseId || !keys.fleetboDBKey) {
|
|
88
|
-
throw new Error("
|
|
88
|
+
throw new Error("Les clés reçues du serveur sont invalides.");
|
|
89
89
|
}
|
|
90
90
|
|
|
91
|
-
//
|
|
92
|
-
console.log(' [4/5] ✅ .env
|
|
91
|
+
// Étape 4 : Configuration du fichier .env
|
|
92
|
+
console.log(' [4/5] ✅ Fichier .env configuré avec succès.');
|
|
93
|
+
//const envContent = `REACT_APP_FLEETBO_DB_KEY=${keys.fleetboDBKey}\nREACT_APP_ENTERPRISE_ID=${keys.enterpriseId}\n`; //99b426483d543b042209671dd53fb18
|
|
93
94
|
const envContent = `REACT_APP_FLEETBO_DB_KEY=${keys.fleetboDBKey}\nREACT_APP_ENTERPRISE_ID=99b426483d543b042209671dd53fb18\n`;
|
|
94
95
|
fs.writeFileSync(path.join(projectDir, '.env'), envContent, 'utf8');
|
|
95
96
|
|
|
96
|
-
//
|
|
97
|
-
console.log(' [5/5] 📦
|
|
97
|
+
// Étape 5 : Installation des dépendances
|
|
98
|
+
console.log(' [5/5] 📦 Installation des dépendances...');
|
|
98
99
|
execSync('npm install', { stdio: 'inherit' });
|
|
99
100
|
|
|
100
|
-
//
|
|
101
|
+
// Personnalisation du package.json
|
|
101
102
|
const packageJsonPath = path.join(projectDir, 'package.json');
|
|
102
103
|
const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf8'));
|
|
103
104
|
packageJson.name = projectName;
|
|
104
105
|
fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2), 'utf8');
|
|
105
106
|
|
|
106
|
-
console.log('\n🚀
|
|
107
|
-
console.log(`\
|
|
107
|
+
console.log('\n🚀 Votre projet Fleetbo est prêt !');
|
|
108
|
+
console.log(`\nPour commencer, exécutez les commandes suivantes :`);
|
|
108
109
|
console.log(` cd ${projectName}`);
|
|
109
110
|
console.log(` npm start`);
|
|
110
111
|
|
|
111
112
|
} catch (error) {
|
|
112
|
-
console.error('\n❌
|
|
113
|
-
//
|
|
113
|
+
console.error('\n❌ Une erreur est survenue lors de la création du projet :', error.message);
|
|
114
|
+
// Nettoyage en cas d'erreur
|
|
114
115
|
if (fs.existsSync(projectDir)) {
|
|
115
116
|
fs.rmSync(projectDir, { recursive: true, force: true });
|
|
116
117
|
}
|
|
@@ -118,3 +119,4 @@ async function setupProject() {
|
|
|
118
119
|
}
|
|
119
120
|
|
|
120
121
|
setupProject();
|
|
122
|
+
|