Ниже приведен пример использования операции OpenDim для открытия параметрического справочника репозитория. В запросе передается моникёр объекта, являющегося справочником, и значения параметров. Предполагается, что параметры в структуре справочника имеют идентификаторы «YEAR_START» и «YEAR_FINISH». В ответе приходит моникёр открытого справочника. Какие-либо дополнительные данные справочника не извлекаются.
В примере C# используется функция FindObjectById, код которой приведён в примере «Получение описания объекта по его идентификатору».
{
"OpenDim" :
{
"tObject" :
{
"id" : "S1!M!128"
},
"tArg" :
{
"openArgs" :
{
"args" :
{
"it" :
[
{
"k" : "18446744073709551615",
"id" : "YEAR_START",
"value" : "2000"
},
{
"k" : "18446744073709551615",
"id" : "YEAR_FINISH",
"value" : "2001"
}
]
}
}
}
}
}
{
"OpenDimResult" :
{
"id" :
{
"id" : "S1!M!S!S2"
}
}
}
public static OpenDimResult OpenParamDimension(MbId mb, string id)
{
var somClient = new SomPortTypeClient(); //Прокси-объект для выполнения операций
//Параметры выполнения операции
var tOpen = new OpenDim()
{
tArg = new OpenDimArg()
{
openArgs = new DmOpenArgs()
{
//Параметры для параметрического справочника
args = new OdArg[2]
{
new OdArg(){id = "YEAR_START", value = "2000", k = ulong.MaxValue},
new OdArg(){id = "YEAR_FINISH", value = "2001", k = ulong.MaxValue}
}
}
},
tObject = new OdId() { id = mb.id + "!" + FindObjectById(mb, id).k }
};
//Открытие параметрического справочника
var tResult = somClient.OpenDim(tOpen);
return tResult;
}
См. также: