1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
6 |
|
7 |
|
8 | 'use strict'
|
9 |
|
10 | const {
|
11 | logs, remove, run,
|
12 | start, stop, inspect
|
13 | } = require('adocker/commands')
|
14 | const co = require('co')
|
15 | const path = require('path')
|
16 | const { mkdirpAsync } = require('asfs')
|
17 |
|
18 | const handleError = (err) => {
|
19 | console.error(err)
|
20 | process.exit(1)
|
21 | }
|
22 |
|
23 |
|
24 | function adockerMysql (name, options = {}) {
|
25 | let {
|
26 | image = 'mysql:latest',
|
27 | rootPassword = 'root',
|
28 | varDir = 'var/mysql',
|
29 | publish = false,
|
30 | network = 'default',
|
31 | onError = handleError,
|
32 | cwd = process.cwd()
|
33 | } = options
|
34 |
|
35 | varDir = path.resolve(varDir)
|
36 | let host = network === 'default' ? '$MYSQL_PORT_3306_TCP_ADDR' : name
|
37 | let bundle = {
|
38 | |
39 |
|
40 |
|
41 |
|
42 | run: (...args) => mkdirpAsync(varDir)
|
43 | .then(() => run({
|
44 | name,
|
45 | network,
|
46 | publish,
|
47 | env: `MYSQL_ROOT_PASSWORD=${rootPassword}`,
|
48 | volume: `${varDir}:/var/lib/mysql`,
|
49 | detach: true
|
50 | }, image, ...args)),
|
51 | |
52 |
|
53 |
|
54 |
|
55 | isRunning: () => inspect(name).then(([ info ]) => !!info),
|
56 | |
57 |
|
58 |
|
59 |
|
60 | logs: logs.bind(null, name),
|
61 | |
62 |
|
63 |
|
64 |
|
65 | start: start.bind(null, name),
|
66 | |
67 |
|
68 |
|
69 |
|
70 | stop: stop.bind(null, name),
|
71 | |
72 |
|
73 |
|
74 |
|
75 |
|
76 |
|
77 | remove: remove.bind(null, name),
|
78 | |
79 |
|
80 |
|
81 |
|
82 | terminal: run.bind(null, {
|
83 | interactive: true,
|
84 | tty: true,
|
85 | network,
|
86 | link: `${name}:mysql`,
|
87 | rm: true
|
88 | }, image, 'sh', '-c', `exec mysql -h"${host}" -P"3306" -uroot -p"${rootPassword}"`)
|
89 | }
|
90 | return Object.assign(bundle, {
|
91 | cli () {
|
92 | return Object.assign({},
|
93 | ...Object.keys(bundle).map((name) => ({
|
94 | [name]: (...args) => {
|
95 | process.chdir(cwd)
|
96 | return bundle[ name ](...args).catch(onError)
|
97 | }
|
98 | }))
|
99 | )
|
100 | }
|
101 | })
|
102 | }
|
103 |
|
104 | module.exports = adockerMysql
|