You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

792 lines
26 KiB

  1. <!doctype html>
  2. <html lang="en" class="no-js">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width,initial-scale=1">
  6. <meta name="description" content="A Text Annotation tool for Humans">
  7. <link rel="canonical" href="https://doccano.github.io/doccano/setup_cloud_storage/">
  8. <meta name="author" content="Hiroki Nakayama">
  9. <link rel="shortcut icon" href="../assets/images/favicon.png">
  10. <meta name="generator" content="mkdocs-1.1.2, mkdocs-material-6.1.0">
  11. <title>Setup cloud storage - doccano</title>
  12. <link rel="stylesheet" href="../assets/stylesheets/main.bc7e593a.min.css">
  13. <link rel="stylesheet" href="../assets/stylesheets/palette.ab28b872.min.css">
  14. <meta name="theme-color" content="#00bdd6">
  15. <link href="https://fonts.gstatic.com" rel="preconnect" crossorigin>
  16. <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,400i,700%7CRoboto+Mono&display=fallback">
  17. <style>body,input{font-family:"Roboto",-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif}code,kbd,pre{font-family:"Roboto Mono",SFMono-Regular,Consolas,Menlo,monospace}</style>
  18. </head>
  19. <body dir="ltr" data-md-color-scheme="" data-md-color-primary="cyan" data-md-color-accent="cyan">
  20. <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
  21. <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
  22. <label class="md-overlay" for="__drawer"></label>
  23. <div data-md-component="skip">
  24. <a href="#setup-cloud-storage" class="md-skip">
  25. Skip to content
  26. </a>
  27. </div>
  28. <div data-md-component="announce">
  29. </div>
  30. <header class="md-header" data-md-component="header">
  31. <nav class="md-header-nav md-grid" aria-label="Header">
  32. <a href="https://doccano.github.io/doccano/" title="doccano" class="md-header-nav__button md-logo" aria-label="doccano">
  33. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 003-3 3 3 0 00-3-3 3 3 0 00-3 3 3 3 0 003 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54z"/></svg>
  34. </a>
  35. <label class="md-header-nav__button md-icon" for="__drawer">
  36. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg>
  37. </label>
  38. <div class="md-header-nav__title" data-md-component="header-title">
  39. <div class="md-header-nav__ellipsis">
  40. <span class="md-header-nav__topic md-ellipsis">
  41. doccano
  42. </span>
  43. <span class="md-header-nav__topic md-ellipsis">
  44. Setup cloud storage
  45. </span>
  46. </div>
  47. </div>
  48. <div class="md-header-nav__source">
  49. <a href="https://github.com/doccano/doccano/" title="Go to repository" class="md-source">
  50. <div class="md-source__icon md-icon">
  51. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05L244 40.45a28.87 28.87 0 00-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 01-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 000 40.81l195.61 195.6a28.86 28.86 0 0040.8 0l194.69-194.69a28.86 28.86 0 000-40.81z"/></svg>
  52. </div>
  53. <div class="md-source__repository">
  54. doccano/doccano
  55. </div>
  56. </a>
  57. </div>
  58. </nav>
  59. </header>
  60. <div class="md-container" data-md-component="container">
  61. <main class="md-main" data-md-component="main">
  62. <div class="md-main__inner md-grid">
  63. <div class="md-sidebar md-sidebar--primary" data-md-component="navigation">
  64. <div class="md-sidebar__scrollwrap">
  65. <div class="md-sidebar__inner">
  66. <nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
  67. <label class="md-nav__title" for="__drawer">
  68. <a href="https://doccano.github.io/doccano/" title="doccano" class="md-nav__button md-logo" aria-label="doccano">
  69. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 003-3 3 3 0 00-3-3 3 3 0 00-3 3 3 3 0 003 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54z"/></svg>
  70. </a>
  71. doccano
  72. </label>
  73. <div class="md-nav__source">
  74. <a href="https://github.com/doccano/doccano/" title="Go to repository" class="md-source">
  75. <div class="md-source__icon md-icon">
  76. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05L244 40.45a28.87 28.87 0 00-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 01-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 000 40.81l195.61 195.6a28.86 28.86 0 0040.8 0l194.69-194.69a28.86 28.86 0 000-40.81z"/></svg>
  77. </div>
  78. <div class="md-source__repository">
  79. doccano/doccano
  80. </div>
  81. </a>
  82. </div>
  83. <ul class="md-nav__list" data-md-scrollfix>
  84. <li class="md-nav__item">
  85. <a href=".." class="md-nav__link">
  86. Get started
  87. </a>
  88. </li>
  89. <li class="md-nav__item">
  90. <a href="../install_and_upgrade_doccano/" class="md-nav__link">
  91. Install and upgrade doccano
  92. </a>
  93. </li>
  94. <li class="md-nav__item">
  95. <a href="../tutorial/" class="md-nav__link">
  96. Tutorial
  97. </a>
  98. </li>
  99. <li class="md-nav__item md-nav__item--active">
  100. <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc">
  101. <label class="md-nav__link md-nav__link--active" for="__toc">
  102. Setup cloud storage
  103. <span class="md-nav__icon md-icon"></span>
  104. </label>
  105. <a href="./" class="md-nav__link md-nav__link--active">
  106. Setup cloud storage
  107. </a>
  108. <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
  109. <label class="md-nav__title" for="__toc">
  110. <span class="md-nav__icon md-icon"></span>
  111. Table of contents
  112. </label>
  113. <ul class="md-nav__list" data-md-scrollfix>
  114. <li class="md-nav__item">
  115. <a href="#amazon-s3" class="md-nav__link">
  116. Amazon S3
  117. </a>
  118. <nav class="md-nav" aria-label="Amazon S3">
  119. <ul class="md-nav__list">
  120. <li class="md-nav__item">
  121. <a href="#create-credentials" class="md-nav__link">
  122. Create credentials
  123. </a>
  124. </li>
  125. <li class="md-nav__item">
  126. <a href="#create-a-bucket" class="md-nav__link">
  127. Create a bucket
  128. </a>
  129. </li>
  130. <li class="md-nav__item">
  131. <a href="#create-a-env-file" class="md-nav__link">
  132. Create a .env file
  133. </a>
  134. </li>
  135. </ul>
  136. </nav>
  137. </li>
  138. <li class="md-nav__item">
  139. <a href="#google-cloud-storage" class="md-nav__link">
  140. Google Cloud Storage
  141. </a>
  142. <nav class="md-nav" aria-label="Google Cloud Storage">
  143. <ul class="md-nav__list">
  144. <li class="md-nav__item">
  145. <a href="#create-credentials_1" class="md-nav__link">
  146. Create credentials
  147. </a>
  148. </li>
  149. <li class="md-nav__item">
  150. <a href="#create-a-env-file_1" class="md-nav__link">
  151. Create a .env file
  152. </a>
  153. </li>
  154. </ul>
  155. </nav>
  156. </li>
  157. <li class="md-nav__item">
  158. <a href="#run-doccano-with-the-env-file" class="md-nav__link">
  159. Run doccano with the .env file
  160. </a>
  161. <nav class="md-nav" aria-label="Run doccano with the .env file">
  162. <ul class="md-nav__list">
  163. <li class="md-nav__item">
  164. <a href="#pip" class="md-nav__link">
  165. Pip
  166. </a>
  167. </li>
  168. <li class="md-nav__item">
  169. <a href="#docker" class="md-nav__link">
  170. Docker
  171. </a>
  172. </li>
  173. </ul>
  174. </nav>
  175. </li>
  176. <li class="md-nav__item">
  177. <a href="#references" class="md-nav__link">
  178. References
  179. </a>
  180. </li>
  181. </ul>
  182. </nav>
  183. </li>
  184. <li class="md-nav__item md-nav__item--nested">
  185. <input class="md-nav__toggle md-toggle" data-md-toggle="nav-5" type="checkbox" id="nav-5">
  186. <label class="md-nav__link" for="nav-5">
  187. Advanced
  188. <span class="md-nav__icon md-icon"></span>
  189. </label>
  190. <nav class="md-nav" aria-label="Advanced" data-md-level="1">
  191. <label class="md-nav__title" for="nav-5">
  192. <span class="md-nav__icon md-icon"></span>
  193. Advanced
  194. </label>
  195. <ul class="md-nav__list" data-md-scrollfix>
  196. <li class="md-nav__item">
  197. <a href="../advanced/aws_https_settings/" class="md-nav__link">
  198. AWS HTTPS settings
  199. </a>
  200. </li>
  201. <li class="md-nav__item">
  202. <a href="../advanced/oauth2_settings/" class="md-nav__link">
  203. OAuth2 settings
  204. </a>
  205. </li>
  206. <li class="md-nav__item">
  207. <a href="../advanced/auto_labelling_config/" class="md-nav__link">
  208. Auto labeling settings
  209. </a>
  210. </li>
  211. </ul>
  212. </nav>
  213. </li>
  214. <li class="md-nav__item">
  215. <a href="../developer_guide/" class="md-nav__link">
  216. Developer guide
  217. </a>
  218. </li>
  219. <li class="md-nav__item">
  220. <a href="../faq/" class="md-nav__link">
  221. FAQ
  222. </a>
  223. </li>
  224. <li class="md-nav__item">
  225. <a href="../CODE_OF_CONDUCT/" class="md-nav__link">
  226. Code of conduct
  227. </a>
  228. </li>
  229. <li class="md-nav__item">
  230. <a href="../roadmap/" class="md-nav__link">
  231. Roadmap
  232. </a>
  233. </li>
  234. </ul>
  235. </nav>
  236. </div>
  237. </div>
  238. </div>
  239. <div class="md-sidebar md-sidebar--secondary" data-md-component="toc">
  240. <div class="md-sidebar__scrollwrap">
  241. <div class="md-sidebar__inner">
  242. <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
  243. <label class="md-nav__title" for="__toc">
  244. <span class="md-nav__icon md-icon"></span>
  245. Table of contents
  246. </label>
  247. <ul class="md-nav__list" data-md-scrollfix>
  248. <li class="md-nav__item">
  249. <a href="#amazon-s3" class="md-nav__link">
  250. Amazon S3
  251. </a>
  252. <nav class="md-nav" aria-label="Amazon S3">
  253. <ul class="md-nav__list">
  254. <li class="md-nav__item">
  255. <a href="#create-credentials" class="md-nav__link">
  256. Create credentials
  257. </a>
  258. </li>
  259. <li class="md-nav__item">
  260. <a href="#create-a-bucket" class="md-nav__link">
  261. Create a bucket
  262. </a>
  263. </li>
  264. <li class="md-nav__item">
  265. <a href="#create-a-env-file" class="md-nav__link">
  266. Create a .env file
  267. </a>
  268. </li>
  269. </ul>
  270. </nav>
  271. </li>
  272. <li class="md-nav__item">
  273. <a href="#google-cloud-storage" class="md-nav__link">
  274. Google Cloud Storage
  275. </a>
  276. <nav class="md-nav" aria-label="Google Cloud Storage">
  277. <ul class="md-nav__list">
  278. <li class="md-nav__item">
  279. <a href="#create-credentials_1" class="md-nav__link">
  280. Create credentials
  281. </a>
  282. </li>
  283. <li class="md-nav__item">
  284. <a href="#create-a-env-file_1" class="md-nav__link">
  285. Create a .env file
  286. </a>
  287. </li>
  288. </ul>
  289. </nav>
  290. </li>
  291. <li class="md-nav__item">
  292. <a href="#run-doccano-with-the-env-file" class="md-nav__link">
  293. Run doccano with the .env file
  294. </a>
  295. <nav class="md-nav" aria-label="Run doccano with the .env file">
  296. <ul class="md-nav__list">
  297. <li class="md-nav__item">
  298. <a href="#pip" class="md-nav__link">
  299. Pip
  300. </a>
  301. </li>
  302. <li class="md-nav__item">
  303. <a href="#docker" class="md-nav__link">
  304. Docker
  305. </a>
  306. </li>
  307. </ul>
  308. </nav>
  309. </li>
  310. <li class="md-nav__item">
  311. <a href="#references" class="md-nav__link">
  312. References
  313. </a>
  314. </li>
  315. </ul>
  316. </nav>
  317. </div>
  318. </div>
  319. </div>
  320. <div class="md-content">
  321. <article class="md-content__inner md-typeset">
  322. <a href="https://github.com/doccano/doccano/edit/master/docs/setup_cloud_storage.md" title="Edit this page" class="md-content__button md-icon">
  323. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20.71 7.04c.39-.39.39-1.04 0-1.41l-2.34-2.34c-.37-.39-1.02-.39-1.41 0l-1.84 1.83 3.75 3.75M3 17.25V21h3.75L17.81 9.93l-3.75-3.75L3 17.25z"/></svg>
  324. </a>
  325. <h1 id="setup-cloud-storage">Setup cloud storage</h1>
  326. <p>This document explains how to setup cloud storages to store the imported datasets to the cloud storage. The following cloud storages are supported in doccano:</p>
  327. <ul>
  328. <li><a href="#amazon-s3">Amazon S3</a></li>
  329. <li><a href="#google-cloud-storage">Google Cloud Storage</a></li>
  330. </ul>
  331. <h2 id="amazon-s3">Amazon S3</h2>
  332. <p>The steps of connecting your Amazon S3 bucket to doccano to store the imported datasets.</p>
  333. <ul>
  334. <li><a href="#create-credentials">Create credentials</a></li>
  335. <li><a href="#create-a-bucket">Create a bucket</a></li>
  336. <li><a href="#create-a-env-file">Create a .env file</a></li>
  337. </ul>
  338. <h3 id="create-credentials">Create credentials</h3>
  339. <p>You must provide your AWS access keys to make programmatic calls to AWS.</p>
  340. <p>When you create your access keys, you create the access key ID (for example, AKIAIOSFODNN7EXAMPLE) and secret access key (for example, wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY) as a set. The secret access key is available for download only when you create it. If you don't download your secret access key or if you lose it, you must create a new one.</p>
  341. <ol>
  342. <li>Sign in to the AWS Management Console as an IAM user.</li>
  343. <li>In the navigation bar on the upper right, choose your user name and then choose <strong>My Security Credentials</strong>.</li>
  344. <li>To create an access key, choose <strong>Create access key</strong>. If you already have two access keys, this button is disabled and you must delete an access key before you can create a new one. When prompted, choose either <strong>Show secret access key</strong> or <strong>Download .csv file</strong>. This is your only opportunity to save your secret access key. After you've saved your secret access key in a secure location, chose <strong>Close</strong>.</li>
  345. </ol>
  346. <h3 id="create-a-bucket">Create a bucket</h3>
  347. <p>To store your dataset to Amazon S3, you must first create an Amazon S3 bucket in one of the AWS Regions. When you create a bucket, you must choose a bucket name and Region. You can optionally choose other storage management options for the bucket. After you create a bucket, you cannot change the bucket name or Region.</p>
  348. <ol>
  349. <li>Sign in to the AWS Management Console and open the Amazon S3 console.</li>
  350. <li>Choose <strong>Create bucket</strong>.</li>
  351. <li>In Bucket name, enter a name for your bucket(e.g. doccano).</li>
  352. <li>In Region, choose the AWS Region where you want the bucket to reside. Choose a Region close to you to minimize latency and costs and address regulatory requirements.</li>
  353. <li>Under Object Ownership, to disable or enable ACLs and control ownership of objects uploaded in your bucket, choose <strong>ACLs disabled</strong>.</li>
  354. <li>In Bucket settings for Block Public Access, choose the <strong>Block Public Access</strong> settings that you want to apply to the bucket.</li>
  355. <li>Choose <strong>Create bucket</strong>.</li>
  356. </ol>
  357. <h3 id="create-a-env-file">Create a .env file</h3>
  358. <p>Once you create a credential and a bucket, you must create a <code>.env</code> file:</p>
  359. <pre><code class="language-bash">DJANGO_SETTINGS_MODULE=config.settings.aws
  360. AWS_ACCESS_KEY_ID={SET_YOUR_KEY}
  361. AWS_SECRET_ACCESS_KEY={SET_YOUR_SECRET_KEY}
  362. REGION_NAME=us-west-1
  363. BUCKET_NAME=doccano
  364. </code></pre>
  365. <h2 id="google-cloud-storage">Google Cloud Storage</h2>
  366. <p>The steps of connecting your Google Cloud Storage bucket to doccano to store the imported datasets.</p>
  367. <ul>
  368. <li><a href="#create-credentials-1">Create credentials</a></li>
  369. <li><a href="#create-a-env-file-1">Create a .env file</a></li>
  370. </ul>
  371. <h3 id="create-credentials_1">Create credentials</h3>
  372. <p>Create a service account:</p>
  373. <ol>
  374. <li>In the Cloud Console, go to the <a href="https://console.cloud.google.com/projectselector2/iam-admin/serviceaccounts/create">Create service account</a> page.</li>
  375. <li>Select your project.</li>
  376. <li>In the <strong>Service account name</strong> field, enter a name. The Cloud Console fills in the <strong>Service account ID</strong> field based on this name. In the <strong>Service account description</strong> field, enter a description. For example, Service account for quickstart.</li>
  377. <li>Click <strong>Create and continue</strong>.</li>
  378. <li>To provide access to your project, grant the following role(s) to your service account: <strong>Cloud Storage &gt; Storage Admin</strong>.</li>
  379. <li>Click <strong>Continue</strong>.</li>
  380. <li>Click <strong>Done</strong> to finish creating the service account. Do not close your browser window. You will use it in the next step.</li>
  381. </ol>
  382. <p>Create a service account key:</p>
  383. <ol>
  384. <li>In the Cloud Console, click the email address for the service account that you created.</li>
  385. <li>Click <strong>Keys</strong>.</li>
  386. <li>Click <strong>Add key</strong>, then click <strong>Create new key</strong>.</li>
  387. <li>Click <strong>Create</strong>. A JSON key file is downloaded to your computer.</li>
  388. <li>Click <strong>Close</strong>.</li>
  389. </ol>
  390. <h3 id="create-a-env-file_1">Create a .env file</h3>
  391. <p>Once you create a credential and a bucket, you must create a <code>.env</code> file. Notice that the file contents differ slightly between the Pip and Docker versions:</p>
  392. <pre><code class="language-bash">DJANGO_SETTINGS_MODULE=config.settings.gcp
  393. GS_PROJECT_ID={SET_YOUR_PROJECT_ID}
  394. BUCKET_NAME=doccano
  395. # In the case of Pip
  396. GOOGLE_APPLICATION_CREDENTIALS={SET_CREDENTIAL_PATH}
  397. # In the case of Docker
  398. GOOGLE_APPLICATION_CREDENTIALS=/doccano/{SET_CREDENTIAL_PATH}
  399. </code></pre>
  400. <h2 id="run-doccano-with-the-env-file">Run doccano with the .env file</h2>
  401. <h3 id="pip">Pip</h3>
  402. <p>When you execute the <code>webserver</code> and <code>task</code> command, specify <code>--env_file</code> option:</p>
  403. <pre><code class="language-bash">doccano webserver --env_file=.env
  404. doccano task --env_file=.env
  405. </code></pre>
  406. <h3 id="docker">Docker</h3>
  407. <p>When you execute the <code>docker container create</code> command, specify <code>--eng-file</code> option:</p>
  408. <pre><code class="language-bash"># Create a container
  409. docker container create --name doccano \
  410. -e &quot;ADMIN_USERNAME=admin&quot; \
  411. -e &quot;ADMIN_EMAIL=admin@example.com&quot; \
  412. -e &quot;ADMIN_PASSWORD=password&quot; \
  413. -v doccano-db:/data \
  414. --env-file .env \
  415. -p 8000:8000 doccano/doccano
  416. # Notice that you must copy the credential in the case of Google Cloud Storage
  417. docker cp {CREDENTIAL_PATH} doccano:/doccano/
  418. # Start the container
  419. docker container start doccano
  420. </code></pre>
  421. <h2 id="references">References</h2>
  422. <ul>
  423. <li><a href="https://docs.aws.amazon.com/general/latest/gr/aws-sec-cred-types.html">Understanding and getting your AWS credentials</a></li>
  424. <li><a href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/create-bucket-overview.html">Amazon S3/Creating a bucket</a></li>
  425. <li><a href="https://cloud.google.com/docs/authentication/getting-started">Google Cloud/Getting started with authentication</a></li>
  426. </ul>
  427. </article>
  428. </div>
  429. </div>
  430. </main>
  431. <footer class="md-footer">
  432. <div class="md-footer-nav">
  433. <nav class="md-footer-nav__inner md-grid" aria-label="Footer">
  434. <a href="../tutorial/" class="md-footer-nav__link md-footer-nav__link--prev" rel="prev">
  435. <div class="md-footer-nav__button md-icon">
  436. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg>
  437. </div>
  438. <div class="md-footer-nav__title">
  439. <div class="md-ellipsis">
  440. <span class="md-footer-nav__direction">
  441. Previous
  442. </span>
  443. Tutorial
  444. </div>
  445. </div>
  446. </a>
  447. <a href="../advanced/aws_https_settings/" class="md-footer-nav__link md-footer-nav__link--next" rel="next">
  448. <div class="md-footer-nav__title">
  449. <div class="md-ellipsis">
  450. <span class="md-footer-nav__direction">
  451. Next
  452. </span>
  453. AWS HTTPS settings
  454. </div>
  455. </div>
  456. <div class="md-footer-nav__button md-icon">
  457. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11v2h12l-5.5 5.5 1.42 1.42L19.84 12l-7.92-7.92L10.5 5.5 16 11H4z"/></svg>
  458. </div>
  459. </a>
  460. </nav>
  461. </div>
  462. <div class="md-footer-meta md-typeset">
  463. <div class="md-footer-meta__inner md-grid">
  464. <div class="md-footer-copyright">
  465. <div class="md-footer-copyright__highlight">
  466. Copyright &copy; 2018 - 2019 Hiroki Nakayama
  467. </div>
  468. Made with
  469. <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
  470. Material for MkDocs
  471. </a>
  472. </div>
  473. <div class="md-footer-social">
  474. <a href="https://github.com/Hironsan" target="_blank" rel="noopener" title="github.com" class="md-footer-social__link">
  475. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 496 512"><path d="M165.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6zm-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3zm44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9zM244.8 8C106.1 8 0 113.3 0 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C428.2 457.8 496 362.9 496 252 496 113.3 383.5 8 244.8 8zM97.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1zm-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7zm32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1zm-11.4-14.7c-1.6 1-1.6 3.6 0 5.9 1.6 2.3 4.3 3.3 5.6 2.3 1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2z"/></svg>
  476. </a>
  477. <a href="https://twitter.com/Hironsan13" target="_blank" rel="noopener" title="twitter.com" class="md-footer-social__link">
  478. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path d="M459.37 151.716c.325 4.548.325 9.097.325 13.645 0 138.72-105.583 298.558-298.558 298.558-59.452 0-114.68-17.219-161.137-47.106 8.447.974 16.568 1.299 25.34 1.299 49.055 0 94.213-16.568 130.274-44.832-46.132-.975-84.792-31.188-98.112-72.772 6.498.974 12.995 1.624 19.818 1.624 9.421 0 18.843-1.3 27.614-3.573-48.081-9.747-84.143-51.98-84.143-102.985v-1.299c13.969 7.797 30.214 12.67 47.431 13.319-28.264-18.843-46.781-51.005-46.781-87.391 0-19.492 5.197-37.36 14.294-52.954 51.655 63.675 129.3 105.258 216.365 109.807-1.624-7.797-2.599-15.918-2.599-24.04 0-57.828 46.782-104.934 104.934-104.934 30.213 0 57.502 12.67 76.67 33.137 23.715-4.548 46.456-13.32 66.599-25.34-7.798 24.366-24.366 44.833-46.132 57.827 21.117-2.273 41.584-8.122 60.426-16.243-14.292 20.791-32.161 39.308-52.628 54.253z"/></svg>
  479. </a>
  480. </div>
  481. </div>
  482. </div>
  483. </footer>
  484. </div>
  485. <script src="../assets/javascripts/vendor.6a3d08fc.min.js"></script>
  486. <script src="../assets/javascripts/bundle.71201edf.min.js"></script><script id="__lang" type="application/json">{"clipboard.copy": "Copy to clipboard", "clipboard.copied": "Copied to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.placeholder": "Search", "search.result.placeholder": "Type to start searching", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.term.missing": "Missing"}</script>
  487. <script>
  488. app = initialize({
  489. base: "..",
  490. features: [],
  491. search: Object.assign({
  492. worker: "../assets/javascripts/worker/search.4ac00218.min.js"
  493. }, typeof search !== "undefined" && search)
  494. })
  495. </script>
  496. </body>
  497. </html>