forked from cenx1/msaccess-devops
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathApplication.vbs
144 lines (118 loc) · 4.59 KB
/
Application.vbs
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
'---------------------------------------------------------------------------------------
' Application : Script to launch Access Database (Installed via ClickOnce)
' Author : Adam Waller
' Date : 8/25/2017
'---------------------------------------------------------------------------------------
'=================================================
' ** SET THESE PARAMETERS **
'=================================================
Const strAppName = "Contacts CRM"
Const strAppFile = "Contacts CRM.accdb"
'=================================================
' Set application as trusted.
VerifyTrustedLocation strAppName
' Use Windows Shell to launch the application.
CreateObject("WScript.Shell").Run """" & MSAccessEXELocation & """ """ & ScriptPath & strAppFile & """ /runtime /cmd ""ojHYrvAwMudK8pezm7AR"""
Function MSAccessEXELocation()
Dim MSAccPath
Dim RegKey
Dim WSHShell
On Error Resume Next
RegKey = "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths\MSACCESS.EXE\Path"
Set WSHShell = WScript.CreateObject("WScript.Shell")
MSAccPath = WSHShell.RegRead(RegKey) & "MSACCESS.EXE"
If Err.Number <> 0 Then
RegKey = "HKEY_CLASSES_ROOT\Access.MDBFile\shell\New\command\"
MSAccPath = WSHShell.RegRead(RegKey)
MSAccPath = left(MSAccPath,instr(MSAccPath, "MSACCESS.EXE")-1)
MSAccPath = mid(MSAccPath, 2) & "MSACCESS.EXE"
End If
Set WSHShell = Nothing
MSAccessEXELocation = MSAccPath
End Function
'---------------------------------------------------------------------------------------
' Function : ScriptPath
' Author : Adam Waller
' Date : 2/8/2017
' Purpose : Get the path to the folder where this script is running.
'---------------------------------------------------------------------------------------
Function ScriptPath()
Dim oFSO
Dim oFile
Set oFSO = CreateObject("Scripting.FileSystemObject")
set oFile = oFSO.GetFile(Wscript.ScriptFullName)
ScriptPath = oFSO.GetParentFolderName(oFile) & "\"
Set oFSO = Nothing
End Function
'---------------------------------------------------------------------------------------
' Function : VerifyTrustedLocation
' Author : Adam Waller
' Date : 1/24/2017
' Purpose : Run this proceedure on startup to make sure the database is located
' : in a trusted location. (Adding an entry if needed.)
'---------------------------------------------------------------------------------------
'
Function VerifyTrustedLocation(strAppName)
Dim oShell
Dim oFSO
Dim oFile
Dim strVersion
Dim strPath
Dim strAppPath
Dim blnCreate
Dim strVal
Set oShell = CreateObject("WScript.Shell")
Set oFSO = CreateObject("Scripting.FileSystemObject")
' Get Access version
On Error Resume Next
strVal = oShell.RegRead("HKEY_CLASSES_ROOT\Access.Application\CurVer\")
If Err Then
Err.Clear
Else
' Parse the version number
strVal = Right(strVal, 2)
If IsNumeric(strVal) Then strVersion = strVal & ".0"
End If
On Error GoTo 0
' Make sure we actually found a version number
If Len(strVersion) <> 4 Then
MsgBox "Unable to determine Microsoft Access Version.", vbCritical
Exit Function
End If
' Get application name
'strAppName = Application.VBE.ActiveVBProject.Name
' Get registry path for trusted locations
strPath = "HKEY_CURRENT_USER\Software\Microsoft\Office\" & _
strVersion & "\Access\Security\Trusted Locations\" & strAppName & "\"
' Attempt to read the key
On Error Resume Next
strVal = oShell.RegRead(strPath & "Path")
If Err Then
Err.Clear
blnCreate = True
End If
On Error GoTo 0
' Get script location, to find application path
strAppPath = WScript.ScriptFullName
'strAppPath = CodeProject.Path & "\" & CodeProject.Name
Set oFile = oFSO.GetFile(strAppPath)
strAppPath = oFSO.GetParentFolderName(oFile)
If blnCreate = True Then
' Create values
oShell.RegWrite strPath & "Path", strAppPath
oShell.RegWrite strPath & "Date", Now()
oShell.RegWrite strPath & "Description", strAppName
oShell.RegWrite strPath & "AllowSubfolders", 1, "REG_DWORD"
Else
' Verify path location
strVal = oShell.RegRead(strPath & "Path")
If strVal <> strAppPath Then
' Update value
oShell.RegWrite strPath & "Path", strAppPath
oShell.RegWrite strPath & "Date", Now()
End If
End If
' Release references
Set oShell = Nothing
Set oFSO = Nothing
End Function