Today I was working on a requirement to validate document approval (we are using OOTB document approval feature) based of some external business rules.
Requirement:
If business validation fails, I have to cancel document Approval process and if validation succeeds then I have to generate email notifying team with links to approved document.
Solution:
My first option was to use Workflow using Visual Studio (I have to re-use the functionality for many other document libraries), but soon found out it's not possible to retrieve before and after values inside Workflow and to cancel list item update. Please let me know if you think otherwise. The other option was to use Event Receiver which I followed. I override synchronous ItemUpdating event and again struggled to retrieve after "Approval Status" value. After couple of hours of debugging, I found key named vti_doclibmodstat in AfterProperites collection containing integer values 0, 1 or 2 which is nothing but Approved, Rejected or Pending statuses. So here is the complete code to retrieve before and after "Approval Status" inside event handler:
public override void ItemUpdating(SPItemEventProperties properties)
{
base.ItemUpdating(properties);
{
base.ItemUpdating(properties);
SPModerationStatusType beforeStatus = properties.ListItem.ModerationInformation.Status;
SPModerationStatusType afterStatus =
(SPModerationStatusType)Int32.Parse(properties.AfterProperties["vti_doclibmodstat"].ToString());
(SPModerationStatusType)Int32.Parse(properties.AfterProperties["vti_doclibmodstat"].ToString());
if ((beforeStatus != afterStatus) &&
(afterStatus == SPModerationStatusType.Approved))
(afterStatus == SPModerationStatusType.Approved))
{
if (Validate(properties) == false)
{
properties.Cancel = true;
properties.ErrorMessage = "";
And now I can validate document approval process, cancel approval process and send email notifications.
Hope this helps.-Javed
Thank you, this snippet was very helpful.
ReplyDeleteHi,
ReplyDeleteIs there a way to check whether ItemUpdating is triggered by Content Approval or while Updating an item.
Thanks,
RIcky A
Kavaklıdere
ReplyDeleteGüzelhisar
Dikili
İnecik
Kuluca
B1Y1
Konya
ReplyDeleteKayseri
Malatya
Elazığ
Tokat
ZSL
elazığ
ReplyDeleteerzincan
bayburt
tunceli
sakarya
4NCY
malatya evden eve nakliyat
ReplyDeleteartvin evden eve nakliyat
kocaeli evden eve nakliyat
ankara evden eve nakliyat
düzce evden eve nakliyat
ZH1TA
kırşehir evden eve nakliyat
ReplyDeletegiresun evden eve nakliyat
tekirdağ evden eve nakliyat
ardahan evden eve nakliyat
izmir evden eve nakliyat
84020
rize evden eve nakliyat
ReplyDeletemuğla evden eve nakliyat
kırıkkale evden eve nakliyat
mardin evden eve nakliyat
istanbul evden eve nakliyat
6H0X
BF7DB
ReplyDeleteİstanbul Parça Eşya Taşıma
Kayseri Şehir İçi Nakliyat
Kocaeli Şehirler Arası Nakliyat
Van Evden Eve Nakliyat
Eryaman Fayans Ustası
Çankırı Şehir İçi Nakliyat
Kırklareli Evden Eve Nakliyat
Eskişehir Lojistik
Ardahan Lojistik
CDF7F
ReplyDeleteYenimahalle Boya Ustası
Düzce Lojistik
Rize Şehirler Arası Nakliyat
Eryaman Alkollü Mekanlar
Karaman Şehir İçi Nakliyat
İstanbul Evden Eve Nakliyat
Çerkezköy Yol Yardım
Nevşehir Evden Eve Nakliyat
Çankırı Lojistik
3F13C
ReplyDeleteboldenone for sale
buy peptides
clenbuterol for sale
order turinabol
order testosterone propionat
buy winstrol stanozolol
buy fat burner
buy steroid cycles
buy oxandrolone anavar
F119E
ReplyDeleteFuckelon Coin Hangi Borsada
Aion Coin Hangi Borsada
Shinja Coin Hangi Borsada
Kwai Beğeni Satın Al
Sui Coin Hangi Borsada
Referans Kimliği Nedir
Kripto Para Kazma
Kripto Para Nedir
Youtube Beğeni Hilesi
984E9
ReplyDeletepudgy penguins
quickswap
uwulend finance
yearn finance
sushiswap
shapeshift
pancakeswap
DefiLlama
eigenlayer
CFGHGFYHNJY
ReplyDeleteشركة كشف تسربات المياه بالجبيل
شركة تنظيف بخميس مشيط h0LpzFZ55z
ReplyDeleteشركة تسليك مجاري بالاحساء Qb8eNfKIOh
ReplyDeleteشركة صيانة افران 1CavpZj8ik
ReplyDeleteافضل شركة مكافحة حشرات kabsjP7olQ
ReplyDeleteشركة عزل اسطح بالهفوف ozencPq7Z7
ReplyDelete4D74FCC467
ReplyDeleteinstagram bot takipci