Send NET C# » History » Version 1
Tomek Dziemidowicz, 2019-07-18 09:06 PM
| 1 | 1 | Tomek Dziemidowicz | h1. Send NET C# |
|---|---|---|---|
| 2 | |||
| 3 | <pre><code class="csharp"> |
||
| 4 | /// <summary> |
||
| 5 | /// Send changes (updates, insert, deletes) from local database to server |
||
| 6 | /// </summary> |
||
| 7 | /// <param name="subscriberId"></param> |
||
| 8 | private void SendChanges(string subscriberId) |
||
| 9 | { |
||
| 10 | using (SQLiteConnection conn = new SQLiteConnection(this.connString)) |
||
| 11 | { |
||
| 12 | using (SQLiteCommand cmd = new SQLiteCommand()) |
||
| 13 | { |
||
| 14 | cmd.Connection = conn; |
||
| 15 | conn.Open(); |
||
| 16 | |||
| 17 | SQLiteHelper sh = new SQLiteHelper(cmd); |
||
| 18 | |||
| 19 | DataTable tables = sh.Select("select tbl_Name from sqlite_master where type='table' and sql like '%RowId%';"); |
||
| 20 | |||
| 21 | StringBuilder sqlitesync_SyncDataToSend = new StringBuilder(); |
||
| 22 | sqlitesync_SyncDataToSend.Append("<?xml version=\"1.0\" encoding=\"utf-8\"?><SyncData xmlns=\"urn:sync-schema\">"); |
||
| 23 | |||
| 24 | foreach (DataRow table in tables.Rows) |
||
| 25 | { |
||
| 26 | string tableName = table["tbl_Name"].ToString(); |
||
| 27 | if (tableName.ToLower() != "MergeDelete".ToLower()) |
||
| 28 | { |
||
| 29 | try |
||
| 30 | { |
||
| 31 | sqlitesync_SyncDataToSend.Append("<tab n=\"" + tableName + "\">"); |
||
| 32 | |||
| 33 | #region new records |
||
| 34 | DataTable newRecords = sh.Select("select * from " + tableName + " where RowId is null;"); |
||
| 35 | sqlitesync_SyncDataToSend.Append("<ins>"); |
||
| 36 | foreach (DataRow record in newRecords.Rows) |
||
| 37 | { |
||
| 38 | sqlitesync_SyncDataToSend.Append("<r>"); |
||
| 39 | foreach (DataColumn column in newRecords.Columns) |
||
| 40 | { |
||
| 41 | if (column.ColumnName != "MergeUpdate") |
||
| 42 | { |
||
| 43 | sqlitesync_SyncDataToSend.Append("<" + column.ColumnName + ">"); |
||
| 44 | sqlitesync_SyncDataToSend.Append("<![CDATA[" + record[column.ColumnName].ToString() + "]]>"); |
||
| 45 | sqlitesync_SyncDataToSend.Append("</" + column.ColumnName + ">"); |
||
| 46 | } |
||
| 47 | } |
||
| 48 | sqlitesync_SyncDataToSend.Append("</r>"); |
||
| 49 | } |
||
| 50 | sqlitesync_SyncDataToSend.Append("</ins>"); |
||
| 51 | #endregion |
||
| 52 | |||
| 53 | #region updated records |
||
| 54 | DataTable updRecords = sh.Select("select * from " + tableName + " where MergeUpdate > 0 and RowId is not null;"); |
||
| 55 | sqlitesync_SyncDataToSend.Append("<upd>"); |
||
| 56 | foreach (DataRow record in updRecords.Rows) |
||
| 57 | { |
||
| 58 | sqlitesync_SyncDataToSend.Append("<r>"); |
||
| 59 | foreach (DataColumn column in updRecords.Columns) |
||
| 60 | { |
||
| 61 | if (column.ColumnName != "MergeUpdate") |
||
| 62 | { |
||
| 63 | sqlitesync_SyncDataToSend.Append("<" + column.ColumnName + ">"); |
||
| 64 | if (record[column.ColumnName].GetType().Name == "Byte[]") |
||
| 65 | sqlitesync_SyncDataToSend.Append("<![CDATA[" + Convert.ToBase64String((byte[])record[column.ColumnName]) + "]]>"); |
||
| 66 | else |
||
| 67 | sqlitesync_SyncDataToSend.Append("<![CDATA[" + record[column.ColumnName].ToString() + "]]>"); |
||
| 68 | sqlitesync_SyncDataToSend.Append("</" + column.ColumnName + ">"); |
||
| 69 | } |
||
| 70 | } |
||
| 71 | sqlitesync_SyncDataToSend.Append("</r>"); |
||
| 72 | } |
||
| 73 | sqlitesync_SyncDataToSend.Append("</upd>"); |
||
| 74 | #endregion |
||
| 75 | |||
| 76 | sqlitesync_SyncDataToSend.Append("</tab>"); |
||
| 77 | } |
||
| 78 | catch (Exception ex) |
||
| 79 | { |
||
| 80 | throw ex; |
||
| 81 | } |
||
| 82 | } |
||
| 83 | } |
||
| 84 | |||
| 85 | #region deleted records |
||
| 86 | DataTable delRecords = sh.Select("select * from MergeDelete;"); |
||
| 87 | sqlitesync_SyncDataToSend.Append("<delete>"); |
||
| 88 | foreach (DataRow record in delRecords.Rows) |
||
| 89 | { |
||
| 90 | sqlitesync_SyncDataToSend.Append("<r>"); |
||
| 91 | sqlitesync_SyncDataToSend.Append("<tb>" + record["TableId"].ToString() + "</tb>"); |
||
| 92 | sqlitesync_SyncDataToSend.Append("<id>" + record["RowId"].ToString() + "</id>"); |
||
| 93 | sqlitesync_SyncDataToSend.Append("</r>"); |
||
| 94 | } |
||
| 95 | sqlitesync_SyncDataToSend.Append("</delete>"); |
||
| 96 | #endregion |
||
| 97 | |||
| 98 | sqlitesync_SyncDataToSend.Append("</SyncData>"); |
||
| 99 | |||
| 100 | #region send changes to server |
||
| 101 | JsonObject inputObject = new JsonObject(); |
||
| 102 | inputObject.Add("subscriber", subscriberId); |
||
| 103 | inputObject.Add("content", sqlitesync_SyncDataToSend.ToString()); |
||
| 104 | inputObject.Add("version", "3"); |
||
| 105 | |||
| 106 | System.Text.UTF8Encoding encoding = new System.Text.UTF8Encoding(); |
||
| 107 | byte[] bytes = encoding.GetBytes(inputObject.ToString()); |
||
| 108 | |||
| 109 | var request = new RestRequest("Send", Method.POST); |
||
| 110 | request.AddHeader("Content-Type", "application/json"); |
||
| 111 | request.AddHeader("Accept", "*/*"); |
||
| 112 | request.AddHeader("charset", "utf-8"); |
||
| 113 | request.AddHeader("Content-Length", bytes.Length.ToString()); |
||
| 114 | |||
| 115 | request.AddParameter("application/json; charset=utf-8", inputObject.ToString(), ParameterType.RequestBody); |
||
| 116 | request.RequestFormat = DataFormat.Json; |
||
| 117 | |||
| 118 | IRestResponse response = wsClient.Execute(request); |
||
| 119 | #endregion |
||
| 120 | |||
| 121 | #region clear update marker |
||
| 122 | foreach (DataRow table in tables.Rows) |
||
| 123 | { |
||
| 124 | string tableName = table["tbl_Name"].ToString().ToLower(); |
||
| 125 | if (tableName != "MergeDelete".ToLower() && tableName != "MergeIdentity".ToLower()) |
||
| 126 | { |
||
| 127 | string updTriggerSQL = (string)sh.ExecuteScalar("select sql from sqlite_master where type='trigger' and name like 'trMergeUpdate_" + tableName + "'"); |
||
| 128 | sh.Execute("drop trigger trMergeUpdate_" + tableName + ";"); |
||
| 129 | sh.Execute("update " + tableName + " set MergeUpdate=0 where MergeUpdate > 0;"); |
||
| 130 | sh.Execute(updTriggerSQL); |
||
| 131 | } |
||
| 132 | |||
| 133 | if (tableName == "MergeIdentity".ToLower()) |
||
| 134 | sh.Execute("update MergeIdentity set MergeUpdate=0 where MergeUpdate > 0;"); |
||
| 135 | } |
||
| 136 | #endregion |
||
| 137 | |||
| 138 | #region clear delete marker |
||
| 139 | sh.Execute("delete from MergeDelete"); |
||
| 140 | #endregion |
||
| 141 | |||
| 142 | conn.Close(); |
||
| 143 | } |
||
| 144 | } |
||
| 145 | } |
||
| 146 | |||
| 147 | </code></pre> |