All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sun.jna.platform.win32.Winevt Maven / Gradle / Ivy

There is a newer version: 5.15.0
Show newest version
/* Copyright (c) 2016 Minoru Sakamoto, All Rights Reserved
 *
 * The contents of this file is dual-licensed under 2
 * alternative Open Source/Free licenses: LGPL 2.1 or later and
 * Apache License 2.0. (starting with JNA version 4.0.0).
 *
 * You can freely decide which license you want to apply to
 * the project.
 *
 * You may obtain a copy of the LGPL License at:
 *
 * http://www.gnu.org/licenses/licenses.html
 *
 * A copy is also included in the downloadable source code package
 * containing JNA, in file "LGPL2.1".
 *
 * You may obtain a copy of the Apache License at:
 *
 * http://www.apache.org/licenses/
 *
 * A copy is also included in the downloadable source code package
 * containing JNA, in file "AL2.0".
 */
package com.sun.jna.platform.win32;

import com.sun.jna.*;
import com.sun.jna.Structure.FieldOrder;
import com.sun.jna.platform.win32.WinDef.BOOL;
import com.sun.jna.platform.win32.WinNT.HANDLE;
import com.sun.jna.win32.W32APITypeMapper;

import java.util.Arrays;
import java.util.List;

/**
 * Ported from winevt.h.
 * Microsoft Windows SDK 10.0.10586
 *
 * @author Minoru Sakamoto
 */
public interface Winevt {

    /**
     * Defines the possible data types of a variant data item.
     * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385616(v=vs.85).aspx
     */
    public static enum EVT_VARIANT_TYPE {

        /** Null content that implies that the element that contains the content does not exist. */
        EvtVarTypeNull(""),

        /** A null-terminated Unicode string. */
        EvtVarTypeString("String"),

        /** A null-terminated ANSI string. */
        EvtVarTypeAnsiString("AnsiString"),

        /** A signed 8-bit integer value. */
        EvtVarTypeSByte("SByte"),

        /** An unsigned 8-bit integer value. */
        EvtVarTypeByte("Byte"),

        /** An signed 16-bit integer value. */
        EvtVarTypeInt16("Int16"),

        /** An unsigned 16-bit integer value. */
        EvtVarTypeUInt16("UInt16"),

        /** A signed 32-bit integer value. */
        EvtVarTypeInt32("Int32"),

        /** An unsigned 32-bit integer value. */
        EvtVarTypeUInt32("UInt32"),

        /** A signed 64-bit integer value. */
        EvtVarTypeInt64("Int64"),

        /** An unsigned 64-bit integer value. */
        EvtVarTypeUInt64("UInt64"),

        /** A single-precision real value. */
        EvtVarTypeSingle("Single"),

        /** A double-precision real value. */
        EvtVarTypeDouble("Double"),

        /** A Boolean value. */
        EvtVarTypeBoolean("Boolean"),

        /** A hexadecimal binary value. */
        EvtVarTypeBinary("Binary"),

        /** A GUID value. */
        EvtVarTypeGuid("Guid"),

        /** An unsigned 32-bit or 64-bit integer value that contains a pointer address. */
        EvtVarTypeSizeT("SizeT"),

        /** A FILETIME value. */
        EvtVarTypeFileTime("FileTime"),

        /** A SYSTEMTIME value. */
        EvtVarTypeSysTime("SysTime"),

        /** A security identifier (SID) structure */
        EvtVarTypeSid("Sid"),

        /** A 32-bit hexadecimal number. */
        EvtVarTypeHexInt32("Int32"),

        /** A 64-bit hexadecimal number. */
        EvtVarTypeHexInt64("Int64"),

        /** An EVT_HANDLE value. */
        EvtVarTypeEvtHandle("EvtHandle"),

        /** A null-terminated Unicode string that contains XML. */
        EvtVarTypeEvtXml("Xml");

        private final String field;

        private EVT_VARIANT_TYPE(String field) {
            this.field = field;
        }

        public String getField() {
            return this.field.isEmpty() ? "" : this.field + "Val";
        }

        public String getArrField() {
            return this.field.isEmpty() ? "" : this.field + "Arr";
        }
    }

    /**
     * The Type member of the EVT_VARIANT structure has this bit set if the variant contains a pointer to an array of
     * values, rather than the value itself.
     * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385781(v=vs.85).aspx
     */
    public static final int EVT_VARIANT_TYPE_ARRAY = 128;

    /**
     * A bitmask that you use to mask out the array bit of the variant type, so you can determine the data type of
     * the variant value that the EVT_VARIANT structure contains.
     * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385781(v=vs.85).aspx
     */
    public static final int EVT_VARIANT_TYPE_MASK = 0x7f;

    /**
     * Defines the types of connection methods you can use to connect to the remote computer.
     * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385529(v=vs.85).aspx
     */
    public static interface EVT_LOGIN_CLASS {

        /** Use Remote Procedure Call (RPC) login. */
        public static final int EvtRpcLogin = 1;
    }

    /**
     * Contains event data or property values.
     * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385611(v=vs.85).aspx
     */
    @FieldOrder({"field1", "Count", "Type"})
    public static class EVT_VARIANT extends Structure {
        /**
         * Exposed to follow JNA rules, use the
         * {@link EVT_VARIANT#getValue} method
         * to manipulate values!
         */
        public field1_union field1;

        /*
        Defined to get correct size for the union. Data is accessed by direct
        read from memory.
        */
        public static class field1_union extends Union {

            public byte byteValue;

            public short shortValue;

            public int intValue;

            public long longValue;

            public float floatValue;

            public double doubleVal;

            public Pointer pointerValue;
        }

        /**
         * The number of elements in the array of values. Use Count if the Type member has
         * the EVT_VARIANT_TYPE_ARRAY flag set.
         * 

* Exposed to follow JNA rules, use * {@link EVT_VARIANT#getValue} and {@link EVT_VARIANT#setValue} methods * to manipulate values! */ public int Count; /** * A flag that specifies the data type of the variant. For possible values, see * the {@link Winevt.EVT_VARIANT_TYPE} enumeration. * The variant contains an array of values, if the EVT_VARIANT_TYPE_ARRAY flag is set. The members that end in * "Arr" contain arrays of values. For example, you would use the StringArr member to access the variant data * if the type is EvtVarTypeString and the EVT_VARIANT_TYPE_ARRAY flag is set. * You can use the {@link Winevt#EVT_VARIANT_TYPE_MASK} constant to mask out the array bit to determine * the variant's type. *

* Exposed to follow JNA rules, use * {@link EVT_VARIANT#getValue} and {@link EVT_VARIANT#setValue} methods * to manipulate values! */ public int Type; public EVT_VARIANT() { super(W32APITypeMapper.DEFAULT); } public EVT_VARIANT(Pointer peer) { super(peer, Structure.ALIGN_DEFAULT, W32APITypeMapper.DEFAULT); } public void use(Pointer m) { useMemory(m, 0); } public static class ByReference extends EVT_VARIANT implements Structure.ByReference { public ByReference(Pointer p) { super(p); } public ByReference() { super(); } } public static class ByValue extends EVT_VARIANT implements Structure.ByValue { public ByValue(Pointer p) { super(p); } public ByValue() { } } private int getBaseType() { return Type & EVT_VARIANT_TYPE_MASK; } public boolean isArray() { return (Type & EVT_VARIANT_TYPE_ARRAY) == EVT_VARIANT_TYPE_ARRAY; } public EVT_VARIANT_TYPE getVariantType() { return EVT_VARIANT_TYPE.values()[getBaseType()]; } // Helper to store java object for set values private Object holder; /** * @param type * @param value */ public void setValue(EVT_VARIANT_TYPE type, Object value) { allocateMemory(); if (type == null) { throw new IllegalArgumentException("setValue must not be called with type set to NULL"); } holder = null; if (value == null || type == EVT_VARIANT_TYPE.EvtVarTypeNull) { Type = EVT_VARIANT_TYPE.EvtVarTypeNull.ordinal(); Count = 0; field1.writeField("pointerValue", Pointer.NULL); } else { switch (type) { case EvtVarTypeAnsiString: if (value.getClass().isArray() && value.getClass().getComponentType() == String.class) { Type = type.ordinal() | EVT_VARIANT_TYPE_ARRAY; StringArray sa = new StringArray((String[]) value, false); holder = sa; Count = ((String[]) value).length; field1.writeField("pointerValue", sa); } else if (value.getClass() == String.class) { Type = type.ordinal(); Memory mem = new Memory(((String) value).length() + 1); mem.setString(0, (String) value); holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else { throw new IllegalArgumentException(type.name() + " must be set from String/String[]"); } break; case EvtVarTypeBoolean: if (value.getClass().isArray() && value.getClass().getComponentType() == BOOL.class) { Type = type.ordinal() | EVT_VARIANT_TYPE_ARRAY; Memory mem = new Memory(((BOOL[]) value).length * 4); for (int i = 0; i < ((BOOL[]) value).length; i++) { mem.setInt(i * 4, ((BOOL[]) value)[i].intValue()); } holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else if (value.getClass() == BOOL.class) { Type = type.ordinal(); Count = 0; field1.writeField("intValue", ((BOOL) value).intValue()); } else { throw new IllegalArgumentException(type.name() + " must be set from BOOL/BOOL[]"); } break; case EvtVarTypeString: case EvtVarTypeEvtXml: if (value.getClass().isArray() && value.getClass().getComponentType() == String.class) { Type = type.ordinal() | EVT_VARIANT_TYPE_ARRAY; StringArray sa = new StringArray((String[]) value, true); holder = sa; Count = ((String[]) value).length; field1.writeField("pointerValue", sa); } else if (value.getClass() == String.class) { Type = type.ordinal(); Memory mem = new Memory((((String) value).length() + 1) * 2); mem.setWideString(0, (String) value); holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else { throw new IllegalArgumentException(type.name() + " must be set from String/String[]"); } break; case EvtVarTypeSByte: case EvtVarTypeByte: if (value.getClass().isArray() && value.getClass().getComponentType() == byte.class) { Type = type.ordinal() | EVT_VARIANT_TYPE_ARRAY; Memory mem = new Memory(((byte[]) value).length * 1); mem.write(0, (byte[]) value, 0, ((byte[]) value).length); holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else if (value.getClass() == byte.class) { Type = type.ordinal(); Count = 0; field1.writeField("byteValue", value); } else { throw new IllegalArgumentException(type.name() + " must be set from byte/byte[]"); } break; case EvtVarTypeInt16: case EvtVarTypeUInt16: if (value.getClass().isArray() && value.getClass().getComponentType() == short.class) { Type = type.ordinal() | EVT_VARIANT_TYPE_ARRAY; Memory mem = new Memory(((short[]) value).length * 2); mem.write(0, (short[]) value, 0, ((short[]) value).length); holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else if (value.getClass() == short.class) { Type = type.ordinal(); Count = 0; field1.writeField("shortValue", value); } else { throw new IllegalArgumentException(type.name() + " must be set from short/short[]"); } break; case EvtVarTypeHexInt32: case EvtVarTypeInt32: case EvtVarTypeUInt32: if (value.getClass().isArray() && value.getClass().getComponentType() == int.class) { Type = type.ordinal() | EVT_VARIANT_TYPE_ARRAY; Memory mem = new Memory(((int[]) value).length * 4); mem.write(0, (int[]) value, 0, ((int[]) value).length); holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else if (value.getClass() == int.class) { Type = type.ordinal(); Count = 0; field1.writeField("intValue", value); } else { throw new IllegalArgumentException(type.name() + " must be set from int/int[]"); } break; case EvtVarTypeHexInt64: case EvtVarTypeInt64: case EvtVarTypeUInt64: if (value.getClass().isArray() && value.getClass().getComponentType() == long.class) { Type = type.ordinal() | EVT_VARIANT_TYPE_ARRAY; Memory mem = new Memory(((long[]) value).length * 4); mem.write(0, (long[]) value, 0, ((long[]) value).length); holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else if (value.getClass() == long.class) { Type = type.ordinal(); Count = 0; field1.writeField("longValue", value); } else { throw new IllegalArgumentException(type.name() + " must be set from long/long[]"); } break; case EvtVarTypeSingle: if (value.getClass().isArray() && value.getClass().getComponentType() == float.class) { Type = type.ordinal() | EVT_VARIANT_TYPE_ARRAY; Memory mem = new Memory(((float[]) value).length * 4); mem.write(0, (float[]) value, 0, ((float[]) value).length); holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else if (value.getClass() == float.class) { Type = type.ordinal(); Count = 0; field1.writeField("floatValue", value); } else { throw new IllegalArgumentException(type.name() + " must be set from float/float[]"); } break; case EvtVarTypeDouble: if (value.getClass().isArray() && value.getClass().getComponentType() == double.class) { Type = type.ordinal() | EVT_VARIANT_TYPE_ARRAY; Memory mem = new Memory(((double[]) value).length * 4); mem.write(0, (double[]) value, 0, ((double[]) value).length); holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else if (value.getClass() == double.class) { Type = type.ordinal(); Count = 0; field1.writeField("doubleVal", value); } else { throw new IllegalArgumentException(type.name() + " must be set from double/double[]"); } break; case EvtVarTypeBinary: if (value.getClass().isArray() && value.getClass().getComponentType() == byte.class) { Type = type.ordinal(); Memory mem = new Memory(((byte[]) value).length * 1); mem.write(0, (byte[]) value, 0, ((byte[]) value).length); holder = mem; Count = 0; field1.writeField("pointerValue", mem); } else { throw new IllegalArgumentException(type.name() + " must be set from byte[]"); } break; case EvtVarTypeFileTime: case EvtVarTypeEvtHandle: case EvtVarTypeSysTime: case EvtVarTypeGuid: case EvtVarTypeSid: case EvtVarTypeSizeT: default: throw new IllegalStateException(String.format("NOT IMPLEMENTED: getValue(%s) (Array: %b, Count: %d)", type, isArray(), Count)); } } write(); } /** * @return value contained in the EVT_VARIANT */ public Object getValue() { EVT_VARIANT_TYPE type = getVariantType(); switch (type) { case EvtVarTypeAnsiString: return isArray() ? field1.getPointer().getPointer(0).getStringArray(0, Count) : field1.getPointer().getPointer(0).getString(0); case EvtVarTypeBoolean: if (isArray()) { int[] rawValue = field1.getPointer().getPointer(0).getIntArray(0, Count); WinDef.BOOL[] result = new WinDef.BOOL[rawValue.length]; for (int i = 0; i < result.length; i++) { result[i] = new WinDef.BOOL(rawValue[i]); } return result; } else { return new WinDef.BOOL(field1.getPointer().getInt(0)); } case EvtVarTypeString: case EvtVarTypeEvtXml: return isArray() ? field1.getPointer().getPointer(0).getWideStringArray(0, Count) : field1.getPointer().getPointer(0).getWideString(0); case EvtVarTypeFileTime: if (isArray()) { WinBase.FILETIME resultFirst = Structure.newInstance(WinBase.FILETIME.class, field1.getPointer().getPointer(0)); resultFirst.read(); return resultFirst.toArray(Count); } else { WinBase.FILETIME result = new WinBase.FILETIME(field1.getPointer()); result.read(); return result; } case EvtVarTypeSysTime: if (isArray()) { WinBase.SYSTEMTIME resultFirst = Structure.newInstance(WinBase.SYSTEMTIME.class, field1.getPointer().getPointer(0)); resultFirst.read(); return resultFirst.toArray(Count); } else { WinBase.SYSTEMTIME result = Structure.newInstance(WinBase.SYSTEMTIME.class, field1.getPointer().getPointer(0)); result.read(); return result; } case EvtVarTypeSByte: case EvtVarTypeByte: return isArray() ? field1.getPointer().getPointer(0).getByteArray(0, Count) : field1.getPointer().getByte(0); case EvtVarTypeInt16: case EvtVarTypeUInt16: return isArray() ? field1.getPointer().getPointer(0).getShortArray(0, Count) : field1.getPointer().getShort(0); case EvtVarTypeHexInt32: case EvtVarTypeInt32: case EvtVarTypeUInt32: return isArray() ? field1.getPointer().getPointer(0).getIntArray(0, Count) : field1.getPointer().getInt(0); case EvtVarTypeHexInt64: case EvtVarTypeInt64: case EvtVarTypeUInt64: return isArray() ? field1.getPointer().getPointer(0).getLongArray(0, Count) : field1.getPointer().getLong(0); case EvtVarTypeSingle: return isArray() ? field1.getPointer().getPointer(0).getFloatArray(0, Count) : field1.getPointer().getFloat(0); case EvtVarTypeDouble: return isArray() ? field1.getPointer().getPointer(0).getDoubleArray(0, Count) : field1.getPointer().getDouble(0); case EvtVarTypeBinary: assert (!isArray()); return field1.getPointer().getPointer(0).getByteArray(0, Count); case EvtVarTypeNull: return null; case EvtVarTypeGuid: if (isArray()) { Guid.GUID resultFirst = Structure.newInstance(Guid.GUID.class, field1.getPointer().getPointer(0)); resultFirst.read(); return resultFirst.toArray(Count); } else { Guid.GUID result = Structure.newInstance(Guid.GUID.class, field1.getPointer().getPointer(0)); result.read(); return result; } case EvtVarTypeSid: if (isArray()) { WinNT.PSID resultFirst = Structure.newInstance(WinNT.PSID.class, field1.getPointer().getPointer(0)); resultFirst.read(); return resultFirst.toArray(Count); } else { WinNT.PSID result = Structure.newInstance(WinNT.PSID.class, field1.getPointer().getPointer(0)); result.read(); return result; } case EvtVarTypeSizeT: if (isArray()) { long[] rawValue = field1.getPointer().getPointer(0).getLongArray(0, Count); BaseTSD.SIZE_T[] result = new BaseTSD.SIZE_T[rawValue.length]; for (int i = 0; i < result.length; i++) { result[i] = new BaseTSD.SIZE_T(rawValue[i]); } return result; } else { return new BaseTSD.SIZE_T(field1.getPointer().getLong(0)); } case EvtVarTypeEvtHandle: if (isArray()) { Pointer[] rawValue = field1.getPointer().getPointer(0).getPointerArray(0, Count); WinNT.HANDLE[] result = new WinNT.HANDLE[rawValue.length]; for (int i = 0; i < result.length; i++) { result[i] = new WinNT.HANDLE(rawValue[i]); } return result; } else { return new WinNT.HANDLE(field1.getPointer().getPointer(0)); } default: throw new IllegalStateException(String.format("NOT IMPLEMENTED: getValue(%s) (Array: %b, Count: %d)", type, isArray(), Count)); } } } /** * Defines the types of authentication that you can use to authenticate the user when connecting to a remote * computer. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385570(v=vs.85).aspx */ public static interface EVT_RPC_LOGIN_FLAGS { /** * Use the default authentication method during RPC login. The default authentication method is Negotiate. */ public static final int EvtRpcLoginAuthDefault = 0; /** * Use the Negotiate authentication method during RPC login. The client and server negotiate whether to use * NTLM or Kerberos. */ public static final int EvtRpcLoginAuthNegotiate = 1; /** Use Kerberos authentication during RPC login. */ public static final int EvtRpcLoginAuthKerberos = 2; /** Use NTLM authentication during RPC login. */ public static final int EvtRpcLoginAuthNTLM = 3; } /** * Contains the information used to connect to a remote computer. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385566(v=vs.85).aspx */ @FieldOrder({"Server", "User", "Domain", "Password", "Flags"}) public class EVT_RPC_LOGIN extends Structure { /** The name of the remote computer to connect to. */ public String Server; /** The user name to use to connect to the remote computer. */ public String User; /** The domain to which the user account belongs. Optional. */ public String Domain; /** The password for the user account. */ public String Password; /** * The authentication method to use to authenticate the user when connecting to the remote computer. * For possible authentication methods, see the {@link Winevt.EVT_RPC_LOGIN_FLAGS} enumeration. */ public int Flags; public EVT_RPC_LOGIN() { super(W32APITypeMapper.UNICODE); } public EVT_RPC_LOGIN(String Server, String User, String Domain, String Password, int Flags) { super(W32APITypeMapper.UNICODE); this.Server = Server; this.User = User; this.Domain = Domain; this.Password = Password; this.Flags = Flags; } public EVT_RPC_LOGIN(Pointer peer) { super(peer, Structure.ALIGN_DEFAULT, W32APITypeMapper.UNICODE); } public static class ByReference extends EVT_RPC_LOGIN implements Structure.ByReference { } public static class ByValue extends EVT_RPC_LOGIN implements Structure.ByValue { } } /** * Defines the values that specify how to return the query results and whether you are query against a channel or * log file. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385549(v=vs.85).aspx */ public static interface EVT_QUERY_FLAGS { /** * Specifies that the query is against one or more channels. The Path parameter of the EvtQuery function must * specify the name of a channel or NULL. */ public static final int EvtQueryChannelPath = 0x1; /** * Specifies that the query is against one or more log files. The Path parameter of the EvtQuery function must * specify the full path to a log file or NULL. */ public static final int EvtQueryFilePath = 0x2; /** * Specifies that the events in the query result are ordered from oldest to newest. This is the default. */ public static final int EvtQueryForwardDirection = 0x100; /** * Specifies that the events in the query result are ordered from newest to oldest. */ public static final int EvtQueryReverseDirection = 0x200; /** * Specifies that {@link Wevtapi#EvtQuery} should run the query even if the part of the query generates * an error (is not well formed). The service validates the syntax of the XPath query to determine if it is * well formed. If the validation fails, the service parses the XPath into individual expressions. It builds * a new XPath beginning with the left most expression. The service validates the expression and if it is valid, * the service adds the next expression to the XPath. The service repeats this process until it finds * the expression that is failing. It then uses the valid expressions that it found beginning with the leftmost * expression as the XPath query (which means that you may not get the events that you expected). If no part of * the XPath is valid, the EvtQuery call fails. */ public static final int EvtQueryTolerateQueryErrors = 0x1000; } /** * Defines the relative position in the result set from which to seek. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385575(v=vs.85).aspx */ public static interface EVT_SEEK_FLAGS { /** * Seek to the specified offset from the first entry in the result set. The offset must be a positive value. */ public static final int EvtSeekRelativeToFirst = 1; /** * Seek to the specified offset from the last entry in the result set. The offset must be a negative value. */ public static final int EvtSeekRelativeToLast = 2; /** * Seek to the specified offset from the current entry in the result set. The offset can be a positive or * negative value. */ public static final int EvtSeekRelativeToCurrent = 3; /** * Seek to the specified offset from the bookmarked entry in the result set. The offset can be a positive or * negative value. */ public static final int EvtSeekRelativeToBookmark = 4; /** * A bitmask that you can use to determine which of the following flags is set: *

    *
  • EvtSeekRelativeToFirst
  • *
  • EvtSeekRelativeToLast
  • *
  • EvtSeekRelativeToBookmark
  • *
*/ public static final int EvtSeekOriginMask = 7; /** * Force the function to fail if the event does not exist. */ public static final int EvtSeekStrict = 0x10000; } /** * Defines the possible values that specify when to start subscribing to events. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385588(v=vs.85).aspx */ public static interface EVT_SUBSCRIBE_FLAGS { /** * Subscribe to only future events that match the query criteria. */ public static final int EvtSubscribeToFutureEvents = 1; /** * Subscribe to all existing and future events that match the query criteria. */ public static final int EvtSubscribeStartAtOldestRecord = 2; /** * Subscribe to all existing and future events that match the query criteria that begin after the bookmarked * event. If you include the EvtSubscribeStrict flag, the {@link Wevtapi#EvtSubscribe} function fails if * the bookmarked event does not exist. If you do not include the EvtSubscribeStrict flag and the bookmarked * event does not exist, the subscription begins with the event that is after the event that is closest to * the bookmarked event. */ public static final int EvtSubscribeStartAfterBookmark = 3; /** * A bitmask that you can use to determine which of the following flags is set: *
    *
  • EvtSubscribeToFutureEvents
  • *
  • EvtSubscribeStartAtOldestRecord
  • *
  • EvtSubscribeStartAfterBookmark
  • *
*/ public static final int EvtSubscribeOriginMask = 3; /** * Complete the subscription even if the part of the query generates an error (is not well formed). The service * validates the syntax of the XPath query to determine if it is well formed. If the validation fails, * the service parses the XPath into individual expressions. It builds a new XPath beginning with the left most * expression. The service validates the expression and if it is valid, the service adds the next expression to * the XPath. The service repeats this process until it finds the expression that is failing. It then uses * the valid expressions that it found beginning with the leftmost expression as the XPath query (which means * that you may not get the events that you expected). If no part of the XPath is valid, * the {@link Wevtapi#EvtSubscribe} call fails. */ public static final int EvtSubscribeTolerateQueryErrors = 0x1000; /** * Forces the {@link Wevtapi#EvtSubscribe} call to fail if you specify EvtSubscribeStartAfterBookmark and * the bookmarked event is not found (the return value is ERROR_NOT_FOUND). Also, set this flag if you want to * receive notification in your callback when event records are missing. */ public static final int EvtSubscribeStrict = 0x10000; } /** * Defines the possible types of data that the subscription service can deliver to your callback. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385596(v=vs.85).aspx */ public static interface EVT_SUBSCRIBE_NOTIFY_ACTION { /** * Indicates that the Event parameter contains a Win32 error code. */ public static final int EvtSubscribeActionError = 0; /** * Indicates that the Event parameter contains an event that matches the subscriber's query. */ public static final int EvtSubscribeActionDeliver = 1; } /** * Defines the identifiers that identify the system-specific properties of an event. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385606(v=vs.85).aspx */ public static interface EVT_SYSTEM_PROPERTY_ID { /** * Identifies the Name attribute of the provider element. The variant type for this property is EvtVarTypeString. */ public static final int EvtSystemProviderName = 0; /** * Identifies the Guid attribute of the provider element. The variant type for this property is EvtVarTypeGuid. */ public static final int EvtSystemProviderGuid = 1; /** Identifies the EventID element. The variant type for this property is EvtVarTypeUInt16. */ public static final int EvtSystemEventID = 2; /** * Identifies the Qualifiers attribute of the EventID element. The variant type for this property is * EvtVarTypeUInt16. */ public static final int EvtSystemQualifiers = 3; /** Identifies the Level element. The variant type for this property is EvtVarTypeUInt8. */ public static final int EvtSystemLevel = 4; /** Identifies the Task element. The variant type for this property is EvtVarTypeUInt16. */ public static final int EvtSystemTask = 5; /** Identifies the Opcode element. The variant type for this property is EvtVarTypeUInt8. */ public static final int EvtSystemOpcode = 6; /** Identifies the Keywords element. The variant type for this property is EvtVarTypeInt64. */ public static final int EvtSystemKeywords = 7; /** * Identifies the SystemTime attribute of the TimeCreated element. The variant type for this property is * EvtVarTypeFileTime. */ public static final int EvtSystemTimeCreated = 8; /** Identifies the EventRecordID element. The variant type for this property is EvtVarTypeUInt64. */ public static final int EvtSystemEventRecordId = 9; /** * Identifies the ActivityID attribute of the Correlation element. The variant type for this property is * EvtVarTypeGuid. */ public static final int EvtSystemActivityID = 10; /** * Identifies the RelatedActivityID attribute of the Correlation element. The variant type for this property is * EvtVarTypeGuid. */ public static final int EvtSystemRelatedActivityID = 11; /** * Identifies the ProcessID attribute of the Execution element. The variant type for this property is * EvtVarTypeUInt32. */ public static final int EvtSystemProcessID = 12; /** * Identifies the ThreadID attribute of the Execution element. The variant type for this property is * EvtVarTypeUInt32. */ public static final int EvtSystemThreadID = 13; /** Identifies the Channel element. The variant type for this property is EvtVarTypeString. */ public static final int EvtSystemChannel = 14; /** Identifies the Computer element. The variant type for this property is EvtVarTypeString. */ public static final int EvtSystemComputer = 15; /** Identifies the UserID element. The variant type for this property is EvtVarTypeSid. */ public static final int EvtSystemUserID = 16; /** Identifies the Version element. The variant type for this property is EvtVarTypeUInt8. */ public static final int EvtSystemVersion = 17; /** This enumeration value marks the end of the enumeration values. */ public static final int EvtSystemPropertyIdEND = 18; } /** * Defines the values that specify the type of information to access from the event. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385561(v=vs.85).aspx */ public static interface EVT_RENDER_CONTEXT_FLAGS { /** Render specific properties from the event. */ public static final int EvtRenderContextValues = 0; /** * Render the system properties under the System element. The properties are returned in the order defined in * the {@link EVT_SYSTEM_PROPERTY_ID} enumeration. */ public static final int EvtRenderContextSystem = 1; /** * Render all user-defined properties under the UserData or EventData element. If the data template associated * with the event contains a UserData section, the UserData properties are rendered; otherwise, the EventData * properties are rendered. */ public static final int EvtRenderContextUser = 2; } /** * Defines the values that specify what to render. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385563(v=vs.85).aspx */ public static interface EVT_RENDER_FLAGS { /** Render the event properties specified in the rendering context. */ public static final int EvtRenderEventValues = 0; /** * Render the event as an XML string. For details on the contents of the XML string, see the Event schema. */ public static final int EvtRenderEventXml = 1; /** * Render the bookmark as an XML string, so that you can easily persist the bookmark for use later. */ public static final int EvtRenderBookmark = 2; } /** * Defines the values that specify the message string from the event to format. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385525(v=vs.85).aspx */ public static interface EVT_FORMAT_MESSAGE_FLAGS { /** Format the event's message string. */ public static final int EvtFormatMessageEvent = 1; /** Format the message string of the level specified in the event. */ public static final int EvtFormatMessageLevel = 2; /** Format the message string of the task specified in the event. */ public static final int EvtFormatMessageTask = 3; /** Format the message string of the opcode specified in the event. */ public static final int EvtFormatMessageOpcode = 4; /** * Format the message string of the keywords specified in the event. If the event specifies multiple keywords, * the formatted string is a list of null-terminated strings. Increment through the strings until your pointer * points past the end of the used buffer. */ public static final int EvtFormatMessageKeyword = 5; /** Format the message string of the channel specified in the event. */ public static final int EvtFormatMessageChannel = 6; /** Format the provider's message string. */ public static final int EvtFormatMessageProvider = 7; /** * Format the message string associated with a resource identifier. The provider's metadata contains * the resource identifiers; the message compiler assigns a resource identifier to each string when it compiles * the manifest. */ public static final int EvtFormatMessageId = 8; /** * Format all the message strings in the event. The formatted message is an XML string that contains the event * details and the message strings. The message strings are included in the RenderingInfo section of the event * details. */ public static final int EvtFormatMessageXml = 9; } /** * Defines the values that specify whether to open a channel or exported log file. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385541(v=vs.85).aspx */ public static interface EVT_OPEN_LOG_FLAGS { /** Open a channel. */ public static final int EvtOpenChannelPath = 0x1; /** Open an exported log file. */ public static final int EvtOpenFilePath = 0x2; } /** * Defines the identifiers that identify the log file metadata properties of a channel or log file. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385536(v=vs.85).aspx */ public static interface EVT_LOG_PROPERTY_ID { /** * Identifies the property that contains the time that the channel or log file was created. The variant type * for this property is EvtVarTypeFileTime. */ public static final int EvtLogCreationTime = 0; /** * Identifies the property that contains the last time that the channel or log file was accessed. The variant * type for this property is EvtVarTypeFileTime. */ public static final int EvtLogLastAccessTime = 1; /** * Identifies the property that contains the last time that the channel or log file was written to. The variant * type for this property is EvtVarTypeFileTime. */ public static final int EvtLogLastWriteTime = 2; /** * Identifies the property that contains the size of the file, in bytes. The variant type for this property * is EvtVarTypeUInt64. */ public static final int EvtLogFileSize = 3; /** * Identifies the property that contains the file attributes (for details on the file attributes, * see the GetFileAttributesEx function). The variant type for this property is EvtVarTypeUInt32. */ public static final int EvtLogAttributes = 4; /** * Identifies the property that contains the number of records in the channel or log file. The variant type * for this property is EvtVarTypeUInt64. */ public static final int EvtLogNumberOfLogRecords = 5; /** * Identifies the property that contains the record number of the oldest event in the channel or log file. * The variant type for this property is EvtVarTypeUInt64. */ public static final int EvtLogOldestRecordNumber = 6; /** * Identifies the property that you use to determine whether the channel or log file is full. The variant type * for this property is EvtVarTypeBoolean. The channel is full if another event cannot be written to the channel * (for example, if the channel is sequential and maximum size is reached). The property will always be false if * the channel is circular or the sequential log is automatically backed up. */ public static final int EvtLogFull = 7; } /** * Defines values that indicate whether the events come from a channel or log file. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385522(v=vs.85).aspx */ public static interface EVT_EXPORTLOG_FLAGS { /** The source of the events is a channel. */ public static final int EvtExportLogChannelPath = 0x1; /** The source of the events is a previously exported log file. */ public static final int EvtExportLogFilePath = 0x2; /** * Export events even if part of the query generates an error (is not well formed). The service validates * the syntax of the XPath query to determine whether it is well formed. If the validation fails, the service * parses the XPath into individual expressions. It builds a new XPath beginning with the leftmost expression. * The service validates the expression and if it is valid, the service adds the next expression to the XPath. * The service repeats this process until it finds the expression that is failing. It then uses the valid * expressions as the XPath query (which means that you may not get the events that you expected). If no part of * the XPath is valid, the EvtExportLog call fails. */ public static final int EvtExportLogTolerateQueryErrors = 0x1000; /** no document */ public static final int EvtExportLogOverwrite = 0x2000; } /** * Defines the identifiers that identify the configuration properties of a channel. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385499(v=vs.85).aspx */ public static interface EVT_CHANNEL_CONFIG_PROPERTY_ID { /** * Identifies the enabled attribute of the channel. The variant type for this property is EvtVarTypeBoolean. * You cannot set this property for the Application, System, and Security channels. */ public static final int EvtChannelConfigEnabled = 0; /** * Identifies the isolation attribute of the channel. The variant type for this property is EvtVarTypeUInt32. * For possible isolation values, see the {@link Winevt.EVT_CHANNEL_ISOLATION_TYPE} enumeration. * You cannot set this property for the Application, System, and Security channels. */ public static final int EvtChannelConfigIsolation = 1; /** * Identifies the type attribute of the channel. The variant type for this property is EvtVarTypeUInt32. * For possible isolation values, see the {@link Winevt.EVT_CHANNEL_TYPE} enumeration. * You cannot set this property. */ public static final int EvtChannelConfigType = 2; /** * Identifies the name attribute of the provider that defined the channel. The variant type for this property * is EvtVarTypeString. You cannot set this property. */ public static final int EvtChannelConfigOwningPublisher = 3; /** * Identifies the configuration property that indicates whether the channel is a classic event channel * (for example the Application or System log). The variant type for this property is EvtVarTypeBoolean. * You cannot set this property. */ public static final int EvtChannelConfigClassicEventlog = 4; /** * Identifies the access attribute of the channel. The variant type for this property is EvtVarTypeString. */ public static final int EvtChannelConfigAccess = 5; /** * Identifies the retention logging attribute of the channel. The variant type for this property is * EvtVarTypeBoolean. */ public static final int EvtChannelLoggingConfigRetention = 6; /** * Identifies the autoBackup logging attribute of the channel. The variant type for this property is * EvtVarTypeBoolean. */ public static final int EvtChannelLoggingConfigAutoBackup = 7; /** * Identifies the maxSize logging attribute of the channel. The variant type for this property is * EvtVarTypeUInt64. */ public static final int EvtChannelLoggingConfigMaxSize = 8; /** * Identifies the configuration property that contains the path to the file that backs the channel. * The variant type for this property is EvtVarTypeString. */ public static final int EvtChannelLoggingConfigLogFilePath = 9; /** * Identifies the level publishing attribute of the channel. The variant type for this property is * EvtVarTypeUInt32. * To set this property, you must first disable the debug or analytic channel. */ public static final int EvtChannelPublishingConfigLevel = 10; /** * Identifies the keywords publishing attribute of the channel. The variant type for this property is * EvtVarTypeUInt64. * To set this property, you must first disable the debug or analytic channel. */ public static final int EvtChannelPublishingConfigKeywords = 11; /** * Identifies the controlGuid publishing attribute of the channel. The variant type for this property is * EvtVarTypeGuid. * You cannot set this property. */ public static final int EvtChannelPublishingConfigControlGuid = 12; /** * Identifies the bufferSize publishing attribute of the channel. The variant type for this property is * EvtVarTypeUInt32. * You cannot set this property. */ public static final int EvtChannelPublishingConfigBufferSize = 13; /** * Identifies the minBuffers publishing attribute of the channel. The variant type for this property is * EvtVarTypeUInt32. You cannot set this property. */ public static final int EvtChannelPublishingConfigMinBuffers = 14; /** * Identifies the maxBuffers publishing attribute of the channel. The variant type for this property is * EvtVarTypeUInt32. * You cannot set this property. */ public static final int EvtChannelPublishingConfigMaxBuffers = 15; /** * Identifies the latency publishing attribute of the channel. The variant type for this property is * EvtVarTypeUInt32. * You cannot set this property. */ public static final int EvtChannelPublishingConfigLatency = 16; /** * Identifies the clockType publishing attribute of the channel. The variant type for this property is * EvtVarTypeUInt32. For possible clock type values, see the {@link Winevt.EVT_CHANNEL_CLOCK_TYPE} enumeration. * You cannot set this property. */ public static final int EvtChannelPublishingConfigClockType = 17; /** * Identifies the sidType publishing attribute of the channel. The variant type for this property is * EvtVarTypeUInt32. For possible SID type values, see the {@link Winevt.EVT_CHANNEL_SID_TYPE} enumeration. * You cannot set this property. */ public static final int EvtChannelPublishingConfigSidType = 18; /** * Identifies the configuration property that contains the list of providers that import this channel. * The variant type for this property is EvtVarTypeString | EVT_VARIANT_TYPE_ARRAY. * You cannot set this property. */ public static final int EvtChannelPublisherList = 19; /** * Identifies the fileMax publishing attribute of the channel. The variant type for this property is * EvtVarTypeUInt32. */ public static final int EvtChannelPublishingConfigFileMax = 20; /** * This enumeration value marks the end of the enumeration values. */ public static final int EvtChannelConfigPropertyIdEND = 21; } /** * Defines the type of a channel. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385514(v=vs.85).aspx */ public static interface EVT_CHANNEL_TYPE { /** The channel's type is Admin. */ public static final int EvtChannelTypeAdmin = 0; /** The channel's type is Operational. */ public static final int EvtChannelTypeOperational = 1; /** The channel's type is Analytic. */ public static final int EvtChannelTypeAnalytic = 2; /** The channel's type is Debug. */ public static final int EvtChannelTypeDebug = 3; } /** * Defines the default access permissions to apply to the channel. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385502(v=vs.85).aspx */ public static interface EVT_CHANNEL_ISOLATION_TYPE { /** Provides open access to the channel. */ public static final int EvtChannelIsolationTypeApplication = 0; /** * Provides restricted access to the channel and is used by applications running under system service accounts, * drivers, or an application that logs events that relate to the health of the computer. */ public static final int EvtChannelIsolationTypeSystem = 1; /** Provides custom access to the channel. */ public static final int EvtChannelIsolationTypeCustom = 2; } /** * Defines the values that specify the type of time stamp to use when logging events channel. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385493(v=vs.85).aspx */ public static interface EVT_CHANNEL_CLOCK_TYPE { /** * Uses the system time for the time stamp. The system time provides a low-resolution (10 milliseconds) time * stamp but is comparatively less expensive to retrieve. System time is the default. Note that if the volume * of events is high, the resolution for system time may not be fine enough to determine the sequence of events. * If multiple events contain the same time stamp, the events may be delivered in the wrong order. */ public static final int EvtChannelClockTypeSystemTime = 0; /** * Uses the query performance counter (QPC) for the time stamp. The QPC time stamp provides a high-resolution * (100 nanoseconds) time stamp but is comparatively more expensive to retrieve. You should use this resolution * if you have high event rates or if the consumer merges events from different buffers. Note that on older * computers, the time stamp may not be accurate because the counter sometimes skips forward due to hardware * errors. */ public static final int EvtChannelClockTypeQPC = 1; } /** * Defines the values that determine whether the event includes the security identifier (SID) of the principal * that logged the event. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385511(v=vs.85).aspx */ public static interface EVT_CHANNEL_SID_TYPE { /** Do not include with the event the SID of the principal that logged the event. */ public static final int EvtChannelSidTypeNone = 0; /** Include with the event the SID of the principal that logged the event. */ public static final int EvtChannelSidTypePublishing = 1; } /** * Defines the values that specify how a channel is referenced. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385507(v=vs.85).aspx */ public static interface EVT_CHANNEL_REFERENCE_FLAGS { /** Specifies that the channel is imported. */ public static final int EvtChannelReferenceImported = 0x1; } /** * Defines the identifiers that identify the metadata properties of a provider. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385545(v=vs.85).aspx */ public static interface EVT_PUBLISHER_METADATA_PROPERTY_ID { /** * Identifies the guid attribute of the provider. The variant type for this property is EvtVarTypeGuid. */ public static final int EvtPublisherMetadataPublisherGuid = 0; /** * Identifies the resourceFilePath attribute of the provider. The variant type for this property is * EvtVarTypeString. */ public static final int EvtPublisherMetadataResourceFilePath = 1; /** * Identifies the parameterFilePath attribute of the provider. The variant type for this property is * EvtVarTypeString. */ public static final int EvtPublisherMetadataParameterFilePath = 2; /** * Identifies the messageFilePath attribute of the provider. The variant type for this property is * EvtVarTypeString. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385545(v=vs.85).aspx */ public static final int EvtPublisherMetadataMessageFilePath = 3; /** * Identifies the helpLink attribute of the provider. The variant type for this property is EvtVarTypeString. */ public static final int EvtPublisherMetadataHelpLink = 4; /** * Identifies the message attribute of the provider. The metadata is the resource identifier assigned to * the message string. To get the message string, call the {@link Wevtapi#EvtFormatMessage} function. * The variant type for this property is EvtVarTypeUInt32. If the provider does not specify a message, * the value is -1. */ public static final int EvtPublisherMetadataPublisherMessageID = 5; /** * Identifies the channels child element of the provider. The variant type for this property is * EvtVarTypeEvtHandle. To access the metadata of the channels that the provider defines or imports, use this * handle when calling the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * When you are done with the handle, call the {@link Wevtapi#EvtClose} function. */ public static final int EvtPublisherMetadataChannelReferences = 6; /** * Identifies the name attribute of the channel. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. The variant type for * this property is EvtVarTypeString. */ public static final int EvtPublisherMetadataChannelReferencePath = 7; /** * Identifies the zero-based index value of the channel in the list of channels. Use this identifier when * calling the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. The variant type * for this property is EvtVarTypeUInt32. */ public static final int EvtPublisherMetadataChannelReferenceIndex = 8; /** * Identifies the value attribute of the channel. Use this identifier when calling * the ${@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. The variant type for * this property is EvtVarTypeUInt32. */ public static final int EvtPublisherMetadataChannelReferenceID = 9; /** * Identifies the flags value that indicates whether this channel is imported from another provider. The channel * is imported if the EvtChannelReferenceImported flag value is set. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * The variant type for this property is EvtVarTypeUInt32. */ public static final int EvtPublisherMetadataChannelReferenceFlags = 10; /** * Identifies the message attribute of the channel. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. The variant type for * this property is EvtVarTypeUInt32. The property contains the resource identifier that is assigned to * the message string. To get the message string, call the EvtFormatMessage function. * If the channel does not specify a message, the value is -1. */ public static final int EvtPublisherMetadataChannelReferenceMessageID = 11; /** * Identifies the levels child element of the provider. The variant type for this property is * EvtVarTypeEvtHandle. To access the metadata of the levels that the provider defines or references, * use this handle when calling the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, * see Remarks. When you are done with the handle, call the {@link Wevtapi#EvtClose} function. */ public static final int EvtPublisherMetadataLevels = 12; /** * Identifies the name attribute of the level. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * The variant type for this property is EvtVarTypeString. */ public static final int EvtPublisherMetadataLevelName = 13; /** * Identifies the value attribute of the level. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. The variant type for * this property is EvtVarTypeUInt32. */ public static final int EvtPublisherMetadataLevelValue = 14; /** * Identifies the message attribute of the level. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. The variant type for * this property is EvtVarTypeUInt32. The property contains the resource identifier that is assigned to * the message string. To get the message string, call the {@link Wevtapi#EvtFormatMessage} function. * If the level does not specify a message, the value is -1. */ public static final int EvtPublisherMetadataLevelMessageID = 15; /** * Identifies the tasks child element of the provider. The variant type for this property is * EvtVarTypeEvtHandle. To access the metadata of the tasks that the provider defines, use this handle when * calling the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * When you are done with the handle, call the {@link Wevtapi#EvtClose} function. */ public static final int EvtPublisherMetadataTasks = 16; /** * Identifies the name attribute of the task. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * The variant type for this property is EvtVarTypeString. */ public static final int EvtPublisherMetadataTaskName = 17; /** * Identifies the eventGuid attribute of the task. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * The variant type for this property is EvtVarTypeString. */ public static final int EvtPublisherMetadataTaskEventGuid = 18; /** * Identifies the value attribute of the task. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * The variant type for this property is EvtVarTypeUInt32. */ public static final int EvtPublisherMetadataTaskValue = 19; /** * Identifies the message attribute of the task. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * The variant type for this property is EvtVarTypeUInt32. The property contains the resource identifier * that is assigned to the message string. To get the message string, call the {@link Wevtapi#EvtFormatMessage} * function. If the task does not specify a message, the value is -1. */ public static final int EvtPublisherMetadataTaskMessageID = 20; /** * Identifies the opcodes child element of the provider. The variant type for this property is * EvtVarTypeEvtHandle. To access the metadata of the opcodes that the provider defines or references, * use this handle when calling the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, * see Remarks. When you are done with the handle, call the {@link Wevtapi#EvtClose} function. */ public static final int EvtPublisherMetadataOpcodes = 21; /** * Identifies the name attribute of the opcode. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * The variant type for this property is EvtVarTypeString. */ public static final int EvtPublisherMetadataOpcodeName = 22; /** * Identifies the value attribute of the opcode. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. The variant type for * this property is EvtVarTypeUInt32. The high word contains the opcode value and the low word contains the task * to which it belongs. If the low word is zero, the opcode is defined globally; otherwise, the opcode is task * specific. Use the low word value to determine the task that defines the opcode. */ public static final int EvtPublisherMetadataOpcodeValue = 23; /** * Identifies the message attribute of the opcode. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. The variant type for * this property is EvtVarTypeUInt32. The property contains the resource identifier that is assigned to * the message string. To get the message string, call the {@link Wevtapi#EvtFormatMessage} function. * If the opcode does not specify a message, the value is -1. */ public static final int EvtPublisherMetadataOpcodeMessageID = 24; /** * Identifies the keywords child element of the provider. The variant type for this property is * EvtVarTypeEvtHandle. To access the metadata of the keywords that the provider defines, use this handle when * calling the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. When you are done * with the handle, call the {@link Wevtapi#EvtClose} function. */ public static final int EvtPublisherMetadataKeywords = 25; /** * Identifies the name attribute of the keyword. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * The variant type for this property is EvtVarTypeString. */ public static final int EvtPublisherMetadataKeywordName = 26; /** * Identifies the mask attribute of the keyword. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. * The variant type for this property is EvtVarTypeUInt64. */ public static final int EvtPublisherMetadataKeywordValue = 27; /** * Identifies the message attribute of the keyword. Use this identifier when calling * the {@link Wevtapi#EvtGetObjectArrayProperty} function. For details, see Remarks. The variant type for * this property is EvtVarTypeUInt32. The property contains the resource identifier that is assigned to * the message string. To get the message string, call the {@link Wevtapi#EvtFormatMessage} function. * If the keyword does not specify a message, the value is -1. */ public static final int EvtPublisherMetadataKeywordMessageID = 28; /** This enumeration value marks the end of the enumeration values. */ public static final int EvtPublisherMetadataPropertyIdEND = 29; } /** * Defines the identifiers that identify the metadata properties of an event definition. * * @see MSDN */ public static interface EVT_EVENT_METADATA_PROPERTY_ID { /** * Identifies the value attribute of the event definition. The variant type for this property is * EvtVarTypeUInt32. */ public static final int EventMetadataEventID = 0; /** * Identifies the version attribute of the event definition. The variant type for this property is * EvtVarTypeUInt32. */ public static final int EventMetadataEventVersion = 1; /** * Identifies the channel attribute of the event definition. The variant type for this property is * EvtVarTypeUInt32. This property does not contain the channel identifier that you specified in the event * definition but instead contains the value attribute of the channel. The value is zero if the event * definition does not specify a channel. */ public static final int EventMetadataEventChannel = 2; /** * Identifies the level attribute of the event definition. The variant type for this property is * EvtVarTypeUInt32. This property does not contain the level name that you specified in the event definition * but instead contains the value attribute of the level. The value is zero if the event definition does not * specify a level. */ public static final int EventMetadataEventLevel = 3; /** * Identifies the opcode attribute of the event definition. The variant type for this property is * EvtVarTypeUInt32. This property does not contain the opcode name that you specified in the event definition * but instead contains the value attribute of the opcode. The value is zero if the event definition does not * specify an opcode. */ public static final int EventMetadataEventOpcode = 4; /** * dentifies the task attribute of the event definition. The variant type for this property is EvtVarTypeUInt32. * This property does not contain the task name that you specified in the event definition but instead contains * the value attribute of the task. The value is zero if the event definition does not specify a task. */ public static final int EventMetadataEventTask = 5; /** * Identifies the keyword attribute of the event definition. The variant type for this property is * EvtVarTypeUInt64. This property does not contain the list of keyword names that you specified in the event * definition but instead contains a 64-bitmask of all the keywords. The top 16 bits of the mask are reserved * for internal use and should be ignored when determining the keyword bits that the event definition set. */ public static final int EventMetadataEventKeyword = 6; /** * Identifies the message attribute of the event definition. The variant type for this property is * EvtVarTypeUInt32. The property contains the resource identifier that is assigned to the message string. * To get the message string, call the EvtFormatMessage function. If the event definition does not specify * a message, the value is -1. */ public static final int EventMetadataEventMessageID = 7; /** * Identifies the template attribute of the event definition. The variant type for this property is * EvtVarTypeString. This property does not contain the template name that you specified in the event definition * but instead contains an XML string that includes the template node and each data node; the string does not * include the UserData. The value is an empty string if the event definition does not specify a template. */ public static final int EventMetadataEventTemplate = 8; /** This enumeration value marks the end of the enumeration values. */ public static final int EvtEventMetadataPropertyIdEND = 9; } /** * Defines the identifiers that identify the query information that you can retrieve. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa820607(v=vs.85).aspx */ public static interface EVT_QUERY_PROPERTY_ID { /** * Identifies the property that contains the list of channel or log file names that are specified in the query. * The variant type for this property is EvtVarTypeString | EVT_VARIANT_TYPE_ARRAY. */ public static final int EvtQueryNames = 0; /** * Identifies the property that contains the list of Win32 error codes that correspond directly to the list of * channel or log file names that the EvtQueryNames property returns. The error codes indicate the success or * failure of the query for the specific channel or log file. The variant type for this property is * EvtVarTypeUInt32 | EVT_VARIANT_TYPE_ARRAY. */ public static final int EvtQueryStatuses = 1; /** This enumeration value marks the end of the enumeration values. */ public static final int EvtQueryPropertyIdEND = 2; } /** * Defines the values that determine the query information to retrieve. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385600(v=vs.85).aspx */ public static interface EVT_EVENT_PROPERTY_ID { /** * Not supported. The identifier of the query that selected the event. The variant type of this property is * EvtVarTypeInt32. */ public static final int EvtEventQueryIDs = 0; /** * The channel or log file from which the event came. The variant type of this property is EvtVarTypeString. */ public static final int EvtEventPath = 1; /** * This enumeration value marks the end of the enumeration values. It can be used to exit a loop when retrieving * all the properties. */ public static final int EvtEventPropertyIdEND = 2; } /** * Read access control permission that allows information to be read from an event log. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385781(v=vs.85).aspx */ public static final int EVT_READ_ACCESS = 0x1; /** * Write access control permission that allows information to be written to an event log. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385781(v=vs.85).aspx */ public static final int EVT_WRITE_ACCESS = 0x2; /** * All (read, write, clear, and delete) access control permission. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385781(v=vs.85).aspx */ public static final int EVT_ALL_ACCESS = 0x7; /** * Clear access control permission that allows all information to be cleared from an event log. * https://msdn.microsoft.com/en-us/library/windows/desktop/aa385781(v=vs.85).aspx */ public static final int EVT_CLEAR_ACCESS = 0x4; public class EVT_HANDLE extends HANDLE { public EVT_HANDLE() { } public EVT_HANDLE(Pointer p) { super(p); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy