-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
16 changed files
with
453 additions
and
1,008 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
package v8 | ||
|
||
import ( | ||
"github.com/v8platform/designer" | ||
"github.com/v8platform/runner" | ||
"reflect" | ||
"testing" | ||
) | ||
|
||
func TestCreateInfobase(t *testing.T) { | ||
|
||
if testing.Short() { | ||
t.Skip("skipped for integrated tests") | ||
} | ||
|
||
type args struct { | ||
create runner.Command | ||
opts []interface{} | ||
} | ||
temp := t.TempDir() | ||
|
||
tests := []struct { | ||
name string | ||
args args | ||
want *Infobase | ||
wantErr bool | ||
}{ | ||
{ | ||
"simple", | ||
args{ | ||
create: designer.CreateFileInfoBaseOptions{ | ||
File: temp, | ||
}, | ||
}, | ||
&Infobase{ | ||
Connect: FilePath{ | ||
File: temp, | ||
}, | ||
}, | ||
false, | ||
}, | ||
} | ||
|
||
for _, tt := range tests { | ||
t.Run(tt.name, func(t *testing.T) { | ||
got, err := CreateInfobase(tt.args.create, tt.args.opts...) | ||
if (err != nil) != tt.wantErr { | ||
t.Errorf("CreateInfobase() error = %v, wantErr %v", err, tt.wantErr) | ||
return | ||
} | ||
if !reflect.DeepEqual(got, tt.want) { | ||
t.Errorf("CreateInfobase() got = %v, want %v", got, tt.want) | ||
} | ||
}) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,232 @@ | ||
package v8 | ||
|
||
import ( | ||
"fmt" | ||
"github.com/v8platform/errors" | ||
"github.com/v8platform/marshaler" | ||
"strings" | ||
) | ||
|
||
var _ ConnectPath = (*FilePath)(nil) | ||
var _ ConnectPath = (*ServerPath)(nil) | ||
|
||
type ConnectPath interface { | ||
String() string | ||
} | ||
|
||
type FilePath struct { | ||
|
||
// имя каталога, в котором размещается файл информационной базы; | ||
File string `v8:"File, equal_sep, quotes" json:"file"` | ||
} | ||
|
||
func (f FilePath) String() string { | ||
v, _ := marshaler.Marshal(f) | ||
connString := strings.Join(v, ";") | ||
return connString + ";" | ||
} | ||
|
||
type WsPath struct { | ||
|
||
// имя каталога, в котором размещается файл информационной базы; | ||
Ws string `v8:"Ws, equal_sep" json:"ws"` | ||
} | ||
|
||
func (f WsPath) String() string { | ||
v, _ := marshaler.Marshal(f) | ||
connString := strings.Join(v, ";") | ||
return connString + ";" | ||
} | ||
|
||
type ServerPath struct { | ||
//имя сервера «1С:Предприятия» в формате: [<протокол>://]<адрес>[:<порт>], где: | ||
//<протокол> – не обязателен, поддерживается только протокол TCP, | ||
//<адрес> – имя сервера или IP-адрес сервера в форматах IPv4 или IPv6, | ||
//<порт> – не обязателен, порт главного менеджера кластера, по умолчанию равен 1541. | ||
Server string `v8:"Srvr, equal_sep" json:"srvr"` | ||
|
||
//имя информационной базы на сервере "1С:Предприятия"; | ||
Ref string `v8:"Ref, equal_sep, quotes" json:"ref"` | ||
} | ||
|
||
func (s ServerPath) String() string { | ||
v, _ := marshaler.Marshal(s) | ||
connString := strings.Join(v, ";") | ||
return connString + ";" | ||
} | ||
|
||
var _ ConnectionString = (*Infobase)(nil) | ||
|
||
type Infobase struct { | ||
Connect ConnectPath `v8:",inherit" json:"path"` | ||
|
||
// имя пользователя; | ||
User string `v8:"Usr, equal_sep, optional" json:"user"` | ||
|
||
// пароль; | ||
Password string `v8:"Pwd, equal_sep, optional" json:"password"` | ||
|
||
// разрешить получение клиентских лицензий через сервер "1С:Предприятия" ("Y"|"N"). | ||
// "Y" — получать клиентскую лицензию через сервер "1С:Предприятия". | ||
// Если клиентское приложение не получило программную лицензию | ||
// или аппаратную лицензию из локального ключа HASP или из сетевого ключа HASP, | ||
// то производится попытка получения клиентской лицензии через сервер 1С:Предприятия. | ||
// "N" — не получать клиентскую лицензию через сервер "1С:Предприятия". | ||
// | ||
// Значение по умолчанию — "N". / false | ||
AllowServerLicenses bool `v8:"LicDstr, equal_sep, optional, bool_true=Y" json:"lic_dstr"` | ||
|
||
// установка разделителей. | ||
// | ||
// ZN=<Общий реквизит 1>,<Общий реквизит 2>,...,<Общий реквизит N> | ||
// | ||
// <Общий реквизит> = [<+>|<->]<значение общего реквизита> | ||
// | ||
// [<+>|<->] - признак использования: "+" (по умолчанию) - реквизит используется; "-" - не используется; | ||
// Если разделитель не используется, то перед значением должен быть "-". | ||
// Если первым символом в значении разделителя содержится символ "+" или "-", то при указании его нужно удваивать. | ||
// <значение общего реквизита> - значение общего реквизита. Если в значении разделителя присутствует запятая, | ||
// то при указании ее нужно удваивать. | ||
// Если значение разделителя пропущено, но разделитель должен использоваться, то используется символ "+". | ||
// Разделители разделяются запятой. | ||
// Например: | ||
// "Zn=-ПервыйРазделитель,+,---ТретийРазделитель", что означает: | ||
// Первый разделитель выключен, значение – "ПервыйРазделитель", | ||
// Второй разделитель включен, значение – пустая строка, | ||
// Третий разделитель выключен, значение – "-ТретийРазделитель". | ||
SeparatorList DatabaseSeparatorList `v8:"ZN, equal_sep, optional" json:"zn"` | ||
|
||
// запуск в режиме привилегированного сеанса. | ||
// Разрешен аутентифицированному пользователю, имеющему административные права. | ||
// Журнал регистрации фиксирует установку или отказ в возможности установки режима привилегированного сеанса. | ||
// prmod=1 - привилегированный сеанс устанавливается. | ||
UsePrivilegedMode bool `v8:"Prmod, equal_sep, optional, bool_true=1" json:"prmod"` | ||
|
||
// язык (страна), который будет использован при открытии или создании информационной базы. | ||
// Допустимые значения такие же как у параметра <Форматная строка> метода Формат(). | ||
// Параметр Locale задавать не обязательно. | ||
// Если не задан, то будут использованы региональные установки текущей информационной базы; | ||
Locale string `v8:"Locale, optional, equal_sep" json:"locale"` | ||
} | ||
|
||
func (ib Infobase) ConnectionString() string { | ||
|
||
v, _ := marshaler.Marshal(ib) | ||
connString := strings.Join(v, ";") | ||
return fmt.Sprintf("/IBConnectionString %s%s", ib.Connect.String(), connString) | ||
} | ||
|
||
func NewFileInfobase(file string) *Infobase { | ||
|
||
ib := &Infobase{ | ||
Connect: FilePath{ | ||
File: file, | ||
}, | ||
} | ||
|
||
ib.Connect.String() | ||
|
||
return ib | ||
|
||
} | ||
|
||
func ParseConnectionString(connectingString string) (ib *Infobase, err error) { | ||
|
||
switch { | ||
|
||
case strings.HasPrefix(connectingString, "/S"): | ||
panic("implement me") | ||
return nil, err | ||
case strings.HasPrefix(connectingString, "/F"): | ||
panic("implement me") | ||
return nil, err | ||
case strings.HasPrefix(connectingString, "/IBConnectionString "): | ||
connectingString = strings.TrimPrefix(connectingString, "/IBConnectionString ") | ||
return parseIBConnectionString(connectingString) | ||
default: | ||
return parseIBConnectionString(connectingString) | ||
} | ||
|
||
} | ||
|
||
func parseIBConnectionString(connectingString string) (ib *Infobase, err error) { | ||
|
||
ib = &Infobase{} | ||
|
||
valuesMap, err := ConnectionStringtoMap(connectingString) | ||
if err != nil { | ||
return nil, err | ||
} | ||
|
||
switch { | ||
case len(valuesMap["srvr"]) > 0: | ||
server := valuesMap["srvr"] | ||
ref := valuesMap["ref"] | ||
|
||
if len(ref) == 0 { | ||
return nil, errors.BadConnectString.New("wrong infobase ref on server connection string") | ||
} | ||
|
||
ib.Connect = ServerPath{ | ||
Server: server, | ||
Ref: ref, | ||
} | ||
|
||
case len(valuesMap["file"]) > 0: | ||
|
||
ib.Connect = FilePath{ | ||
File: valuesMap["file"], | ||
} | ||
|
||
default: | ||
return nil, errors.BadConnectString.New("wrong server connection string") | ||
} | ||
|
||
for key, val := range valuesMap { | ||
switch key { | ||
|
||
case "usr": | ||
ib.User = val | ||
case "pwd": | ||
ib.Password = val | ||
case "locale": | ||
ib.Locale = val | ||
case "licdstr": | ||
ib.AllowServerLicenses = val == "Y" | ||
case "prmod": | ||
ib.UsePrivilegedMode = val == "1" | ||
case "zn": | ||
var err error | ||
ib.SeparatorList, err = ParseDatabaseSeparatorList(val) | ||
if err != nil { | ||
return nil, err | ||
} | ||
} | ||
} | ||
|
||
return | ||
} | ||
|
||
func ConnectionStringtoMap(connectingString string) (map[string]string, error) { | ||
valuesMap := make(map[string]string) | ||
|
||
values := strings.Split(connectingString, ";") | ||
|
||
for _, value := range values { | ||
|
||
if len(value) == 0 || | ||
strings.HasPrefix(value, "/") || | ||
strings.HasPrefix(value, "-") { | ||
continue | ||
} | ||
|
||
keyValue := strings.SplitN(value, "=", 2) | ||
|
||
if len(keyValue) != 2 { | ||
return nil, errors.BadConnectString.New("wrong key/value count") | ||
} | ||
|
||
valuesMap[strings.ToLower(keyValue[0])] = strings.Trim(keyValue[1], "'") | ||
} | ||
return valuesMap, nil | ||
} |
Oops, something went wrong.