bin/update
author Tero Marttila <terom@paivola.fi>
Tue, 20 Mar 2012 13:38:12 +0200
changeset 567 8f49e2f51c0d
parent 566 b2ac0fd85828
child 568 3d6bf3864d8a
permissions -rwxr-xr-x
update: cleanup, docs
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     1
#!/bin/bash
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     2
# vim: set ft=sh :
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     3
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     4
set -ue
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     5
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
     6
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
     7
### Paths
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     8
ROOT=$(pwd)
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     9
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
    10
# resolve $0
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
    11
self=$0
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
    12
while [ -L $self ]; do
554
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
    13
    tgt=$(readlink $self)
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
    14
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
    15
    if [ "${tgt:0:1}" == "/" ]; then
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
    16
        self=$tgt
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
    17
    else
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
    18
        self=$(dirname $self)/$tgt
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
    19
    fi
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
    20
done
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
    21
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
    22
# Our bin dir, with scripts
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
    23
BIN=$(dirname $self)
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    24
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
    25
# Data files
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    26
DATA=settings
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    27
ZONES=zones
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    28
SERIALS=$DATA
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
    29
REPO=
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    30
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
    31
# Script/data args
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    32
PROCESS_ARGS='--input-charset latin-1'
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    33
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
    34
# external progs
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
    35
NAMED_CHECKZONE=/usr/sbin/named-checkzone
554
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
    36
HG=/usr/bin/hg
550
773c91a7547a update: deploy_zones
Tero Marttila <terom@paivola.fi>
parents: 549
diff changeset
    37
RNDC=/usr/sbin/rndc
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
    38
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
    39
### Command-line argument handling
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
    40
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    41
IS_TTY=
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    42
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
    43
## Options
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
    44
LOG_ERROR=y
554
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
    45
LOG_WARN=y
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    46
LOG=y
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
    47
LOG_FORCE=y
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
    48
LOG_UPDATE=y
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
    49
LOG_NOOP=y
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
    50
LOG_SKIP=
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    51
LOG_DEBUG=
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    52
LOG_CMD=
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    53
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    54
UPDATE_FORCE=
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    55
UPDATE_NOOP=
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    56
UPDATE_DIFF=
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
    57
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
    58
SERIAL_NOOP=
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
    59
SERIAL_FORCE=
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
    60
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    61
COMMIT_SKIP=
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    62
COMMIT_FORCE=
545
5d2a8510a28f update: fix COMMIT_MSG bug
Tero Marttila <terom@paivola.fi>
parents: 544
diff changeset
    63
COMMIT_MSG=' '
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    64
550
773c91a7547a update: deploy_zones
Tero Marttila <terom@paivola.fi>
parents: 549
diff changeset
    65
DEPLOY_SKIP=
773c91a7547a update: deploy_zones
Tero Marttila <terom@paivola.fi>
parents: 549
diff changeset
    66
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
    67
## Output command-line argument help.
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    68
function help_args {
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    69
    local prog=$1
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    70
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    71
    cat <<END
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    72
Usage: $prog [options]
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    73
538
e517ad3376f7 update: fixup help
Tero Marttila <terom@paivola.fi>
parents: 537
diff changeset
    74
General:
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    75
    -h      display this help text
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
    76
    -d DIR  datadir
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    77
538
e517ad3376f7 update: fixup help
Tero Marttila <terom@paivola.fi>
parents: 537
diff changeset
    78
Logging:    
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    79
    -q      quiet
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    80
    -v      verbose
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    81
    -D      debug
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    82
    -V      debug commands
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
    83
    
538
e517ad3376f7 update: fixup help
Tero Marttila <terom@paivola.fi>
parents: 537
diff changeset
    84
Updates:
532
beb4bef2498a update: bugfix, -C
Tero Marttila <terom@paivola.fi>
parents: 531
diff changeset
    85
    -p      show changes
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    86
    -F      force-updates without checking src mtime
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    87
    -S      do not update serial
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
    88
    -s      update serials
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    89
    -n      no-op/mock-update; don't actually change anything; implies -SpC
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    90
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    91
Commit    
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    92
    -C      do not commit changes
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
    93
    -c      commit changes
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
    94
    -m MSG  commit message
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    95
END
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    96
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    97
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
    98
## Parse any command-line arguments, setting the global options vars.
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
    99
function parse_args {
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   100
    OPTIND=1
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   101
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   102
    while getopts 'hd:qvDVpFSsnCcm:' opt "$@"; do
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   103
        case $opt in
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   104
            h)  
538
e517ad3376f7 update: fixup help
Tero Marttila <terom@paivola.fi>
parents: 537
diff changeset
   105
                help_args $0
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   106
                exit 0
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   107
            ;;
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   108
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   109
            d)  ROOT="$OPTARG" ;;
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   110
554
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   111
            q)  
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   112
                LOG= 
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   113
                LOG_WARN=
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   114
                LOG_UPDATE=
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   115
                LOG_FORCE=
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   116
                LOG_NOOP=
554
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   117
                ;;
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   118
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   119
            v)  LOG_SKIP=y ;;
539
6516dc848a47 update: tweak functions
Tero Marttila <terom@paivola.fi>
parents: 538
diff changeset
   120
            D)  
6516dc848a47 update: tweak functions
Tero Marttila <terom@paivola.fi>
parents: 538
diff changeset
   121
                LOG_DEBUG=y
6516dc848a47 update: tweak functions
Tero Marttila <terom@paivola.fi>
parents: 538
diff changeset
   122
                LOG_INFO=y
6516dc848a47 update: tweak functions
Tero Marttila <terom@paivola.fi>
parents: 538
diff changeset
   123
                ;;
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   124
            V)  LOG_CMD=y ;;
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   125
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   126
            p)  UPDATE_DIFF=y   ;;
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   127
            F)  UPDATE_FORCE=y  ;;
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   128
            S)  SERIAL_NOOP=y   ;;
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   129
            s)  SERIAL_FORCE=y  ;;
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   130
 
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   131
            n)  
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   132
                UPDATE_NOOP=y 
532
beb4bef2498a update: bugfix, -C
Tero Marttila <terom@paivola.fi>
parents: 531
diff changeset
   133
                # implies -Sp
beb4bef2498a update: bugfix, -C
Tero Marttila <terom@paivola.fi>
parents: 531
diff changeset
   134
                UPDATE_DIFF=y
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   135
                SERIAL_NOUPDATE=y
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   136
                COMMIT_SKIP=y
550
773c91a7547a update: deploy_zones
Tero Marttila <terom@paivola.fi>
parents: 549
diff changeset
   137
                DEPLOY_SKIP=y
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   138
                ;;
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   139
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   140
            C)  COMMIT_SKIP=y ;;
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   141
            c)  COMMIT_FORCE=y ;;
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   142
            m)  COMMIT_MSG="$OPTARG" ;;
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   143
           
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   144
            ?)  
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   145
                die 
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   146
            ;;
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   147
        esac
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   148
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   149
    done
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   150
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   151
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   152
### Logging
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   153
# Output message to stderr.
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   154
function log_msg {
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   155
    echo "$*" >&2
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   156
}
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   157
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   158
# Output message to stderr, optionally with given color, if TTY.
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   159
function log_color {
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   160
    local code=$1; shift
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   161
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   162
    if [ $IS_TTY ]; then
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   163
        echo $'\e['${code}'m'"$*"$'\e[00m' >&2
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   164
    else
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   165
        echo "$*" >&2
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   166
    fi
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   167
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   168
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   169
## Log at various log-levels
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   170
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   171
function log_error {
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   172
    [ $LOG_ERROR ] && log_color '31' "$*"
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   173
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   174
554
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   175
function log_warn {
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   176
    [ $LOG_WARN ] && log_color '33' "$*" || true
554
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   177
}
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   178
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   179
# plain
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   180
function log {
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   181
    [ $LOG ] && log_msg "$*" || true
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   182
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   183
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   184
function log_force {
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   185
    [ $LOG_FORCE ] && log_color '2;33' "  $*" || true
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   186
}
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   187
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   188
function log_update {
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   189
    [ $LOG_UPDATE ] && log_color '36' "  $*" || true
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   190
}
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   191
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   192
function log_noop {
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   193
    [ $LOG_NOOP ] && log_color '2;34' "  $*" || true
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   194
}
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   195
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   196
function log_skip {
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   197
    [ $LOG_SKIP ] && log_color '1;34' "  $*" || true
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   198
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   199
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   200
function log_debug {
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   201
    [ $LOG_DEBUG ] && log_color 32 "    $*" || true
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   202
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   203
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   204
function log_cmd {
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   205
    [ $LOG_CMD ] && log_color 35 "        \$ $*" || true
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   206
}
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   207
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   208
# Output stacktrace, broken.
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   209
function log_stack {
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   210
    local level=1
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   211
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   212
    while info=$(caller $level); do
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   213
        echo $info | read line sub file
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   214
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   215
        log_msg "$file:$lineno $sub()"
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   216
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   217
        level=$(($level + 1))
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   218
    done
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   219
}
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   220
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   221
# Output calling function's name.
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   222
function func_caller {
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   223
    caller 1 | cut -d ' ' -f 2
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   224
}
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   225
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   226
### High-level logging output
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   227
# Log with func_caller at log_debug
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   228
function debug {
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   229
    printf -v prefix "%s" $(func_caller)
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   230
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   231
    log_debug "$prefix: $*"
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   232
}
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   233
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   234
# Log with func_caller at log_error and exit, intended for internal errors...
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   235
function fail {
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   236
    log_error "$(func_caller): $*"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   237
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   238
    exit 2
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   239
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   240
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   241
# Log at log_error and exit
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   242
function die {
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   243
    log_error "$*"
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   244
    exit 1
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   245
}
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   246
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   247
### Command execution
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   248
## Execute command, possibly logging its execution.
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   249
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   250
#   cmd     $cmd...
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   251
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   252
# Fails if the command returns an error exit code.
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   253
function cmd {
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   254
    log_cmd "$@"
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   255
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   256
    "$@" || die "Failed"
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   257
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   258
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   259
function indent () {
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   260
    local indent=$1; shift
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   261
541
826103fe3c8c update: abspath; fixup serials log; indent log_cmd
Tero Marttila <terom@paivola.fi>
parents: 540
diff changeset
   262
    log_cmd "$@"
826103fe3c8c update: abspath; fixup serials log; indent log_cmd
Tero Marttila <terom@paivola.fi>
parents: 540
diff changeset
   263
549
d2fdfe98b7b9 update: fix indent leading whitespace; implement update_hosts_meta, but not used - commit workflow becomes a little weird
Tero Marttila <terom@paivola.fi>
parents: 545
diff changeset
   264
    "$@" | sed "s/^/$indent/"
554
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   265
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   266
    return ${PIPESTATUS[0]}
541
826103fe3c8c update: abspath; fixup serials log; indent log_cmd
Tero Marttila <terom@paivola.fi>
parents: 540
diff changeset
   267
}
826103fe3c8c update: abspath; fixup serials log; indent log_cmd
Tero Marttila <terom@paivola.fi>
parents: 540
diff changeset
   268
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   269
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   270
### FS utils
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   271
# Create dir in $ROOT if not exists.
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   272
function ensure_dir {
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   273
    local dir=$1
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   274
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   275
    if [ ! -d $ROOT/$dir ]; then
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   276
        log_warn "Creating output dir: $dir"
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   277
        cmd mkdir $ROOT/$dir
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   278
    fi
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   279
}
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   280
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   281
## Output absolute path from $ROOT:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   282
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   283
#   abspath $path
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   284
#
541
826103fe3c8c update: abspath; fixup serials log; indent log_cmd
Tero Marttila <terom@paivola.fi>
parents: 540
diff changeset
   285
function abspath () {
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   286
    local path=$1
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   287
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   288
    echo "$ROOT/$path"
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   289
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   290
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   291
### HG wrappers
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   292
# Run `hg ...` within $REPO.
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   293
function hg {
562
57551a87a93e update: hardcode $REPO in hg
Tero Marttila <terom@paivola.fi>
parents: 561
diff changeset
   294
    local repo=$REPO; shift
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   295
554
2b7aad3466c6 update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents: 553
diff changeset
   296
    cmd $HG -R $ROOT/$repo "$@"
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   297
}
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   298
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   299
# Does the repo have local modifications?
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   300
function hg_modified {
562
57551a87a93e update: hardcode $REPO in hg
Tero Marttila <terom@paivola.fi>
parents: 561
diff changeset
   301
    hg id | grep -q '+'
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   302
}
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   303
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   304
# Output possible -u flag for commit.
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   305
function hg_user {
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   306
    if [ ${SUDO_USER:-} ]; then
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   307
        echo '-u' "$SUDO_USER"
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   308
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   309
    elif [ $HOME ] && [ -e $HOME/.hgrc ]; then
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   310
        debug "using .hgrc user"
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   311
        echo ''
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   312
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   313
    else
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   314
        echo '-u' "$USER"
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   315
    fi
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   316
}
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   317
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   318
# Show changes in repo
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   319
function hg_diff {
562
57551a87a93e update: hardcode $REPO in hg
Tero Marttila <terom@paivola.fi>
parents: 561
diff changeset
   320
    hg diff
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   321
}
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   322
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   323
## Commit changes in repo, with given message:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   324
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   325
#   hg_commit   $msg
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   326
#
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   327
function hg_commit {
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   328
    local msg=$1
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   329
    local user_opt=$(hg_user)
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   330
    
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   331
    debug "$user_opt: $msg"
562
57551a87a93e update: hardcode $REPO in hg
Tero Marttila <terom@paivola.fi>
parents: 561
diff changeset
   332
    hg commit $user_opt -m "$msg"
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   333
}
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   334
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   335
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   336
### Dependency-based updates
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   337
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   338
## Compare the given output file with all given source files:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   339
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   340
#   check_update $out ${deps[@]} && do_update $out ... || ...
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   341
#
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   342
# Returns true if the output file needs to be updated.
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   343
function check_update {
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   344
    # target
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   345
    local out=$1; shift
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   346
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   347
    debug "$out"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   348
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   349
    # need update?
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   350
    local update=
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   351
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   352
    if [ ${#@} == 0 ]; then
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   353
        debug "  update: unknown deps"
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   354
        update=y
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   355
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   356
    elif [ ! -e $out ]; then
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   357
        debug "  update: dest missing"
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   358
        update=y
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   359
        
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   360
    elif [ $UPDATE_FORCE ]; then
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   361
        debug "  update: forced"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   362
        update=y
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   363
    fi
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   364
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   365
    # check deps
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   366
    for dep in "$@"; do
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   367
        # don't bother checking if already figured out
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   368
        [ $update ] && continue
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   369
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   370
        # check
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   371
        if [ ! -e $ROOT/$dep ]; then
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   372
            fail "$dst: Missing source: $dep"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   373
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   374
        elif [ $ROOT/$out -ot $ROOT/$dep ]; then
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   375
            debug "  update: $dep"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   376
            update=y
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   377
        else
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   378
            debug "  check: $dep"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   379
        fi
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   380
    done
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   381
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   382
    [ ! $update ] && debug "  up-to-date"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   383
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   384
    # return
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   385
    [ $update ]
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   386
}
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   387
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   388
## Generate updated output file from given command's stdout:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   389
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   390
#   do_update $out $BIN/cmd --args
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   391
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   392
# Writes output to a temporary .new file, optionally shows a diff of changes, and commits
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   393
# the new version to $out (unless noop'd).
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   394
function do_update {
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   395
    local out=$1; shift
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   396
    local tmp=$out.new
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   397
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   398
    debug "$out"
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   399
    cmd "$@" > $ROOT/$tmp
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   400
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   401
    # compare
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   402
    if [ -e $ROOT/$out ] && [ $UPDATE_DIFF ]; then
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   403
        debug "  changes:"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   404
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   405
        # terse
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   406
        indent "        " diff --unified=1 $ROOT/$out $ROOT/$tmp || true
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   407
    fi
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   408
    
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   409
    # deploy
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   410
    if [ $UPDATE_NOOP ]; then
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   411
        # cleanup
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   412
        debug "  no-op"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   413
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   414
        cmd rm $ROOT/$tmp
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   415
    else
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   416
        # commit
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   417
        debug "  deploy"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   418
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   419
        cmd mv $ROOT/$tmp $ROOT/$out
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   420
    fi
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   421
}
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   422
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   423
## Look for a link target:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   424
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   425
#   find_link   $lnk    $tgt...
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   426
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   427
# Outputs the first given target to exist, skipping any that are the same as the given $lnk.
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   428
# If no $tgt matches, outputs the last one, or '-'.
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   429
function choose_link {
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   430
    local lnk=$1; shift
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   431
    local tgt=-
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   432
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   433
    for tgt in "$@"; do
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   434
        [ $tgt != $out ] && [ -e $ROOT/$tgt ] && break
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   435
    done
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   436
    
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   437
    echo $tgt
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   438
}
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   439
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   440
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   441
## Compare symlink to target:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   442
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   443
#   check_link $lnk $tgt && do_link $lnk $tgt || ...
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   444
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   445
# Tests if the symlink exists, and the target matches.
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   446
# Fails if the target does not exist.
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   447
function check_link {
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   448
    local lnk=$1
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   449
    local tgt=$2
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   450
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   451
    [ ! -e $ROOT/$tgt ] && fail "$tgt: target does not exist"
537
b883ef452cd8 fix handling of initial serial
Tero Marttila <terom@paivola.fi>
parents: 536
diff changeset
   452
    
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   453
    [ ! -e $ROOT/$lnk ] || [ $(readlink $ROOT/$lnk) != $ROOT/$tgt ]
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   454
}
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   455
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   456
## Update symlink to point to target:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   457
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   458
#   do_link $lnk $tgt
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   459
#
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   460
function do_link {
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   461
    local lnk=$1
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   462
    local tgt=$2
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   463
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   464
    cmd ln -sf $ROOT/$tgt $ROOT/$lnk
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   465
}
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   466
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   467
## Update .serial number:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   468
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   469
#   do_update_serial $serial
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   470
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   471
# Shows old/new serial on debug.
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   472
function do_update_serial {
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   473
    local serial=$1
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   474
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   475
    # read
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   476
    local old=$(test -e $ROOT/$serial && cat $ROOT/$serial || echo '')
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   477
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   478
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   479
    cmd $BIN/update-serial $ROOT/$serial
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   480
    
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   481
    # read
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   482
    local new=$(cat $ROOT/$serial)
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   483
        
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   484
    debug "  $old -> $new"
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   485
}
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   486
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   487
## Perform `hg commit` for $DATA
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   488
function do_commit {
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   489
    local msg=$1
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   490
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   491
    indent "    " hg_diff
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   492
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   493
    hg_commit "$msg"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   494
}
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   495
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   496
### Hosts
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   497
## Update hosts from verbatim from input zone data:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   498
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   499
#   copy_hosts      $ZONES/$zone    $DATA/$base
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   500
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   501
# Writes updated zone to $zone, deps on $base.
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   502
function copy_hosts {
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   503
    local zone=$1
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   504
    local base=$2
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   505
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   506
    if check_update $zone $base; then
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   507
        log_update "Copying hosts $zone <- $base..."
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   508
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   509
        do_update $zone \
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   510
            cat $ROOT/$base
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   511
    else
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   512
        log_skip "Copying hosts $zone <- $base: not changed"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   513
    fi
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   514
}
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   515
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   516
## Generate hosts from input zone data using $BIN/process-zone:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   517
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   518
#   update_hosts    $ZONES/$zone    $DATA/$base
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   519
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   520
# Writes process-zone'd data to $zone, deps on $base.
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   521
function update_hosts {
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   522
    local zone=$1; shift
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   523
    local base=$1; shift
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   524
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   525
    if check_update $zone $base; then
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   526
        log_update "Generating hosts $zone <- $base..."
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   527
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   528
        do_update $zone \
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   529
            $BIN/process-zone $PROCESS_ARGS $ROOT/$base "$@"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   530
    else
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   531
        log_skip "Generating hosts $zone <- $base: not changed"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   532
    fi
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   533
}
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   534
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   535
## Generate new serial for zone using $BIN/update-serial, if the zone data has changed:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   536
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   537
#   update_serial   $zone   $deps...
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   538
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   539
# Supports SERIAL_FORCE/NOOP.
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   540
# Updates $SERIALS/$zone.serial.
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   541
function update_serial {
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   542
    local zone=$1; shift
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   543
    
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   544
    local serial=$SERIALS/$zone.serial
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   545
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   546
    # test
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   547
    if [ $SERIAL_FORCE ]; then
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   548
        log_force "Updating $serial: forced"
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   549
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   550
        do_update_serial $serial
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   551
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   552
    elif ! check_update $serial "$@"; then
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   553
        log_skip "Updating $serial: not changed"
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   554
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   555
    elif [ $SERIAL_NOOP ]; then
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   556
        log_noop "Updating $serial: skipped"
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   557
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   558
    else
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   559
        log_update "Updating $serial..."
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   560
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   561
        do_update_serial $serial
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   562
    fi
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   563
}
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   564
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   565
## Link serial for zone from given base-zone:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   566
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   567
#   link_serial $zone $base
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   568
function link_serial {
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   569
    local zone=$1
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   570
    local base=$2
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   571
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   572
    local lnk=$SERIALS/$zone.serial
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   573
    local tgt=$SERIALS/$base.serial
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   574
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   575
    if check_link $lnk $tgt; then
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   576
        log_update "Linking $lnk -> $tgt..."
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   577
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   578
        do_link $lnk $tgt
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   579
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   580
    else
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   581
        log_skip "Linking $lnk -> $tgt: not changed"
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   582
    fi
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   583
}
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   584
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   585
## Update zone file verbatim from source:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   586
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   587
#   copy_zone   $view   $zone   [$base]
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   588
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   589
# Copies changed $DATA/$base zone data to $ZONES/$view/$zone.
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   590
function copy_zone {
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   591
    local view=$1
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   592
    local zone=$2
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   593
    local base=${3:-$zone}
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   594
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   595
    local out=$ZONES/$view/$zone
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   596
    local src=$DATA/$base
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   597
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   598
    if check_update $out $src; then
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   599
        log_update "Copying $out <- $src..."
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   600
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   601
        do_update $out \
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   602
            cat $ROOT/$src
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   603
    else
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   604
        log_skip "Copying $out <- $src: not changed"
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   605
    fi
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   606
}
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   607
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   608
## Expand zone file from source using $BIN/expand-zone:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   609
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   610
#   update_zone $view   $zone   [$base]
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   611
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   612
# Processed $DATA/$base zone data through $BIN/expand-zone, writing output to $ZONES/$view/$zone.
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   613
function update_zone {
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   614
    local view=$1
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   615
    local zone=$2
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   616
    local base=${3:-$zone}
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   617
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   618
    local out=$ZONES/$view/$zone
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   619
    local src=$DATA/$base.zone
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   620
    local lnk=$ZONES/$base
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   621
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   622
    local serial=$SERIALS/$base.serial
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   623
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   624
    if check_update $out $src $serial; then
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   625
        log_update "Generating $out <- $src..." 
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   626
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   627
        do_update $out \
563
d99ebc15833d update: simplify $BIN
Tero Marttila <terom@paivola.fi>
parents: 562
diff changeset
   628
            $BIN/expand-zone $ROOT/$src \
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   629
                --serial $ROOT/$serial              \
541
826103fe3c8c update: abspath; fixup serials log; indent log_cmd
Tero Marttila <terom@paivola.fi>
parents: 540
diff changeset
   630
                --expand zones=$(abspath $ZONES)    \
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   631
                --expand view=$view
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   632
    else
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   633
        log_skip "Generating $out <- $src: not changed" 
531
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   634
    fi
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   635
}
dab145ee3f81 update: mad bash wizardry
Tero Marttila <terom@paivola.fi>
parents: 530
diff changeset
   636
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   637
## Link zone file to ues given shared zone.
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   638
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   639
#   link_zone   $view   $zone   [$base]
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   640
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   641
# Looks for shared zone at:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   642
#   $ZONES/$view/$base
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   643
#   $ZONES/common/$base
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   644
function link_zone {
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   645
    local view=$1
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   646
    local zone=$2
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   647
    local base=${3:-$zone}
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   648
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   649
    local out=$ZONES/$view/$zone
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   650
    local tgt=$(choose_link $out $ZONES/$view/$base $ZONES/common/$base)
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   651
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   652
    if check_link $out $tgt; then
566
b2ac0fd85828 update: log_force/update/noop/skip, implemented for update_serial
Tero Marttila <terom@paivola.fi>
parents: 565
diff changeset
   653
        log_update "Linking $out -> $tgt..."
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   654
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   655
        do_link $out $tgt
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   656
553
1a8bc67b1eb7 update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents: 552
diff changeset
   657
    else
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   658
        log_skip "Linking $out -> $tgt: not changed"
553
1a8bc67b1eb7 update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents: 552
diff changeset
   659
    fi
1a8bc67b1eb7 update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents: 552
diff changeset
   660
}
1a8bc67b1eb7 update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents: 552
diff changeset
   661
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   662
## Test hosts zone for validity:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   663
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   664
#   check_hosts     $DATA/$hosts    --check-exempt ...
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   665
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   666
# Fails if the check fails.
536
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   667
function check_hosts {
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   668
    local hosts=$1; shift 1
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   669
563
d99ebc15833d update: simplify $BIN
Tero Marttila <terom@paivola.fi>
parents: 562
diff changeset
   670
    local cmd=($BIN/process-zone $PROCESS_ARGS $ROOT/$hosts --check-hosts "$@")
536
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   671
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   672
    if "${cmd[@]}" -q; then
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   673
        log_skip "Check $hosts: OK"
536
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   674
    else
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   675
        log_error "  Check $hosts: Failed"
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   676
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   677
        indent "    " "${cmd[@]}"
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   678
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   679
        exit 1
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   680
    fi
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   681
}
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   682
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   683
## Test zone file for validity using named-checkzone:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   684
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   685
#   check_zone      $view       $zone       $origin
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   686
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   687
# Uses the zonefile at $ZONES/$view/$zone, loading it with given initial $ORIGIN.
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   688
# Fails if the check fails.
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   689
function check_zone {
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   690
    local view=$1
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   691
    local zone=$2
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   692
    local origin=$3
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   693
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   694
    local src=$ZONES/$view/$zone
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   695
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   696
    local cmd=($NAMED_CHECKZONE $origin $ROOT/$src)
536
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   697
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   698
    # test
536
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   699
    # XXX: checkzone is very specific about the order of arguments, -q must be first
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   700
    if $NAMED_CHECKZONE -q $origin $ROOT/$src; then
564
baae373b787e update: log_skip; simplify update_serial args; check_update tests for deps
Tero Marttila <terom@paivola.fi>
parents: 563
diff changeset
   701
        log_skip "Check $src ($origin): OK"
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   702
    else
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   703
        log_error "  Check $src ($origin): Failed:"
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   704
536
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   705
        indent "    " "${cmd[@]}"
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   706
        
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   707
        exit 1
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   708
    fi
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   709
}
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   710
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   711
## Load update zonefiles into bind:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   712
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   713
#   deploy_zones    
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   714
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   715
# Invokes `rndc reload`, showing its output.
550
773c91a7547a update: deploy_zones
Tero Marttila <terom@paivola.fi>
parents: 549
diff changeset
   716
function deploy_zones {
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   717
    if [ $DEPLOY_SKIP ]; then
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   718
        log_skip "Reload zones: skipped"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   719
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   720
    else
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   721
        log_update "Reload zones..."
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   722
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   723
        # run
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   724
        indent "        rndc: " \
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   725
            $RNDC reload
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   726
    fi
550
773c91a7547a update: deploy_zones
Tero Marttila <terom@paivola.fi>
parents: 549
diff changeset
   727
}
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   728
## Commit changes in $DATA to version control:
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   729
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   730
#   commit_data
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   731
#
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   732
# Invokes `hg commit` in the $REPO, first showing the diff.
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   733
function commit_data {
562
57551a87a93e update: hardcode $REPO in hg
Tero Marttila <terom@paivola.fi>
parents: 561
diff changeset
   734
    local repo=$REPO
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   735
    local commit_msg="$COMMIT_MSG"
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   736
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   737
    local msg="Commit changes in $repo..."
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   738
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   739
    # operate?
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   740
    if [ $COMMIT_FORCE ]; then
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   741
        log_force   "$msg..."
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   742
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   743
        do_commit "$commit_msg"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   744
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   745
    elif ! hg_modified; then
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   746
        log_skip    "$msg: no changes"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   747
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   748
    elif [ $COMMIT_SKIP ]; then
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   749
        log_noop    "$msg: skipped"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   750
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   751
    else
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   752
        log_update  "msg..."
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   753
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   754
        do_commit "$commit_msg"
544
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   755
    fi
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   756
}
81cd07bc5f76 update: commit
Tero Marttila <terom@paivola.fi>
parents: 542
diff changeset
   757
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   758
## Site settings, used as arguments to scripts
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   759
# MX record to generate in hosts --forward-zone
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   760
FORWARD_MX=mail
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   761
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   762
# IP network to generate reverse records for in --reverse-zone
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   763
REVERSE_ZONE=194.197.235
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   764
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   765
# Origin domain to generate reverse records for in --reverse-zone
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   766
REVERSE_DOMAIN=paivola.fi
551
647f6de0d0ac update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents: 550
diff changeset
   767
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   768
# Views used
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   769
VIEWS=(internal external)
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   770
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   771
# Base domain zone for domains
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   772
DOMAIN_BASE=paivola
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   773
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   774
# List of actual domains used; will be linked to $DOMAIN_BASE
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   775
DOMAINS=(paivola.fi paivola.net paivola.org paivola.info paivola.mobi xn--pivl-load8j.fi)
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   776
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   777
## Operate!
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   778
function run {
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   779
    ## Hosts
550
773c91a7547a update: deploy_zones
Tero Marttila <terom@paivola.fi>
parents: 549
diff changeset
   780
    # test
536
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   781
    log "Testing hosts..."
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   782
        #                   data                            args...
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   783
        check_hosts         $DATA/paivola.txt               --check-exempt ufc
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   784
550
773c91a7547a update: deploy_zones
Tero Marttila <terom@paivola.fi>
parents: 549
diff changeset
   785
    # update
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   786
    log "Generating host zones..."
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   787
        #                   hosts                           data                args...
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   788
        update_hosts        $ZONES/hosts/paivola:internal   $DATA/paivola.txt   --forward-zone --forward-txt --forward-mx $FORWARD_MX
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   789
        update_hosts        $ZONES/hosts/paivola:external   $DATA/paivola.txt   --forward-zone
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   790
        update_hosts        $ZONES/hosts/194.197.235        $DATA/paivola.txt   --reverse-zone $REVERSE_ZONE --reverse-domain $REVERSE_DOMAIN
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   791
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   792
        
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   793
        update_hosts        $ZONES/hosts/10                 $DATA/pvl.txt       --reverse-zone 10 --reverse-domain pvl -q
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   794
        update_hosts        $ZONES/hosts/192.168            $DATA/pvl.txt       --reverse-zone 192.168 --reverse-domain pvl -q
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   795
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   796
        # XXX: unsupported --forward-zone with pvl.txt
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   797
        # update_hosts    $ZONES/hosts/pvl                    $DATA/pvl.txt      --forward-zone
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   798
        copy_hosts          $ZONES/hosts/pvl                $DATA/pvl.txt
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   799
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   800
    ## Includes
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   801
    log "Copying zone includes..."
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   802
        #                   view            zone                    base
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   803
        copy_zone           includes        paivola:internal        paivola.zone.internal
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   804
        copy_zone           includes        paivola:external        paivola.zone.external
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   805
        copy_zone           includes        paivola.auto            paivola.zone.auto
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   806
        copy_zone           includes        paivola.services        paivola.zone.services
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   807
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   808
    ## Serials
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   809
    log "Updating serials..."
541
826103fe3c8c update: abspath; fixup serials log; indent log_cmd
Tero Marttila <terom@paivola.fi>
parents: 540
diff changeset
   810
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   811
        #                   zone            deps...
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   812
        update_serial       pvl             $ZONES/hosts/pvl        $DATA/pvl.zone
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   813
        update_serial       10              $ZONES/hosts/10         $DATA/10.zone
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   814
        update_serial       192.168         $ZONES/hosts/192.168    $DATA/192.168.zone
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   815
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   816
        update_serial       paivola         \
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   817
            $ZONES/hosts/paivola:*          \
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   818
            $DATA/paivola.zone              \
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   819
            $ZONES/includes/paivola:*       \
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   820
            $ZONES/includes/paivola.*
565
ef5bcc4145de debug with func_caller; update_serial deps
Tero Marttila <terom@paivola.fi>
parents: 564
diff changeset
   821
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   822
        update_serial       194.197.235     \
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   823
            $ZONES/hosts/194.197.235        \
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   824
            $DATA/194.197.235.zone          
536
7d02a07e0354 update: check_hosts
Tero Marttila <terom@paivola.fi>
parents: 533
diff changeset
   825
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   826
    ## Zones
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   827
    log "Updating zones..."
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   828
        #                   view        zone            base
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   829
        update_zone         internal    pvl
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   830
        update_zone         internal    paivola
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   831
        update_zone         external    paivola
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   832
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   833
        update_zone         internal    10
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   834
        update_zone         internal    192.168
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   835
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   836
        update_zone         common      194.197.235
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   837
        link_zone           internal    194.197.235
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   838
        link_zone           external    194.197.235
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   839
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   840
    ## Test
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   841
    log "Testing zones..."
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   842
        #                   view        zone            origin
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   843
        check_zone          internal    paivola         paivola.fi
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   844
        check_zone          external    paivola         paivola.fi
559
3208cd6540dc update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents: 555
diff changeset
   845
561
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   846
        check_zone          internal    10              10.in-addr.arpa
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   847
        check_zone          internal    192.168         192.168.in-addr.arpa
39799fc994e9 update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents: 560
diff changeset
   848
        check_zone          common      194.197.235     235.197.194.in-addr.arpa
533
26e789db3f72 update: named-checkzone
Tero Marttila <terom@paivola.fi>
parents: 532
diff changeset
   849
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   850
    ## Domains...
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   851
    log "Linking domains..."
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   852
        for view in "${VIEWS[@]}"; do
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   853
            for zone in "${DOMAINS[@]}"; do
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   854
                # link
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   855
                link_zone       $view       $zone           $DOMAIN_BASE
553
1a8bc67b1eb7 update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents: 552
diff changeset
   856
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   857
                # test
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   858
                check_zone      $view       $zone           $zone
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   859
            done
553
1a8bc67b1eb7 update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents: 552
diff changeset
   860
        done
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   861
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   862
    ## Deploy
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   863
    log "Deploy zones..."
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   864
        deploy_zones
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   865
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   866
    ## Commit
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   867
    log "Commit data..."
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   868
        commit_data
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   869
}
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   870
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   871
## Main entry point
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   872
function main {
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   873
    # test tty
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   874
    [ -t 1 ] && IS_TTY=y
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   875
    
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   876
    parse_args "$@"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   877
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   878
    ## test env
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   879
    [ -d $ROOT/$DATA ] || die "Missing data: $ROOT/$DATA"
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   880
    ensure_dir  $ZONES
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   881
    
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   882
    ## Output dirs
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   883
    for dir in "common" "hosts" "includes" "${VIEWS[@]}"; do
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   884
        ensure_dir $ZONES/$dir
553
1a8bc67b1eb7 update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents: 552
diff changeset
   885
    done
1a8bc67b1eb7 update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents: 552
diff changeset
   886
567
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   887
    ## Go
8f49e2f51c0d update: cleanup, docs
Tero Marttila <terom@paivola.fi>
parents: 566
diff changeset
   888
    run
525
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   889
}
aeb106b9487c update: update zonefiles
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   890
530
f4457348faa0 update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents: 525
diff changeset
   891
main "$@"