OpenWsp

Синтаксис

OpenWspResult OpenWsp(OdId tOb, OpenWspArg tArg)

Параметры

tOb. Моникёр объекта репозитория, являющегося рабочим пространством.

tArg. Параметры выполнения операции.

Описание

Операция OpenWsp открывает рабочее пространство.

Комментарии

Операция позволяет получить доступ к структуре рабочего пространства. Для выполнения операции укажите в поле tOb моникёр объекта, являющегося рабочим пространством, а в поле tArg параметры открытия. Моникёр объекта может быть получен при выполнении операции GetObjects.

В поле tArg могут быть указаны режим открытия рабочего пространства (просмотр или редактирование), значения параметров и шаблон для извлечения метаданных. В шаблоне указывается та информация, которая должна быть получена при выполнении операции. Результатом работы операции будет моникёр открытого экземпляра рабочего пространства, а также метаданные, если при выполнении операции в поле tArg.metaGet был задан соответствующий шаблон.

Дальнейшая работа с открытым экземпляром осуществляется с помощью операций GetWspMd и SetWspMd.

Для закрытия открытого экземпляра рабочего пространства используйте операцию CloseWsp.

Пример

Ниже приведён пример открытия на редактирование рабочего пространства. В запросе передаётся моникёр объекта, являющегося рабочим пространством репозитория. В ответе приходит моникёр открытого экземпляра рабочего пространства.

В примере C# используется функция FindObjectById, код которой приведен в примере «Получение описания объекта по его идентификатору».

SOAP-запрос:

<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Body xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<OpenWsp xmlns="http://www.fsight.ru/PP.SOM.Som">
<tOb xmlns="">
  <id>PBCNGJNIEPHMFOAEJKJCHHDECPOLMJDEOKLJGKMANEMFPNKO!M!282380</id>
  </tOb>
<tArg xmlns="">
<args>
  <bind>true</bind>
  <openForEdit>true</openForEdit>
  </args>
  </tArg>
  </OpenWsp>
  </s:Body>
  </s:Envelope>

SOAP-ответ:

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/">
<soapenv:Body>
<OpenWspResult xmlns="http://www.fsight.ru/PP.SOM.Som" xmlns:q1="http://www.fsight.ru/PP.SOM.Som" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<id xmlns="">
  <id>PBCNGJNIEPHMFOAEJKJCHHDECPOLMJDEOKLJGKMANEMFPNKO!M!S!WSPJPIHAMNIEPHMFOAELLBCEKBPPLOICPBEPIHOFPDINMHNPKOF</id>
  </id>
  </OpenWspResult>
  </soapenv:Body>
  </soapenv:Envelope>

JSON-запрос:

{
"OpenWsp" :
{
"tOb" :
{
"id" : "PBCNGJNIEPHMFOAEJKJCHHDECPOLMJDEOKLJGKMANEMFPNKO!M!282380"
},
"tArg" :
{
"args" :
{
"bind" : "true",
"openForEdit" : "true"
}
}
}
}

JSON-ответ:

{
"OpenWspResult" :
{
"id" :
{
"id" : "PBCNGJNIEPHMFOAEJKJCHHDECPOLMJDEOKLJGKMANEMFPNKO!M!S!WSPJPIHAMNIEPHMFOAELLBCEKBPPLOICPBEPIHOFPDINMHNPKOF"
}
}
}
public static OpenWspResult OpenWorkspace(MbId mb, string id)
{
var somClient = new SomPortTypeClient(); // Прокси-объект для выполнения операций
// Параметры выполнения операции
var tOpen = new OpenWsp()
{
tArg = new OpenWspArg()
{
args = new WspOpenArgs()
{
bind = true,
openForEdit = true
}
},
tOb = new OdId() { id = mb.id + "!" + FindObjectById(mb, id).k }
};
// Открытие рабочего пространства
var tResult = somClient.OpenWsp(tOpen);
return tResult;
}

См. также:

Работа с рабочим пространством