forked from sijms/go-ora
-
Notifications
You must be signed in to change notification settings - Fork 0
/
db_version.go
66 lines (62 loc) · 1.74 KB
/
db_version.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package go_ora
import (
"errors"
"fmt"
"github.com/sijms/go-ora/network"
)
type DBVersion struct {
Info string
Text string
Number uint16
MajorVersion int
MinorVersion int
PatchsetVersion int
isDb10gR20OrHigher bool
isDb11gR10OrHigher bool
}
func GetDBVersion(session *network.Session) (*DBVersion, error) {
session.ResetBuffer()
session.PutBytes(3, 0x3B, 0)
session.PutUint(1, 1, false, false)
session.PutUint(0x100, 2, true, true)
session.PutUint(1, 1, false, false)
session.PutUint(1, 1, false, false)
err := session.Write()
if err != nil {
return nil, err
}
msg, err := session.GetInt(1, false, false)
if msg != 8 {
return nil, errors.New(fmt.Sprintf("message code error: received code %d and expected code is 8", msg))
}
length, err := session.GetInt(2, true, true)
if err != nil {
return nil, err
}
info, err := session.GetBytes(int(length))
if err != nil {
return nil, err
}
number, err := session.GetInt(4, true, true)
if err != nil {
return nil, err
}
version := (number>>24&0xFF)*1000 + (number>>20&0xF)*100 + (number>>12&0xF)*10 + (number >> 8 & 0xF)
text := fmt.Sprintf("%d.%d.%d.%d.%d", number>>24&0xFF, number>>20&0xF,
number>>12&0xF, number>>8&0xF, number&0xFF)
ret := &DBVersion{
Info: string(info),
Text: text,
Number: uint16(version),
MajorVersion: int(number >> 24 & 0xFF),
MinorVersion: int(number >> 20 & 0xF),
PatchsetVersion: int(number >> 8 & 0xF),
}
if ret.MajorVersion > 10 || (ret.MajorVersion == 10 && ret.MinorVersion >= 2) {
ret.isDb10gR20OrHigher = true
}
if ret.MajorVersion > 11 || (ret.MajorVersion == 11 && ret.MinorVersion >= 1) {
ret.isDb11gR10OrHigher = true
}
return ret, nil
}