NoChangeImporterDao.cs

Description du code

NoChangeImporterDao.cs est un fichier du projet BiblioBrol.
Ce fichier est situé dans /var/www/bin/sniplets/bibliobrol/src/.

Projet BiblioBrol :

Gestion de media en CSharp.

Pour plus d'infos, vous pouvez consulter la brève analyse.

Code source ou contenu du fichier

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. using System.Runtime.Serialization.Formatters.Binary;
  5. using System.IO;
  6. using System.Collections;
  7. using System.Data.Common;
  8. using System.Data;
  9. using System.Drawing;
  10. using be.gaudry.observer;
  11. using be.gaudry.model;
  12.  
  13. namespace be.gaudry.bibliobrol.model.dao.mysql
  14. {
  15. public sealed class NoChangeImporterDao : Observable, IImporterDao
  16. {
  17. private String conStr;
  18.  
  19. #region singleton
  20. static NoChangeImporterDao instance = null;
  21. static readonly object padlock = new object();
  22. private DbProviderFactory dbpf;
  23. NoChangeImporterDao()
  24. {
  25. notify(new Notification(Notification.VERBOSE.debug, "AccessImporterDao singleton call", this));
  26. dbpf = ((MySQLFactory)MySQLFactory.Instance).getDbpf();
  27. conStr = ((MySQLFactory)MySQLFactory.Instance).getConnectionString();
  28. }
  29. public static NoChangeImporterDao Instance
  30. {
  31. get
  32. {
  33. lock (padlock)
  34. {
  35. if (instance == null)
  36. {
  37. instance = new NoChangeImporterDao();
  38. }
  39. return instance;
  40. }
  41. }
  42. }
  43. #endregion
  44.  
  45. #region IImporter Members
  46. /// <summary>
  47. /// Deserialize images
  48. /// </summary>
  49. /// <param name="path">(String) path of binary import file</param>
  50. /// <returns>A list of images</returns>
  51. public List<Image> importImages(string path)
  52. {
  53. FileStream fs = null;
  54. try
  55. {
  56. fs = new FileStream(path, FileMode.Open, FileAccess.Read);
  57. List<Image> images = (List<Image>)new BinaryFormatter().Deserialize(fs);
  58. return images;
  59. }
  60. catch (FileNotFoundException)
  61. {
  62. notify(new Notification(Notification.VERBOSE.criticalError, "Importation des images", String.Format("Fichier {0} non trouvé.", path), this));
  63. return new List<Image>();
  64. }
  65. catch (Exception e)
  66. {
  67. notify(new Notification(Notification.VERBOSE.criticalError, "Importation des images", e, this));
  68. return new List<Image>();
  69. }
  70. finally
  71. {
  72. fs.Close();
  73. }
  74. }
  75.  
  76. /// <summary>
  77. /// Deserialize mediabrols
  78. /// Search existings mediabrols which not match exactly with new list items (don't check id's).
  79. /// </summary>
  80. /// <param name="path">(String) path of binary import file</param>
  81. public void importBinaryMediaBrol(string path)
  82. {
  83. DateTime startDateTime = DateTime.Now;
  84.  
  85. FileStream fs = null;
  86. Object deserializedList = null;
  87. int count = 0;
  88. try
  89. {
  90. fs = new FileStream(path, FileMode.Open, FileAccess.Read);
  91. deserializedList = new BinaryFormatter().Deserialize(fs);
  92. count = castList(deserializedList);
  93. }
  94. catch (FileNotFoundException)
  95. {
  96. notify(new Notification(Notification.VERBOSE.criticalError, "Importation", String.Format("Fichier {0} non trouvé.",path), this));
  97. return;
  98. }
  99. catch (Exception e)
  100. {
  101. notify(new Notification(Notification.VERBOSE.criticalError, "Importation", e, this));
  102. return;
  103. }
  104. finally
  105. {
  106. if (fs != null) fs.Close();
  107.  
  108. notify(new Notification(Notification.VERBOSE.internalNotification, "lastBrol", String.Format("Fin des {0} chargements", count), this));
  109. notify(new Notification(Notification.VERBOSE.internalNotification, "End", String.Format("Fin de tous les traitements ({0})", Units.getDelay(startDateTime)), this));
  110. }
  111. }
  112. #endregion
  113.  
  114. #region private methods
  115. /// <summary>
  116. /// Test if deserialized object matches with a list of brols or a list of mediabrols
  117. /// And call appropriate method to import items
  118. /// </summary>
  119. /// <param name="deserializedList"></param>
  120. private int castList(object deserializedList)
  121. {
  122. int count;
  123. if (deserializedList is List<Brol>)
  124. {
  125. //first attempt : is it a list of brols ?
  126. List<Brol> importedList = (List<Brol>)deserializedList;
  127. count = importedList.Count;
  128. notify(new Notification(Notification.VERBOSE.internalNotification, "count", count.ToString(), this));
  129. importBrols(importedList);
  130. }
  131. else if (deserializedList is List<MediaBrol>)
  132. {
  133. //second attempt : is it a list of mediabrols ?
  134. List<MediaBrol> importedList = (List<MediaBrol>)deserializedList;
  135. count = importedList.Count;
  136. notify(new Notification(Notification.VERBOSE.internalNotification, "count", count.ToString(), this));
  137. importMediabrols(importedList);
  138. }
  139. else
  140. {
  141. count = 0;
  142. notify(new Notification(Notification.VERBOSE.error, "Importation", "Le fichier importé ne comporte ni ouvrage, ni exemplaire. Il est possible qu'il soit corrompu." , this));
  143. }
  144. return count;
  145. }
  146.  
  147. private void saveConflicts(List<IBrol> conflictList)
  148. {
  149. if (conflictList.Count > 0)
  150. {
  151. DateTime dt = DateTime.Now;
  152. StringBuilder saveConflictPath = new StringBuilder(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments));
  153. saveConflictPath.Append(System.IO.Path.DirectorySeparatorChar);
  154. saveConflictPath.Append("brolConflict");
  155. saveConflictPath.Append(dt.Year);
  156. if (dt.Month < 10) saveConflictPath.Append("0");
  157. saveConflictPath.Append(dt.Month);
  158. if (dt.Day < 10) saveConflictPath.Append("0");
  159. saveConflictPath.Append(dt.Day);
  160. if (dt.Minute < 10) saveConflictPath.Append("0");
  161. saveConflictPath.Append(dt.Minute);
  162. saveConflictPath.Append(".bed");
  163. StringBuilder str = new StringBuilder(String.Format(
  164. "{0} éléments semblent déjà présents dans l'application. Vous pouvez toutefois importer ces éléments depuis le fichier suivant : {1}\n\nListe des éléments de ce fichier :\n\n",
  165. conflictList.Count,
  166. saveConflictPath.ToString()));
  167. if(conflictList[0].GetType().Equals(typeof(Brol)))
  168. {
  169. foreach (Brol brol in conflictList)
  170. str.AppendLine(brol.Title);
  171. }
  172. else if(conflictList[0].GetType().Equals(typeof(MediaBrol)))
  173. {
  174. foreach (MediaBrol mediabrol in conflictList)
  175. str.AppendLine(mediabrol.Brol.Title);
  176. }
  177. //exportation of conflicts list
  178. BinaryFormatter bf = new BinaryFormatter();
  179. FileStream fs = NoChangeExporterDao.Instance.getFileStream(saveConflictPath.ToString(), FileMode.OpenOrCreate, FileAccess.Write);
  180. if (fs == null)
  181. {
  182. notify(new Notification(Notification.VERBOSE.criticalError, "Exportation des conflits", "Impossible de trouver un flux de sortie", this));
  183. str.AppendLine("ERREUR : Impossible de trouver un flux de sortie");
  184. }
  185. else
  186. {
  187. try
  188. {
  189. bf.Serialize(fs, conflictList);
  190. notify(new Notification(Notification.VERBOSE.internalNotification, "Exportation des conflits", String.Format("Les éléments en conflits ont été sauvés sous {0}",saveConflictPath.ToString()), this));
  191. }
  192. catch (Exception eSer)
  193. {
  194. notify(new Notification(Notification.VERBOSE.criticalError, "Exportation", eSer, this));
  195. str.AppendLine(eSer.Message);
  196. }
  197. finally
  198. {
  199. fs.Close();
  200. }
  201. }
  202. notify(new Notification(Notification.VERBOSE.opsResult, "Exportation", str.ToString(), this));
  203. }
  204. }
  205.  
  206. /// <summary>
  207. /// Check imported mediabrols.
  208. /// If a mediabrol don't exists, insert it.
  209. /// If an actor or a categorie don't exists, insert it.
  210. /// </summary>
  211. /// <param name="importedList">Deserialized mediabrols</param>
  212. private void importMediabrols(List<MediaBrol> importedList)
  213. {
  214. notify(new Notification(Notification.VERBOSE.internalNotification, "Mediabrols",
  215. "Le fichier contient des exemplaires. Cette méthode n'est pour l'instant implémentée que pour des ouvrages.", this));
  216. }
  217. /// <summary>
  218. /// Check imported brols.
  219. /// If a brol don't exists, insert it.
  220. /// If an actor or a categorie don't exists, insert it.
  221. /// </summary>
  222. /// <param name="importedList">Deserialized brols</param>
  223. private void importBrols(List<Brol> importedList)
  224. {
  225. int foundId;
  226. List<IBrol> conflicts = new List<IBrol>();
  227. DbConnection dbCon = dbpf.CreateConnection();
  228. DbDataAdapter dbDa = dbpf.CreateDataAdapter();
  229. dbCon.ConnectionString = conStr;
  230. dbDa.SelectCommand = dbCon.CreateCommand();
  231. //todo : getTypesHashtable with , dbCon, dbDa
  232. Hashtable types = getTypesHashtable();
  233. //todo : getCategoriesHashtable with , dbCon, dbDa
  234. Hashtable categories = getCategoriesHashtable(dbCon, dbDa);
  235. //todo : getPersonsHashtable with , dbCon, dbDa
  236. Hashtable persons = getPersonsHashtable();
  237.  
  238. // load all persons and categories form bibliobrol to adapt ids
  239. // and check if we need to insert new item
  240.  
  241. //Check imported brols
  242. dbCon.Open();
  243. foreach (Brol importedBrol in importedList)
  244. {
  245. foundId = 0;
  246. notify(new Notification(Notification.VERBOSE.internalNotification, "count2", "5", this));
  247. //test if type exists
  248. if (types.ContainsKey(importedBrol.BrolType.Name.ToUpper()))
  249. importedBrol.BrolType.Id = (int)types[importedBrol.BrolType.Name.ToUpper()];
  250. else
  251. {
  252. //add type if not exists
  253. //modify brol type id
  254. importedBrol.BrolType.Id = NoChangeConfigDao.Instance.insertBrolType(importedBrol.BrolType, dbCon, dbDa);
  255. //insert into existing
  256. types.Add(importedBrol.BrolType.Name.ToUpper(), importedBrol.BrolType.Id);
  257. notify(new Notification(Notification.VERBOSE.internalNotification, "Ajout d'un type", String.Format("Ajout du type {0} dans l'application"), this));
  258. }
  259. notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 1", this));
  260. //test if brol exists
  261. dbDa.SelectCommand.CommandText = String.Format("SELECT id FROM item WHERE UCASE(itemTitle)='{0}'", MySQLUtils.escapeAndTrim(importedBrol.Title.ToUpper()));
  262. notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this));
  263. try
  264. {
  265. foundId = (int)dbDa.SelectCommand.ExecuteScalar();
  266. notify(new Notification(Notification.VERBOSE.debug, "foundId : " + foundId + " for " + importedBrol.Title, "", this));
  267. }
  268. catch (Exception){}
  269.  
  270. notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 2", this));
  271. if (foundId > 0)
  272. {
  273. //conflict
  274. notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 3", this));
  275. //importedBrol.Id = foundId;
  276. notify(new Notification(Notification.VERBOSE.internalNotification, "Conflit", String.Format("L'élément {0} semble en conflit avec un élément existant.", importedBrol.Title), this));
  277. notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 4", this));
  278. conflicts.Add(importedBrol);}
  279. else
  280. {
  281. insertImportedBrol(importedBrol, dbCon, dbDa, types, categories, persons);
  282. notify(new Notification(Notification.VERBOSE.internalNotification, "Import", String.Format("L'élément {0} est correstement importé.", importedBrol.Title), this));
  283. }
  284. notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 5", this));
  285. notify(new Notification(Notification.VERBOSE.internalNotification, "brolEnd", "", this));
  286. }
  287. dbCon.Close();
  288. saveConflicts(conflicts);
  289. }
  290. /// <summary>
  291. /// Insert a new brol from import file
  292. /// </summary>
  293. /// <param name="importedBrol"></param>
  294. /// <param name="dbCon"></param>
  295. /// <param name="dbDa"></param>
  296. /// <param name="types"></param>
  297. /// <param name="categories"></param>
  298. /// <param name="persons"></param>
  299. /// <returns></returns>
  300. private int insertImportedBrol(Brol importedBrol, DbConnection dbCon, DbDataAdapter dbDa, Hashtable types, Hashtable categories, Hashtable persons)
  301. {
  302. if (dbDa.InsertCommand == null)
  303. dbDa.InsertCommand = dbCon.CreateCommand();
  304. String key;
  305. importedBrol.Id = -1;//we need to set this value to insert as new item (!!!! otherwise we UPDATE AN EXISTING ITEM !!!)
  306. foreach (BrolCategory cat in importedBrol.Categories)
  307. {
  308. key = cat.Name.ToUpper()+importedBrol.BrolType.Id;
  309. //exists into bibliobrol
  310. if (categories.Contains(key))
  311. {
  312. cat.Id = (int)categories[key];
  313. }
  314. else
  315. {
  316. cat.Status = STATUS.toAppAdd;
  317. //insert new category into bibliobrol and set new id
  318. cat.Id = NoChangeConfigDao.Instance.insertCategory(cat, importedBrol.BrolType, dbCon, dbDa);
  319. notify(new Notification(Notification.VERBOSE.internalNotification, "Ajout", String.Format("La catégorie {0} est ajoutée.", cat.Name), this));
  320. categories.Add(key, cat.Id);
  321. }
  322. cat.Status = STATUS.toAdd;
  323. }
  324. notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 3", this));
  325.  
  326. foreach (Actor actor in importedBrol.Actors)
  327. {
  328. key = getPersonKey(actor);
  329. //exists into bibliobrol
  330. if (persons.Contains(key))
  331. {
  332. actor.Id = (int)persons[key];
  333. }
  334. else
  335. {
  336. //todo : if person img exists, prompt to delete it (it is probably an img from another actor)
  337. actor.Status = STATUS.toAppAdd;
  338. actor.Id = -1;//to force insertion
  339.  
  340. actor.Id = NoChangePersonDao.Instance.insertPerson(actor, dbCon, dbDa, new StringBuilder());
  341. notify(new Notification(Notification.VERBOSE.internalNotification, "Ajout", String.Format("La personne {0} est ajoutée.", actor.Display), this));
  342. persons.Add(key, actor.Id);
  343. }
  344. actor.Status = STATUS.toAdd;
  345. }
  346. notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 4", this));
  347. return NoChangeBrolDao.Instance.insertBrol(importedBrol, dbCon, dbDa, true);
  348. }
  349.  
  350. /// <summary>
  351. /// Check imported brols.
  352. /// If a brol don't exists, insert it.
  353. /// If an actor or a categorie don't exists, insert it.
  354. /// </summary>
  355. /// <param name="importedList">Deserialized mediabrols</param>
  356. /// <returns>(List IBrol)List of conflict brols</returns>
  357. private List<IBrol> importConflictBrols(List<IBrol> importedList)
  358. {
  359. /*Brol existingBrol;
  360.   List<Brol> existingBrols = null;
  361.   int[] brolIds = new int[1];
  362.   StringBuilder str = new StringBuilder("Résultat de l'importation");
  363.   Hashtable categories = getCategoriesHashtable();
  364.   Hashtable persons = getPersonsHashtable();
  365.   DbConnection dbCon = dbpf.CreateConnection();
  366.   DbDataAdapter dbDa = dbpf.CreateDataAdapter();
  367.   dbCon.ConnectionString = conStr;
  368.   dbDa.SelectCommand = dbCon.CreateCommand();
  369.  
  370.   // load all persons and categories form bibliobrol to adapt ids
  371.   // and check if we need to insert new item
  372.  
  373.   //todo : loadpersons with , dbCon, dbDa
  374.   //todo : loadCategories with , dbCon, dbDa
  375.  
  376.   //Check imported brols
  377.   String key;//key to test
  378.   foreach (Brol importedBrol in importedList)
  379.   {
  380.   notify(new Notification(Notification.VERBOSE.internalNotification, "count2", "6", this));
  381.   notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 1", this));
  382.   //load brol if exists
  383.   //ds = new DataSet();
  384.   dbDa.SelectCommand.CommandText = String.Format("SELECT id FROM item WHERE UCASE(itemTitle)='{0}'", importedBrol.Title.Trim().ToUpper().Replace("'", "''"));
  385.   notify(new Notification(Notification.VERBOSE.advancedOperation, dbDa.SelectCommand.CommandText, this));
  386.   dbCon.Open();
  387.   try
  388.   {
  389.   brolIds[0] = (int)dbDa.SelectCommand.ExecuteScalar();
  390.   existingBrols = AccessExporterDao.Instance.loadSelectedBrols(brolIds, dbCon, dbDa, false);
  391.   }
  392.   catch (Exception) { }
  393.   dbCon.Close();
  394.  
  395.   notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 2", this));
  396.   if (existingBrols != null && existingBrols.Count > 0)
  397.   {
  398.   existingBrol = existingBrols[0];
  399.   }
  400.   else
  401.   {
  402.   existingBrol = new Brol();
  403.   existingBrol.Title = importedBrol.Title;
  404.   }
  405.   foreach (BrolCategory cat in importedBrol.Categories)
  406.   {
  407.   key = cat.Name.ToUpper() + existingBrol.BrolType.Id;
  408.   //exists into bibliobrol
  409.   if (categories.Contains(key))
  410.   {
  411.   cat.Id = (int)categories[key];
  412.  
  413.   //check with found Brol item
  414.   cat.Status = STATUS.none;
  415.   foreach (BrolCategory tempCat in existingBrol.Categories)
  416.   {
  417.   if (tempCat.Id == cat.Id)
  418.   {
  419.   cat.Status = STATUS.toAdd;
  420.   break;
  421.   }
  422.   }
  423.   //cat exists into bibliobrol, but not into existing brol
  424.   if (cat.Status.Equals(STATUS.toAdd))
  425.   {
  426.   existingBrol.addCategory(cat);
  427.   }
  428.   }
  429.   //don't exists into bibliobrol (and don't exists into existing brol)
  430.   else
  431.   {
  432.   cat.Status = STATUS.toAppAdd;
  433.   //insert new category into bibliobrol
  434.   cat.Id = AccessConfigDao.Instance.insertCategory(cat, existingBrol.BrolType, dbCon, dbDa);
  435.   cat.Status = STATUS.toAdd;
  436.   categories.Add(key, cat.Id);
  437.   existingBrol.addCategory(cat);
  438.   }
  439.   }
  440.   notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 3", this));
  441.  
  442.   foreach (Actor actor in importedBrol.Actors)
  443.   {
  444.   key = getPersonKey(actor);
  445.   //exists into bibliobrol
  446.   if (persons.Contains(key))
  447.   {
  448.   actor.Id = (int)persons[key];
  449.  
  450.   //check with found Brol item
  451.   STATUS = STATUS.none;
  452.   foreach (Actor tempActor in existingBrol.Actors)
  453.   {
  454.   if (tempActor.Id == actor.Id)
  455.   {
  456.   STATUS = STATUS.toAdd;
  457.   break;
  458.   }
  459.   }
  460.   //person exists into bibliobrol, but actor not exists into current loaded brol
  461.   if (STATUS.Equals(STATUS.toAdd))
  462.   {
  463.   existingBrol.addActor(actor);
  464.   }
  465.   }
  466.   //don't exists into bibliobrol (and don't exists into existing brol)
  467.   else
  468.   {
  469.   STATUS = STATUS.toAppAdd;
  470.   //insert new category into bibliobrol
  471.   actor.Id = AccessPersonDao.Instance.insertPerson(actor.getPerson(), dbCon, dbDa, str);
  472.   STATUS = STATUS.toAdd;
  473.   persons.Add(key, actor.Id);
  474.   existingBrol.addActor(actor);
  475.   }
  476.   }
  477.   notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 4", this));
  478.   if (String.Empty.Equals(existingBrol.Comment) && !String.Empty.Equals(importedBrol.Comment))
  479.   {
  480.   existingBrol.Comment = importedBrol.Comment;
  481.   }
  482.   if (String.Empty.Equals(existingBrol.Synopsis) && !String.Empty.Equals(importedBrol.Synopsis))
  483.   {
  484.   existingBrol.Synopsis = importedBrol.Synopsis;
  485.   }
  486.   if ((new DateTime(0L)).Equals(existingBrol.Date) && !(new DateTime(0L)).Equals(importedBrol.Date))
  487.   {
  488.   existingBrol.Date = importedBrol.Date;
  489.   }
  490.   if (existingBrol.Cotation < 1 && importedBrol.Cotation > 0)
  491.   {
  492.   existingBrol.Cotation = importedBrol.Cotation;
  493.   }
  494.   notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 5", this));
  495.   if (existingBrol.Id < 0)
  496.   {
  497.   AccessBrolDao.Instance.insertBrol(existingBrol, dbCon, dbDa, false);
  498.   }
  499.   else
  500.   {
  501.   AccessBrolDao.Instance.updateBrol(existingBrol, dbCon, dbDa, false, str);
  502.   }
  503.   notify(new Notification(Notification.VERBOSE.internalNotification, "pb2", "step 6", this));
  504.   str.AppendLine(String.Format("Ouvrage {0} : {1}", existingBrol.Id, existingBrol.Title));
  505.   notify(new Notification(Notification.VERBOSE.internalNotification, "brolEnd", "", this));
  506.  
  507.   }*/
  508. return null;
  509. }
  510. /// <summary>
  511. /// Get a Hashtable with all categories ids.
  512. /// key : name.toUpper()+typeId
  513. /// value : id
  514. /// </summary>
  515. /// <returns>Hashtable with categories ids</returns>
  516. private Hashtable getCategoriesHashtable(DbConnection dbCon, DbDataAdapter dbDa)
  517. {
  518. Hashtable categories = new Hashtable();
  519. DataTable catsDt = new DataTable();
  520. dbDa.SelectCommand.CommandText = "SELECT id, typeId, name FROM category";
  521. notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this));
  522. try
  523. {
  524. dbDa.Fill(catsDt);
  525. foreach (DataRow row in catsDt.Rows)
  526. {
  527. if (!(row["id"] is DBNull) && !(row["name"] is DBNull))
  528. {
  529. categories.Add(((String)row["name"]).ToUpper()+(int)row["typeId"], (int)row["id"]);
  530. }
  531. }
  532. }
  533. catch (Exception e)
  534. {
  535. notify(new Notification(Notification.VERBOSE.advancedOperation, "Chargement des catégories", e, this));
  536. }
  537. /*foreach (BrolCategory c in AccessBrolDao.Instance.loadCategories(-2))
  538.   {
  539.   categories.Add(c.Name.ToUpper(), c.Id);
  540.   }*/
  541. return categories;
  542. }
  543.  
  544. /// <summary>
  545. /// Get a Hashtable with all persons ids.
  546. /// key : see String getPersonKey(Person person) method
  547. /// value : id
  548. /// </summary>
  549. /// <returns>Hashtable with persons ids</returns>
  550. private Hashtable getPersonsHashtable()
  551. {
  552. Hashtable persons = new Hashtable();
  553. foreach (Person person in NoChangePersonDao.Instance.loadPersons())
  554. {
  555. persons.Add(getPersonKey(person), person.Id);
  556. }
  557. return persons;
  558. }
  559. /// <summary>
  560. /// Get a Hashtable with all types ids.
  561. /// key : type name
  562. /// value : id
  563. /// </summary>
  564. /// <returns>Hashtable with persons ids</returns>
  565. private Hashtable getTypesHashtable()
  566. {
  567. Hashtable types = new Hashtable();
  568. foreach (BrolType type in NoChangeConfigDao.Instance.loadBrolTypes())
  569. {
  570. types.Add(type.Name.ToUpper(), type.Id);
  571. }
  572. return types;
  573. }
  574. /// <summary>
  575. /// Get a key for a person : FirstName.ToUpper() + LastName.ToUpper();
  576. /// </summary>
  577. /// <param name="person">(Person) from which we need a key</param>
  578. /// <returns>(String)person key</returns>
  579. private String getPersonKey(Person person)
  580. {
  581. return person.FirstName.ToUpper() + person.LastName.ToUpper();
  582. }
  583.  
  584. #endregion
  585. }
  586. }

Structure et Fichiers du projet

Afficher/masquer...


Répertoires contenus dans /var/www/bin/sniplets/bibliobrol/src/model/dao/mysql/ 
IcôneNomTailleModification
IcôneNomTailleModification
| _ Répertoire parent0 octets1736378905 09/01/2025 00:28:25
| _utils0 octets1541007203 31/10/2018 18:33:23
Fichiers contenus dans /var/www/bin/sniplets/bibliobrol/src/model/dao/mysql/ 
IcôneNomTailleModificationAction
IcôneNomTailleModificationAction
Afficher le fichier .cs|.csNoChangeImporterDao.cs27.14 Ko31/10/2018 18:33:18-refusé-
Afficher le fichier .cs|.csNoChangeExporterDao.cs33.69 Ko31/10/2018 18:33:18-refusé-
Afficher le fichier .cs|.csNoChangeSerieDao.cs6.22 Ko31/10/2018 18:33:18-refusé-
Afficher le fichier .cs|.csMySQLFactory.cs3.75 Ko31/10/2018 18:33:17-refusé-
Afficher le fichier .cs|.csNoChangeConfigDao.cs12.25 Ko31/10/2018 18:33:18-refusé-
Afficher le fichier .cs|.csNoChangePersonDao.cs59.9 Ko31/10/2018 18:33:18-refusé-
Afficher le fichier .cs|.csNoChangeTaskDao.cs8.92 Ko31/10/2018 18:33:18-refusé-
Afficher le fichier .cs|.csNoChangeBrolDao.cs58.25 Ko31/10/2018 18:33:18-refusé-
Afficher le fichier .cs|.csMySQLStatsDao.cs10.63 Ko31/10/2018 18:33:18-refusé-
Afficher le fichier .cs|.csMySQLMediaBrolDao.cs50.51 Ko31/10/2018 18:33:18-refusé-

Utilisation de l'explorateur de code

  • Navigation :
    • Un clic sur une icône de répertoire ouvre ce répertoire pour en afficher les fichiers.
    • Lorsque le répertoire en cours ne contient pas de sous-répertoires il est possible de remonter vers le répertoire parent.
    • La structure de répertoires en treetable (tableau en forme d'arborescence) n'est plus possibledans cette version.
    • Un clic sur une icône de fichier ouvre ce fichier pour en afficher le code avec la coloration syntaxique adaptée en fonction du langage principal utilisé dans le fichier.
  • Affichage :
    • Il est possible de trier les répertoires ou les fichiers selon certains critères (nom, taille, date).
  • Actions :
    • Les actions possible sur les fichiers dépendent de vos droits d'utilisateur sur le site. Veuillez activer le mode utilisateur pour activer les actions.

English translation

You have asked to visit this site in English. For now, only the interface is translated, but not all the content yet.

If you want to help me in translations, your contribution is welcome. All you need to do is register on the site, and send me a message asking me to add you to the group of translators, which will give you the opportunity to translate the pages you want. A link at the bottom of each translated page indicates that you are the translator, and has a link to your profile.

Thank you in advance.

Document created the 16/10/2009, last modified the 26/10/2018
Source of the printed document:https://www.gaudry.be/en/cs-bibliobrol-source-rf-model/dao/mysql/NoChangeImporterDao.cs.html

The infobrol is a personal site whose content is my sole responsibility. The text is available under CreativeCommons license (BY-NC-SA). More info on the terms of use and the author.