{"id":10080,"date":"2019-08-02T12:06:26","date_gmt":"2019-08-02T03:06:26","guid":{"rendered":"http:\/\/www.moonmile.net\/blog\/?p=10080"},"modified":"2019-08-02T14:26:53","modified_gmt":"2019-08-02T05:26:53","slug":"asp-net-mvc-%e3%81%8b%e3%82%89-redminemysql-%e3%82%92%e6%93%8d%e4%bd%9c%e3%81%99%e3%82%8b","status":"publish","type":"post","link":"http:\/\/www.moonmile.net\/blog\/archives\/10080","title":{"rendered":"ASP.NET MVC \u304b\u3089 Redmine+MySQL \u3092\u64cd\u4f5c\u3059\u308b"},"content":{"rendered":"<p>\u4ee5\u524d <a href=\"http:\/\/www.moonmile.net\/blog\/archives\/9141\">\u72ec\u81ea\u306b\u30dd\u30fc\u30c8\u30d5\u30a9\u30ef\u30fc\u30c9\u4f5c\u6210\u3057\u3001\u30e9\u30ba\u30d1\u30a4\u306e MySQL \u3078 LINQ \u3067\u63a5\u7d9a\u3059\u308b<\/a> \u3067 SSH \u30dd\u30fc\u30c8\u30d5\u30a9\u30ef\u30fc\u30c9\u3092\u4f7f\u3063\u3066 MySQL \u306b\u63a5\u7d9a\u3057\u305f\u306e\u3060\u304c\u3001\u3053\u308c\u3092\u3082\u3046\u3061\u3087\u3063\u3068\u6d3b\u7528\u3059\u308b\u3068\u3001.NET Core \u3067\u4f5c\u6210\u3057\u305f ASP.NET MVC \u304b\u3089 Redmine \u306e MySQL \u3092\u95b2\u89a7\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308b\u3002<\/p>\n<h2 id=\"%E4%B8%BB%E3%81%AA%E6%89%8B%E9%A0%86\">\u4e3b\u306a\u624b\u9806<\/h2>\n<ol>\n<li>Redmine \u30c6\u30fc\u30d6\u30eb\u306e EF \u3092\u7528\u610f\u3059\u308b<\/li>\n<li>ASP.NET MVC \u306e\u3072\u306a\u5f62\u3092 .NET Core \u3067\u4f5c\u308b<\/li>\n<li>ASP.NET MVC \u306b EF \u3092\u30b3\u30d4\u30fc\u3059\u308b<\/li>\n<li>ASP.NET MVC \u306e\u30b9\u30ad\u30e3\u30d5\u30a9\u30fc\u30c9\u6a5f\u80fd\u3092\u4f7f\u3063\u3066\u3001Controller \u3068 \u5404\u7a2e\u306e View \u3092\u81ea\u52d5\u751f\u6210\u3059\u308b\u3002<\/li>\n<li>\u52d5\u4f5c\u6642\u306f\u3001SSH \u30dd\u30fc\u30c8\u30d5\u30a9\u30ef\u30fc\u30c9\u3067\u3001\u5b9f\u904b\u7528\u306e Redmine + MySQL \u306b\u63a5\u7d9a\u3055\u305b\u308b<\/li>\n<\/ol>\n<p>ASP.NET MVC \u3067\u5229\u7528\u3059\u308b EF \u306f\u76f4\u63a5 MySQL \u304b\u3089\u4f5c\u6210\u3057\u3066\u3082\u3088\u3044\u306e\u3060\u3051\u3069\u3001\u4f55\u304b\u3068\u9762\u5012\u306a\u306e\u3067\u624b\u4f5c\u696d\u3067\u4f5c\u308b\u304b\u3001\u3042\u3089\u304b\u3058\u3081 SQL Server \u3067\u4f5c\u3063\u305f\u3082\u306e\u3092\u7528\u610f\u3059\u308b\u3002<\/p>\n<h2 id=\"ef-%E3%81%AE%E3%83%A2%E3%83%87%E3%83%AB%E3%82%AF%E3%83%A9%E3%82%B9%E3%82%92%E4%BD%9C%E6%88%90%E3%81%99%E3%82%8B\">EF \u306e\u30e2\u30c7\u30eb\u30af\u30e9\u30b9\u3092\u4f5c\u6210\u3059\u308b<\/h2>\n<p>Visual Studio \u304b\u3089 EF \u3092\u4f5c\u6210\u3059\u308b\u307b\u3046\u304c\u697d\u306a\u306e\u3067\u3001&#8221;ADO.NET Entity Data Model&#8221; \u3092\u8ffd\u52a0\u3057\u3066\u3001SQL Server \u4e0a\u306b\u4f5c\u6210\u3057\u305f Redmine \u306e\u30c6\u30fc\u30d6\u30eb\u304b\u3089\u3001\u30e2\u30c7\u30eb\u30af\u30e9\u30b9\u3092\u4f5c\u6210\u3059\u308b\u3002<\/p>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190801_01org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190801_01thum.jpg\"><\/a><\/p>\n<p>\u5fc5\u8981\u306a\u306e\u306f\u3001RedmineModel.tt \u914d\u4e0b\u306b\u3042\u308b *.cs \u306e\u30af\u30e9\u30b9\u3067\u3001\u305f\u3068\u3048\u3070\u30c1\u30b1\u30c3\u30c8\u3092\u7ba1\u7406\u3057\u3066\u3044\u308b issues \u30af\u30e9\u30b9\u306f\u3053\u3093\u306a\u611f\u3058\u306b\u306a\u308b\u3002<\/p>\n<pre class=\"hljs\"><code>\n\n\n<div>public partial class issues\n{\n    public int id { get; set; }\n    public int tracker_id { get; set; }\n    public int project_id { get; set; }\n    public string subject { get; set; }\n    public string description { get; set; }\n    public Nullable&lt;System.DateTime&gt; due_date { get; set; }\n    public Nullable&lt;int&gt; category_id { get; set; }\n    public int status_id { get; set; }\n    public Nullable&lt;int&gt; assigned_to_id { get; set; }\n    public int priority_id { get; set; }\n    public Nullable&lt;int&gt; fixed_version_id { get; set; }\n    public int author_id { get; set; }\n    public int lock_version { get; set; }\n    public Nullable&lt;System.DateTime&gt; created_on { get; set; }\n    public Nullable&lt;System.DateTime&gt; updated_on { get; set; }\n    public Nullable&lt;System.DateTime&gt; start_date { get; set; }\n    public int done_ratio { get; set; }\n    public Nullable&lt;double&gt; estimated_hours { get; set; }\n    public Nullable&lt;int&gt; parent_id { get; set; }\n    public Nullable&lt;int&gt; root_id { get; set; }\n    public Nullable&lt;int&gt; lft { get; set; }\n    public Nullable&lt;int&gt; rgt { get; set; }\n    public bool is_private { get; set; }\n    public Nullable&lt;System.DateTime&gt; closed_on { get; set; }\n}\n<\/div>\n\n\n<\/code><\/pre>\n<h2 id=\"aspnet-mvc-core-%E3%81%AE%E3%81%B2%E3%81%AA%E5%BD%A2%E3%82%92%E4%BD%9C%E3%82%8B\">ASP.NET MVC Core \u306e\u3072\u306a\u5f62\u3092\u4f5c\u308b<\/h2>\n<p>\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u304b\u3089\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u4f5c\u6210\u3059\u308b\u3002<\/p>\n<pre class=\"hljs\"><code>\n\n\n<div>dotnet new mvc -n redmine.web\n<\/div>\n\n\n<\/code><\/pre>\n<p>VSCode \u3092\u4f7f\u3063\u3066\u3082\u3088\u3044\u306e\u3060\u3051\u3069\u3001\u30b9\u30ad\u30e3\u30d5\u30a9\u30fc\u30c9\u6a5f\u80fd\u3092\u4f7f\u3046\u5834\u5408\u3001Visual Studio 2019 \u3092\u4f7f\u3063\u305f\u307b\u3046\u304c\u3088\u3044\u306e\u3067\u3001*.sln \u30d5\u30a1\u30a4\u30eb\u3082\u4f5c\u3063\u3066\u304a\u304f\u3002<\/p>\n<h2 id=\"ef-%E3%81%AE%E3%83%A2%E3%83%87%E3%83%AB%E3%82%AF%E3%83%A9%E3%82%B9%E3%82%92%E3%82%B3%E3%83%94%E3%83%BC%E3%81%99%E3%82%8B\">EF \u306e\u30e2\u30c7\u30eb\u30af\u30e9\u30b9\u3092\u30b3\u30d4\u30fc\u3059\u308b<\/h2>\n<p>\u5148\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u4f5c\u6210\u3057\u305f\u30e2\u30c7\u30eb\u30af\u30e9\u30b9\u3092 ASP.NET MVC \u306e Models \u30d5\u30a9\u30eb\u30c0\u30fc\u306b\u30b3\u30d4\u30fc\u3059\u308b\u3002<\/p>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190801_03org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190801_03thum.jpg\"><\/a><\/p>\n<p>\u6ce8\u610f\u3057\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u306e\u306f\u3001Redmine \u3067\u306f tinyint(1) \u3092\u30d5\u30e9\u30b0\u4ee3\u308f\u308a\u306b\u4f7f\u3063\u3066\u3044\u308b\u306e\u3067\u3001\u3053\u308c\u3092 bool \u578b\u3067\u6271\u3046\u304b\uff1f int \u578b\u3067\u6271\u3046\u304b\u3068\u3044\u3046\u554f\u984c\u304c\u3042\u308b\u3002\u672c\u6765\u306f\u30c1\u30a7\u30c3\u30af\u30dc\u30c3\u30af\u30b9\u306b\u3057\u305f\u3044\u306e\u3067 bool \u578b\u306b\u3057\u305f\u3044\u3068\u3053\u308d\u306a\u306e\u3060\u304c\u3001\u3072\u3068\u307e\u305a int \u578b\u306b\u3057\u3066\u304a\u304f\u3002<\/p>\n<pre class=\"hljs\"><code>\n\n\n<div>public partial class issues\n{\n    public int id { get; set; }\n    public int tracker_id { get; set; }\n    public int project_id { get; set; }\n    public string subject { get; set; }\n    public string description { get; set; }\n    public Nullable&lt;System.DateTime&gt; due_date { get; set; }\n    public Nullable&lt;int&gt; category_id { get; set; }\n    public int status_id { get; set; }\n    public Nullable&lt;int&gt; assigned_to_id { get; set; }\n    public int priority_id { get; set; }\n    public Nullable&lt;int&gt; fixed_version_id { get; set; }\n    public int author_id { get; set; }\n    public int lock_version { get; set; }\n    public Nullable&lt;System.DateTime&gt; created_on { get; set; }\n    public Nullable&lt;System.DateTime&gt; updated_on { get; set; }\n    public Nullable&lt;System.DateTime&gt; start_date { get; set; }\n    public int done_ratio { get; set; }\n    public Nullable&lt;double&gt; estimated_hours { get; set; }\n    public Nullable&lt;int&gt; parent_id { get; set; }\n    public Nullable&lt;int&gt; root_id { get; set; }\n    public Nullable&lt;int&gt; lft { get; set; }\n    public Nullable&lt;int&gt; rgt { get; set; }\n    public int is_private { get; set; }\n    public Nullable&lt;System.DateTime&gt; closed_on { get; set; }\n}\n<\/div>\n\n\n<\/code><\/pre>\n<p>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u63a5\u7d9a\u60c5\u5831\u3084\u30c7\u30fc\u30bf\u30a2\u30af\u30bb\u30b9\u3092 LINQ \u3067\u4f7f\u3048\u308b\u3088\u3046\u306b\u3059\u308b\u305f\u3081\u3001DbContext \u3092\u7d99\u627f\u3057\u305f RedmineContext \u30af\u30e9\u30b9\u3092\u4f5c\u308b\u3002<\/p>\n<pre class=\"hljs\"><code>\n\n\n<div>namespace redmine.web.Data\n{\n    public class RedmineContext : DbContext\n    {\n        public RedmineContext(DbContextOptions&lt;RedmineContext&gt; options)\n            : base(options)\n        {\n        }\n\n        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)\n        {\n            base.OnConfiguring(optionsBuilder);\n        }\n    }\n}\n<\/div>\n\n\n<\/code><\/pre>\n<p>NuGet\u3067 MySql.Data.EntityFrameworkCore \u3092\u5165\u308c\u305f\u5f8c\u3001<br \/>\nStartup.cs \u3092\u958b\u3044\u3066\u3001MySQL \u3078\u306e\u63a5\u7d9a\u6587\u5b57\u5217\u3092 ConfigureServices \u30e1\u30bd\u30c3\u30c9\u5185\u306b\u66f8\u304f\u3002<\/p>\n<pre class=\"hljs\"><code>\n\n\n<div>public class Startup\n{\n    public Startup(IConfiguration configuration)\n    {\n        Configuration = configuration;\n    }\n\n    public IConfiguration Configuration { get; }\n\n    \/\/ This method gets called by the runtime. Use this method to add services to the container.\n    public void ConfigureServices(IServiceCollection services)\n    {\n        services.Configure&lt;CookiePolicyOptions&gt;(options =&gt;\n        {\n            \/\/ This lambda determines whether user consent for non-essential cookies is needed for a given request.\n            options.CheckConsentNeeded = context =&gt; true;\n            options.MinimumSameSitePolicy = SameSiteMode.None;\n        });\n\n        services.AddDbContext&lt;redmine.web.Data.RedmineContext&gt;(options =&gt;\n            options.UseMySQL(@\"server=localhost;user id=redmine;password=redmine;database=redmine;port=3306;sslmode=None\");\n        });\n\n        services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);\n    }\n<\/div>\n\n\n<\/code><\/pre>\n<h2 id=\"%E3%82%B9%E3%82%AD%E3%83%A3%E3%83%95%E3%82%A9%E3%83%BC%E3%83%89%E6%A9%9F%E8%83%BD%E3%81%A7-controller-%E3%81%A8-view-%E3%82%92%E4%BD%9C%E3%82%8B\">\u30b9\u30ad\u30e3\u30d5\u30a9\u30fc\u30c9\u6a5f\u80fd\u3067 Controller \u3068 View \u3092\u4f5c\u308b<\/h2>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_01org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_01thum.jpg\"><\/a><\/p>\n<h2 id=\"%E3%81%B2%E3%81%A8%E3%81%BE%E3%81%9A%E3%83%AD%E3%83%BC%E3%82%AB%E3%83%AB%E3%81%AE-mysql%E3%81%AB%E6%8E%A5%E7%B6%9A%E3%81%97%E3%81%A6%E7%A2%BA%E8%AA%8D%E3%81%99%E3%82%8B\">\u3072\u3068\u307e\u305a\u30ed\u30fc\u30ab\u30eb\u306e MySQL\u306b\u63a5\u7d9a\u3057\u3066\u78ba\u8a8d\u3059\u308b<\/h2>\n<p>Visual Studio \u304b\u3089\u30c7\u30d0\u30c3\u30b0\u5b9f\u884c\u3059\u308b\u3068\u3001\u30c7\u30d0\u30c3\u30b0\u7528\u306e\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u304c\u8868\u793a\u3055\u308c\u3066\u3001localhost:5000 \u3078\u63a5\u7d9a\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308b\u3002<\/p>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_03org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_03thum.jpg\"><\/a><\/p>\n<p>https:\/\/localhost:5001\/Issues \u306e\u3088\u3046\u306b\u30a2\u30af\u30bb\u30b9\u3059\u308b\u3068\u3001MySQL \u306e\u4e2d\u8eab\u304c\u8868\u793a\u3055\u308c\u308b\u3002Issue \u306e\u4e00\u89a7\u306b\u306a\u308b\u306e\u3067\u3001\u3059\u3079\u3066\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e Issue \u304c\u307e\u3068\u3081\u3066\u8868\u793a\u3055\u308c\u3066\u3057\u307e\u3046\u304c\u3001\u3053\u308c\u306f\u72ec\u81ea\u306b\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u3092\u4f7f\u3063\u3066\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u5185\u306e\u307f\u8868\u793a\u3055\u305b\u308c\u3070\u3088\u3044\u3002<\/p>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_02org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_02thum.jpg\"><\/a><\/p>\n<h2 id=\"ssh-%E3%83%9D%E3%83%BC%E3%83%88%E3%83%95%E3%82%A9%E3%83%AF%E3%83%BC%E3%83%89%E3%82%92%E4%BD%BF%E3%81%86\">SSH \u30dd\u30fc\u30c8\u30d5\u30a9\u30ef\u30fc\u30c9\u3092\u4f7f\u3046<\/h2>\n<p>options.UseMySQL \u3067\u8a18\u8ff0\u3057\u305f\u63a5\u7d9a\u5148\u3092 SSH \u30dd\u30fc\u30c8\u30d5\u30a9\u30ef\u30fc\u30c9\u7528\u306b\u5909\u66f4\u3059\u308c\u3070\u3088\u3044\u306e\u3060\u304c\u3001\u3072\u3068\u307e\u305a SSH \u3067\u7e4b\u304c\u308b\u304b\u3069\u3046\u304b\u3092 MySQL Workbench \u3067\u63a5\u7d9a\u3057\u3066\u307f\u308b<\/p>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_04org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_04thum.jpg\"><\/a><\/p>\n<p>Connection Method \u3092 &#8220;Standard TCP\/IP over SSH&#8221; \u306b\u5909\u66f4\u3057\u3066 SSH \u7d4c\u7531\u3067\u63a5\u7d9a\u3067\u304d\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u304a\u304f\u3002<\/p>\n<p>\u305d\u306e\u5f8c\u3067\u3001Ubuntu on Windows \u3067\u3001localhost \u306e 190000\u756a\u3092 openccpm.com \u5185\u90e8\u306b\u3042\u308b MySQL(3306) \u306b\u901a\u3059\u3088\u3046\u306b\u3059\u308b\u3002<\/p>\n<pre class=\"hljs\"><code>\n\n\n<div>ssh -L 19000:localhost:3306 masuda@openccpm.com\n<\/div>\n\n\n<\/code><\/pre>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_05org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2019\/08\/images20190802_05thum.jpg\"><\/a><\/p>\n<p>Setup.cs \u306e\u8a72\u5f53\u7b87\u6240\u3092\u66f8\u304d\u63db\u3048\u308b<\/p>\n<pre class=\"hljs\"><code>\n\n\n<div>services.AddDbContext&lt;redmine.web.Data.RedmineContext&gt;(options =&gt;\n{\n    options.UseMySQL(@\"server=localhost;user id=redmine;password=redmine;database=redmine;port=19000;sslmode=None\");\n});\n<\/div>\n\n\n<\/code><\/pre>\n<p>Visual Studio 2019 \u304b\u3089\u30c7\u30d0\u30c3\u30b0\u5b9f\u884c\u3067\u304d\u308c\u3070 ok.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u4ee5\u524d \u72ec\u81ea\u306b\u30dd\u30fc\u30c8\u30d5\u30a9\u30ef\u30fc\u30c9\u4f5c\u6210\u3057\u3001\u30e9\u30ba\u30d1\u30a4\u306e MySQL \u3078 LINQ \u3067\u63a5\u7d9a\u3059\u308b \u3067 SSH \u30dd\u30fc\u30c8\u30d5\u30a9\u30ef\u30fc\u30c9\u3092\u4f7f\u3063\u3066 MySQL \u306b\u63a5\u7d9a\u3057\u305f\u306e\u3060\u304c\u3001\u3053\u308c\u3092\u3082\u3046\u3061\u3087\u3063\u3068\u6d3b\u7528\u3059\u308b\u3068\u3001.NET Core \u3067\u4f5c\u6210\u3057\u305f AS &hellip; <a href=\"http:\/\/www.moonmile.net\/blog\/archives\/10080\">\u7d9a\u304d\u3092\u8aad\u3080 <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[3],"tags":[],"class_list":["post-10080","post","type-post","status-publish","format-standard","hentry","category-dev"],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/10080","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/comments?post=10080"}],"version-history":[{"count":4,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/10080\/revisions"}],"predecessor-version":[{"id":10084,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/10080\/revisions\/10084"}],"wp:attachment":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/media?parent=10080"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/categories?post=10080"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/tags?post=10080"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}