[user_id, session_id, ...]. Есть хранимка которая просто делает return box.space.sessions:get(user_id).
Для декодирования тапла сессии на стороне go есть декодер (сделан по примеру ридми в коннекторе):
func (i *SessionStore) DecodeMsgpack(d *msgpack.Decoder) error {
l, err := d.DecodeArrayLen()
if err != nil {
return err
}
if l != 5 {
return fmt.Errorf("array len doesn't match: %d", l)
}
...
Проблема в том, что когда тарантул не находит сессии и возвращает nil, я получаю из декодера ошибку типа "array len doesn't match: -1". A хотелось бы "session not found" например.
Я могу это прямо в DecodeMsgpack() добавить, но может правильнее как-то по другому эту ситуацию обрабатывать?
а) если хранимка просто делает get, то почему ты просто не делаешь conn.Select ? b) ты распаковываешь в var ss SessionStore; conn.Call17(..,.. &ss) ? А что если var ss *SessionStore? Тогда, по идее, ss останется nil.
Там на самом деле между драйвером и кодом сессий ещё самописный враппер, плюс всё писалось разными людьми, поэтому так получилось. Но в целом понятно, надо просто правильно оформить вызов, спасибо.
Обсуждают сегодня