Настроить пользователя для решения itgenexl029 по запросу SQL на Exact Online
Когда я запускаю следующий запрос с использованием Invantive Data Hub на Exact Online (Нидерланды):
create or replace table spn@inmemorystorage
as
select /*+ ods(false) */
spn.item_code_attr
, spn.warehouse_code_attr
, spn.item_description
, spn.currentquantity
, spn.planning_in
, spn.planning_out
, spn.currentquantity + spn.planning_in - spn.planning_out plannedquantity
from exactonlinexml..StockPositions spn
--
-- Filter out no stock nor planned.
--
where ( spn.currentquantity !=0
or
spn.planning_in != 0
or
spn.planning_out != 0
)
Я получаю следующую ошибку:
Error itgencun016: Uitroep itgenexl029: U heeft onvoldoende rechten om deze actie uit te voeren.
со стеком вызовов:
Error itgencun017: Type: Invantive.Data.ServiceException
at Invantive.Data.ValidationException..ctor(String messageCode, String messageText, String kindRequest, String localStackTrace, String nk, Exception innerException)
at Invantive.Data.InvantiveSystemException..ctor(String validationCode, String errorMessage, String kindRequest, String stackTrace, String nk, Exception innerException)
at Invantive.Data.ExactOnlineXmlProvider.FailOnAnswerWithErrors(XmlDocument document, String topic, String& responseErrorsOnly, String& responseXmlPayloadRetry, Exception& ex, Int32& countSuccess, Int32& countWarning, Int32& countError, Int32& countFatalError)
at Invantive.Data.ExactOnlineXmlProvider.GetDataFromWebService(String url, String cacheId, String partitionCode, String topic, XmlObjectDefinition objectDefinition, Int32 pageCounter, String previousTimeStampLastRecord, String callSafeNameOverrule, Int32& pageSize, Int32& count, String& timeStampLastRecord, Int64& documentSizeCharacters, Int64& documentSizeBytes)
at Invantive.Data.ExactOnlineXmlProvider.<GetRowsDataFromWebService>d__232.MoveNext()
at Invantive.Data.CompressedEnumerable`1.<GetEnumerator>d__2.MoveNext()
at Invantive.Data.CachedEnumerable`1.TryGetNext(Int32 index, T& item)
at Invantive.Data.CachedEnumerable`1.<GetEnumerator>d__6.MoveNext()
at System.Linq.Enumerable.<SelectManyIterator>d__16`2.MoveNext()
at Invantive.Sql.DataSourceOrFunctionTree.<GetDataFromDataContainer>d__50.MoveNext()
at Invantive.Data.CompressedEnumerable`1.<GetEnumerator>d__2.MoveNext()
at Invantive.Data.CachedEnumerable`1.TryGetNext(Int32 index, T& item)
at Invantive.Data.CachedEnumerable`1.<GetEnumerator>d__6.MoveNext()
at Invantive.Sql.FirehoseResultSet.<Iterator>d__57.MoveNext()
at Invantive.Data.CompressedEnumerable`1.<GetEnumerator>d__2.MoveNext()
at Invantive.Data.CachedEnumerable`1.TryGetNext(Int32 index, T& item)
at Invantive.Data.CachedEnumerable`1.<GetEnumerator>d__6.MoveNext()
at Invantive.Sql.FirehoseResultSet.<Iterator>d__57.MoveNext()
at Invantive.Sql.FilterIterator.<Iterator>d__3.MoveNext()
at Invantive.Sql.ChainedFirehose.<Iterator>d__11.MoveNext()
at Invantive.Sql.SelectListIterator.<Iterator>d__7.MoveNext()
at System.Linq.Enumerable.Count[TSource](IEnumerable`1 source)
at Invantive.Sql.DdlStatementTree.OnExecute(ParameterList parameters, ExpressionParser expressionParser)
at Invantive.Sql.QueryTree.Execute(ParameterList parameters, ExpressionParser expressionParser)
at Invantive.Sql.QueryPlan.ForcePlan()
at Invantive.Sql.QueryPlan.get_Fields()
at Invantive.Sql.QueryPlan.get_FieldCount()
at Invantive.Data.QueryPlanCacheEntry.<>c.<.ctor>b__12_0(IQueryPlan qp)
at System.Linq.Enumerable.WhereSelectArrayIterator`2.MoveNext()
at System.Linq.Buffer`1..ctor(IEnumerable`1 source)
at System.Linq.Enumerable.ToArray[TSource](IEnumerable`1 source)
at Invantive.Data.QueryPlanCacheEntry..ctor(String sqlStatement, IQueryPlan[] queryPlans, ParameterList parameters)
at Invantive.Sql.SqlEngine.ExecuteAndFetch(IProviderManager manager, String sqlStatement, ParameterList parameters, Boolean allowSelect)
at Invantive.Data.ConnectionManager.ExecuteProviderPassthroughSqlActionTable(String actionSql, ParameterList parameters, String& handlingPath)
at Invantive.Data.ConnectionManager.PassthroughSqlActionTable(String actionSql, ParameterList parameters)
at Invantive.Data.ActionProceduresBase.PassthroughSqlActionTable(String actionSql, ParameterList parameters)
at Invantive.Producer.QueryEngine.QueryEngine.ProcessStatement(String sqlStatement, ResultSet& resultSet, Action`1 fetchMoreRows, Action`7 executeStatement, Boolean isInInteractiveMode, ScriptingLanguageNextStepSpecification& nextStepSpecification)
at Invantive.Producer.QueryEngine.QueryEngine.ProcessStatements(Action`1 fetchMoreRows, Action`7 executeStatement, IEnumerable`1 statements, ScriptingLanguageNextStepSpecification& exitSpecification)
at Invantive.Producer.QueryEngine.QueryEngine.Run(String[] arguments)
at Invantive.Producer.QueryEngine.Program.Main(String[] arguments)
at Invantive.Data.ExactOnlineXmlProvider.GetDataFromWebService(String url, String cacheId, String partitionCode, String topic, XmlObjectDefinition objectDefinition, Int32 pageCounter, String previousTimeStampLastRecord, String callSafeNameOverrule, Int32& pageSize, Int32& count, String& timeStampLastRecord, Int64& documentSizeCharacters, Int64& documentSizeBytes) in File348:line 7573
at Invantive.Data.ExactOnlineXmlProvider.<GetRowsDataFromWebService>d__232.MoveNext() in File348:line 6871
at Invantive.Data.CompressedEnumerable`1.<GetEnumerator>d__2.MoveNext() in File275:line 3987
at Invantive.Data.CachedEnumerable`1.TryGetNext(Int32 index, T& item) in File275:line 4163
at Invantive.Data.CachedEnumerable`1.<GetEnumerator>d__6.MoveNext() in File275:line 4112
at System.Linq.Enumerable.<SelectManyIterator>d__16`2.MoveNext()
at Invantive.Sql.DataSourceOrFunctionTree.<GetDataFromDataContainer>d__50.MoveNext() in File54:line 420
at Invantive.Data.CompressedEnumerable`1.<GetEnumerator>d__2.MoveNext() in File275:line 3987
at Invantive.Data.CachedEnumerable`1.TryGetNext(Int32 index, T& item) in File275:line 4163
at Invantive.Data.CachedEnumerable`1.<GetEnumerator>d__6.MoveNext() in File275:line 4112
at Invantive.Sql.FirehoseResultSet.<Iterator>d__57.MoveNext() in File25:line 598
at Invantive.Data.CompressedEnumerable`1.<GetEnumerator>d__2.MoveNext() in File275:line 3987
at Invantive.Data.CachedEnumerable`1.TryGetNext(Int32 index, T& item) in File275:line 4163
at Invantive.Data.CachedEnumerable`1.<GetEnumerator>d__6.MoveNext() in File275:line 4112
at Invantive.Sql.FirehoseResultSet.<Iterator>d__57.MoveNext() in File25:line 598
at Invantive.Sql.FilterIterator.<Iterator>d__3.MoveNext() in File24:line 93
at Invantive.Sql.ChainedFirehose.<Iterator>d__11.MoveNext() in File22:line 82
at Invantive.Sql.SelectListIterator.<Iterator>d__7.MoveNext() in File30:line 120
at System.Linq.Enumerable.Count[TSource](IEnumerable`1 source)
at Invantive.Sql.DdlStatementTree.OnExecute(ParameterList parameters, ExpressionParser expressionParser) in File55:line 195
at Invantive.Sql.QueryTree.Execute(ParameterList parameters, ExpressionParser expressionParser) in File33:line 174
at Invantive.Sql.QueryPlan.ForcePlan() in File32:line 89
at Invantive.Sql.QueryPlan.get_Fields() in File32:line 66
at Invantive.Sql.QueryPlan.get_FieldCount() in File32:line 77
at Invantive.Data.QueryPlanCacheEntry.<>c.<.ctor>b__12_0(IQueryPlan qp) in File242:line 68
at System.Linq.Enumerable.WhereSelectArrayIterator`2.MoveNext()
at System.Linq.Buffer`1..ctor(IEnumerable`1 source)
at System.Linq.Enumerable.ToArray[TSource](IEnumerable`1 source)
at Invantive.Data.QueryPlanCacheEntry..ctor(String sqlStatement, IQueryPlan[] queryPlans, ParameterList parameters) in File242:line 68
at Invantive.Sql.SqlEngine.ExecuteAndFetch(IProviderManager manager, String sqlStatement, ParameterList parameters, Boolean allowSelect) in File37:line 538
at Invantive.Data.ConnectionManager.ExecuteProviderPassthroughSqlActionTable(String actionSql, ParameterList parameters, String& handlingPath) in File74:line 4546
--- End of stack trace from previous location where exception was thrown ---
at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw()
at Invantive.Data.ConnectionManager.ExecuteProviderPassthroughSqlActionTable(String actionSql, ParameterList parameters, String& handlingPath) in File74:line 4669
at Invantive.Data.ConnectionManager.PassthroughSqlActionTable(String actionSql, ParameterList parameters) in File74:line 2487
--- End of stack trace from previous location where exception was thrown ---
at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw()
at Invantive.Data.ConnectionManager.PassthroughSqlActionTable(String actionSql, ParameterList parameters) in File74:line 2501
at Invantive.Data.ActionProceduresBase.PassthroughSqlActionTable(String actionSql, ParameterList parameters) in File64:line 134
at Invantive.Producer.QueryEngine.QueryEngine.ProcessStatement(String sqlStatement, ResultSet& resultSet, Action`1 fetchMoreRows, Action`7 executeStatement, Boolean isInInteractiveMode, ScriptingLanguageNextStepSpecification& nextStepSpecification)
Предположительно, это проблема с разрешениями для текущего пользователя Exact через API Exact XML. Раньше это работало раньше, но после отключения / включения пользователя API StockPositions больше не доступен.
Как настроить пользователя для обеспечения доступности API StockPositions?
1 ответ
Модель авторизации Exact Online не очень подходит для сложных настроек безопасности; у него нет контроля доступа на основе ролей или простого сопоставления параметров безопасности с формами и API-интерфейсами.
В этом случае вам повезло. поскольку StockPositions
является таблицей на основе XML API, вы можете видеть в веб-интерфейсе пользователя Exact Online, есть ли у пользователя какие-либо привилегии.
Чтобы проверить это:
- Войдите в систему как пользователь, выполняющий запрос, используя то же имя пользователя и пароль для Exact Online.
- Нажмите на название компании вверху слева.
- Нажмите на опцию Импорт / Экспорт.
- Нажмите на метод XML.
- Все доступные API отображаются так:
- Для загрузки необходимо проверить, отображается ли опция "Экспорт". Для загрузки проверьте, присутствует ли "Импорт".
Если привилегии API отсутствуют, опытный пользователь, который может настроить привилегии пользователя, должен открыть Exact Online.
Затем:
- Нажмите на компанию
- Нажмите на Основные данные
- Нажмите на Пользователи -> Обзор
- Выберите пользователя.
- В группе "Монитор" нажмите "Права".
- Вы увидите обширный список из сотен флажков:
- Каждый флажок представляет некоторые привилегии пользователя под рукой.
- В общем, посмотрите на вкладку основной темы, к которой пользователю нужен доступ, и попробуйте эффекты для пользователя. Или обратитесь в точную поддержку за советом.