Update create_certs.py
This commit is contained in:
@@ -1,28 +0,0 @@
|
|||||||
import pandas as pd
|
|
||||||
|
|
||||||
df = pd.read_csv('GhostPath_URLS.csv', header=None,
|
|
||||||
names=['country', 'city', 'url'])
|
|
||||||
|
|
||||||
df['location'] = (df['country'].map(str) + '-' + df['city']).map(
|
|
||||||
lambda x: x.replace(' ', '-'))
|
|
||||||
|
|
||||||
urls_by_location = df.groupby('location')['url'].apply(list).reset_index()
|
|
||||||
|
|
||||||
tail = """
|
|
||||||
auth-user-pass /config/openvpn-credentials.txt
|
|
||||||
client
|
|
||||||
redirect-gateway
|
|
||||||
remote-cert-tls server
|
|
||||||
cipher AES-256-CBC
|
|
||||||
proto udp
|
|
||||||
dev tun
|
|
||||||
nobind
|
|
||||||
ca /etc/openvpn/ghostpath/ca.crt
|
|
||||||
"""
|
|
||||||
def create_cert(row):
|
|
||||||
with open(f'{row["location"]}.ovpn', 'w') as f:
|
|
||||||
for url in row['url']:
|
|
||||||
f.write(f'remote {url} 443 udp\n')
|
|
||||||
f.write(tail)
|
|
||||||
|
|
||||||
urls_by_location.apply(create_cert, axis=1)
|
|
48
openvpn/ghostpath/create-certs/create_certs.py
Normal file
48
openvpn/ghostpath/create-certs/create_certs.py
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
'''This code reads in "GhostPath_URLS.csv"
|
||||||
|
(which was copied from https://ghostpath.com/servers)
|
||||||
|
in order to create basic ovpn files for all the different instances
|
||||||
|
It requires pandas and python 3.6 or greater.
|
||||||
|
'''
|
||||||
|
import pandas as pd
|
||||||
|
|
||||||
|
TAIL = '''
|
||||||
|
auth-user-pass /config/openvpn-credentials.txt
|
||||||
|
client
|
||||||
|
redirect-gateway
|
||||||
|
remote-cert-tls server
|
||||||
|
cipher AES-256-CBC
|
||||||
|
proto udp
|
||||||
|
dev tun
|
||||||
|
nobind
|
||||||
|
ca /etc/openvpn/ghostpath/ca.crt
|
||||||
|
'''
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
|
||||||
|
# Read in teh CSV
|
||||||
|
df = pd.read_csv('GhostPath_URLS.csv', header=None,
|
||||||
|
names=['country', 'city', 'url'])
|
||||||
|
|
||||||
|
# Create a new column `locations` with the stringized file names
|
||||||
|
df['location'] = (df['country'].map(str) + '-' + df['city']).map(
|
||||||
|
lambda x: x.replace(' ', '-'))
|
||||||
|
|
||||||
|
# Group by locations and create lists of all the urls for each location
|
||||||
|
urls_by_location = df.groupby('location')['url'].apply(list).reset_index()
|
||||||
|
|
||||||
|
def create_cert(row):
|
||||||
|
'''
|
||||||
|
Creates a file with the location name and the urls with the `TAIL`
|
||||||
|
'''
|
||||||
|
with open(f'{row["location"]}.ovpn', 'w') as f:
|
||||||
|
for url in row['url']:
|
||||||
|
f.write(f'remote {url} 443 udp\n')
|
||||||
|
f.write(TAIL)
|
||||||
|
|
||||||
|
# Save the files for each location
|
||||||
|
urls_by_location.apply(create_cert, axis=1)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
Reference in New Issue
Block a user