Форум программистов, компьютерный форум, киберфорум
HCL Notes: Программирование
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/102: Рейтинг темы: голосов - 102, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 07.01.2011
Сообщений: 153

Написание агента

08.09.2011, 12:06. Показов 19360. Ответов 16
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужна помощь в написании агента. Есть код представленный ниже, который берет приатачменный файл, который находится в кодировке OEM 866 перегоняется в кодировку вин 1251 и сохраняется в файл в кодировке utf-8. Как этот код переделать, чтобы подкинуть его в агент который должен срабатывать по событию получение нового письма?



Sub Click(Source As Button)
Dim doc As NotesDocument
Dim rtitem As Variant
Dim sourceName As String
Dim uiDoc As NotesUiDocument
Dim ws As New NotesUIWorkspace
Dim result As NotesMIMEEntity
Dim s As New NotesSession
Dim item As notesitem
Dim mystring As String
Dim res As Integer
Dim Tmp1 As String
Dim neoEmbedAttachment As NotesEmbeddedObject
Dim nrimAttachment As NotesRichTextItem
Dim varFilePath As Variant
Dim strFilePath As String
Dim session As New NotesSession
Dim strFieldname As String
Dim rtdoc As Variant
_________________________достаем путь прикрепленного файла
If doc.GetItemValue("From")(0) <> "CN=Vasya V Pupkin/O=Roga And Copyta" Then
Set uiDoc = ws.CurrentDocument
Set doc = uiDoc.Document
Set result = doc.CreateMIMEEntity
Set rtdoc=doc.GetFirstItem("Files")
If ( rtdoc.type = RICHTEXT ) Then
If Not Isempty(rtdoc.EmbeddedObjects) Then
Set mime = result.CreateChildEntity( )
Forall object In rtdoc.EmbeddedObjects
If (object.Type = EMBED_ATTACHMENT ) Then
filepath =Environ("Temp")+"\"+Cstr(Object.name)
Call object.ExtractFile(filepath)
________________________________________ ____________________________

outputFile = Freefile()
fileName$ = "C:\111.xml"
Open fileName$ For Output As outputFile Charset = "UTF-8"

fileNum = Freefile()
Open filepath For Input As fileNum
Do While Not Eof(fileNum)
Line Input #fileNum, MyTmpString
Tmp1 = MyTmpString
res = DosToWin(MyTmpString,Tmp1)
Print #outputFile, Tmp1
Loop

Close outputFile
Close fileNum
Call object.Remove удаление прикрепленного файла
________________________________________ _______берем этот файл и приатачеваем его
Set nrimAttachment = doc.GetFirstItem("Files")
Set neoEmbedAttachment = nrimAttachment.EmbedObject( EMBED_ATTACHMENT, "", fileName$)
Set nudWebdoc = ws.CurrentDocument
Set ndocBackWebdoc = nudWebdoc.Document
strFieldname = uidoc.CurrentField
Set nrimAttachment = doc.GetFirstItem("Files")
If session.NotesBuildVersion >= 190 Then
nrimAttachment.Update
Else
Call doc.ComputeWithForm(True, False)
End If
Set Doc = uiDoc.Document
Call doc.Save( True, True )
doc.SaveOptions = "0"
Call uidoc.Close(True)
Set uidocNew = ws.EditDocument(True, ndocBackWebdoc, , , , True)
Delete uidoc
uidocNew.Document.RemoveItem("SaveOption s")
If strFieldname <> "" Then uidocNew.GotoField(strFieldname)

Kill "C:\111.xml" удаляет файл с винта

End If
End Forall
End If
End If


End Sub
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.09.2011, 12:06
Ответы с готовыми решениями:

Написание агента
Здравствуйте! возникла проблема в написании агента :unsure: Этот агент должен просматривать все документы,которые проходят...

Mail написание агента "автоответчик"
Lotus 7.0.2 Подскажите как можно реализовать механизм авто ответа на входящие письма. Есть ли какие нибудь встроенные механизмы или...

вызов Ls-агента с показом диалогового окна из Java-агента
есть Java-агент, надо в нем показать диалоговое окно (картинку в нем показать и поле для ввода), попытался решить так: из Java-агента...

16
0 / 0 / 0
Регистрация: 07.01.2011
Сообщений: 153
08.09.2011, 17:20
Цитата Сообщение от romanko
Нужна помощь в написании агента. Есть код представленный ниже, который берет приатачменный файл, который находится в кодировке OEM 866 перегоняется в кодировку вин 1251 и сохраняется в файл в кодировке utf-8. Как этот код переделать, чтобы подкинуть его в агент который должен срабатывать по событию получение нового письма?
Впринципе, вот так должно работать

LotusScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
Sub Initialize
 
Dim session As New NotesSession
 
Set db = session.CurrentDatabase
Set collection = db.UnprocessedDocuments
Set doc = collection.GetFirstDocument
 
Call session.UpdateProcessedDoc( doc )
If doc.GetItemValue("From")(0) <> "CN=Vasya V Pupkin/O=Roga And Copyta" Then
Set rtitem = doc.GetFirstItem( "Files" )
If (Isarray(rtitem.EmbeddedObjects)) Then
Forall object In rtitem.EmbeddedObjects
If (object.Type = EMBED_ATTACHMENT ) Then
filepath = Environ("Temp")+"\"+Cstr(Object.name)
Call object.ExtractFile(filepath)
________________________________________________________________
outputFile = Freefile()
fileName$ = "C:\peredelal.xml"
Open fileName$ For Output As outputFile Charset = "UTF-8"
 
fileNum = Freefile()
Open filepath For Input As fileNum
Do While Not Eof(fileNum)
Line Input #fileNum, MyTmpString
Tmp1 = MyTmpString
res = DosToWin(MyTmpString,Tmp1)
Print #outputFile, Tmp1
 
Loop
 
Close outputFile
Close fileNum
 
Call object.Remove удаление прикрепленного файла
Call doc.Save( True, True )
____________________________________________________________________________
_
 
Dim rtitem1 As NotesRichTextItem
 
Set db = session.CurrentDatabase
Set doc = collection.GetFirstDocument
 
Set rtitem1 = doc.GetFirstItem("Files")
Set object = rtitem1.EmbedObject _
( EMBED_ATTACHMENT, "", fileName$)
Call doc.Save( True, True )
______________________________________________________________________
 
Kill    "C:\peredelal.xml"  удаляет файл с винта
 
 
End If
End Forall
End If
 
End Sub
 
Declarations :
Declare Function DosToWin Lib "User32" Alias "OemToCharA" (Byval lpAnsiStr As String, Byval lpOemStr As String) As Integer
Dim doc As NotesDocument
Dim db As NotesDatabase
Dim rtitem As Variant
Dim collection As NotesDocumentCollection
Dim neoEmbedAttachment As NotesEmbeddedObject
Если найдете какие-то ошибки подскажите.Потому что проверить пока немогу.((
Dim nrimAttachment As NotesRichTextItem
0
0 / 0 / 0
Регистрация: 07.01.2011
Сообщений: 153
11.09.2011, 12:44
Не срабатывает этот код ложится прям вот тут
Dim doc As NotesDocument
Dim db As NotesDatabase
Dim rtitem As Variant
Dim collection As NotesDocumentCollection
Dim neoEmbedAttachment As NotesEmbeddedObject
Dim nrimAttachment As NotesRichTextItem
Dim view As NotesView

Set db = session.CurrentDatabase
Set view = db.GetView("($Inbox)")
Set collection = db.UnprocessedDocuments
Set doc = collection.GetFirstDocument

If doc.GetItemValue("tmpDisplaySentBy")(0) <> "CN=От кого письмо" Then ВОТ СДЕСЬ ПИШЕТ ЧТО object variable not set
Call session.UpdateProcessedDoc( doc )
Set rtitem = doc.GetFirstItem( "Body" )

подскажите пожайлуста что с этим делать как правельно задавать переменную doc.
0
0 / 0 / 1
Регистрация: 30.06.2007
Сообщений: 2,153
11.09.2011, 12:46
romanko
Какой Target у документа?
Сколько возвращает collection.count?
0
0 / 0 / 0
Регистрация: 07.01.2011
Сообщений: 153
11.09.2011, 13:02
Цитата Сообщение от Omh
romanko
Какой Target у документа?
Сколько возвращает collection.count?
collection.count возвращает 0
collection [0, False, ""]

Добавлено:


Цитата Сообщение от romanko
collection.count возвращает 0
collection [0, False, ""]
Ну это если он один документ лежит во входящих, тоесть он пропускает первый. И как его заставить отрабатывать на событие прихода сообщения?
0
0 / 0 / 1
Регистрация: 30.06.2007
Сообщений: 2,153
11.09.2011, 13:07
Цитата Сообщение от romanko
И как его заставить отрабатывать на событие прихода сообщения?
Ты вообще смотрел свойства агента, в частности, Target?
0
0 / 0 / 0
Регистрация: 07.01.2011
Сообщений: 153
11.09.2011, 13:12
Цитата Сообщение от Omh
Ты вообще смотрел свойства агента, в частности, Target?
Там стоит событие после получения почты. а что не так?
0
0 / 0 / 1
Регистрация: 30.06.2007
Сообщений: 2,153
11.09.2011, 13:31
Тогда хорошо
0
0 / 0 / 0
Регистрация: 19.04.2009
Сообщений: 2,219
11.09.2011, 13:48
Цитата Сообщение от romanko
Там стоит событие после получения почты. а что не так?
А точно после получения почты (After new mail has arrived), а не до (Before new mail arrives)?
0
0 / 0 / 0
Регистрация: 13.10.2005
Сообщений: 848
11.09.2011, 13:57
romanko
чего хочется сделать то?

Если не ошибаюсь, то для обработки пришедшего письма нужно:
1. использовать событие "Before new mail arrives"
2. документ получать как notesSession.DocumentContext
0
0 / 0 / 0
Регистрация: 19.04.2009
Сообщений: 2,219
11.09.2011, 14:16
Цитата Сообщение от oshmianski
Если не ошибаюсь, то для обработки пришедшего письма нужно:
1. использовать событие "Before new mail arrives"
2. документ получать как notesSession.DocumentContext
При использовании события "Before new mail arrives" имеются ограничения и в контексте задачи (детачить вложение) лучше всё-таки использовать "After new mail has arrived" + set docs = notesDatabase.UnprocessedDocuments
0
0 / 0 / 0
Регистрация: 07.01.2011
Сообщений: 153
11.09.2011, 14:33
Цитата Сообщение от oshmianski
romanko
чего хочется сделать то?

Если не ошибаюсь, то для обработки пришедшего письма нужно:
1. использовать событие "Before new mail arrives"
2. документ получать как notesSession.DocumentContext
Хочется чтобы агент отрабатывал после прихода письма. но он почему-то неотрабатывает.Если запустить его принудительно то он все делает как надо а вот по событию нехочет.

Добавлено:


Цитата Сообщение от nvy
При использовании события "Before new mail arrives" имеются ограничения и в контексте задачи (детачить вложение) лучше всё-таки использовать "After new mail has arrived" + set docs = notesDatabase.UnprocessedDocuments
Так оно все так и написано и стоит после получения почты но почему-то неатрабатывает?когда письмо приходит то ничего не происходит.
0
0 / 0 / 0
Регистрация: 19.04.2009
Сообщений: 2,219
11.09.2011, 14:46
romanko
Кем подписан агент, от чьего имени запускается?
0
0 / 0 / 0
Регистрация: 07.01.2011
Сообщений: 153
11.09.2011, 15:47
Цитата Сообщение от nvy
romanko
Кем подписан агент, от чьего имени запускается?
Подписан менеджером бд на которой стоит. А как должно быть я просто в первый раз ставлю агент.
0
0 / 0 / 0
Регистрация: 07.01.2011
Сообщений: 153
11.09.2011, 17:23
Цитата Сообщение от nvy
romanko
Кем подписан агент, от чьего имени запускается?
а на бд mail.box агенты вообще никак не работают, тоесть его ни как не запустиш?
0
0 / 0 / 0
Регистрация: 19.04.2009
Сообщений: 2,219
11.09.2011, 17:27
Цитата Сообщение от romanko
а на бд mail.box агенты вообще никак не работают, тоесть его ни как не запустиш?
Так Вы это в mail.box агента запихнуть пытаетесь ?
0
0 / 0 / 0
Регистрация: 07.01.2011
Сообщений: 153
11.09.2011, 17:39
Цитата Сообщение от nvy
Так Вы это в mail.box агента запихнуть пытаетесь ?
Да. И что никак с этим не справиться?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.09.2011, 17:39
Помогаю со студенческими работами здесь

Проблема запуска Агента из агента!
Доброго времени суток! Ситуация такова запускю агента из другого агента, при запуске в строке запуска агента от компилятора получаю Notes...

запуск агента
Добрый день! Подскажите как запустить агент (LotusScript) через MS FoxPro 8.0 ?? строка Call nAgent.RunOnServer не дает...

Статус агента.
Всем привет! Вот собственно вопрос... можно ли принудительно выставить статус агента при запуске RunOnServer? Деление на ноль не...

Log агента
Здравствуйте. Возник вопрос: как получить в скрипте лог агента (в частности, инфу об ошибках, произошедших при последнем запуске агента)....

Ошибка агента.
Добрый день! Есть ошибка в написании агента, как её отловить? Агент работает по времени. После его запуска в логах пишет: AMgr: Agent...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru