From 9aec4969cd24cc9d6688b0c8f4a58beadde954ca Mon Sep 17 00:00:00 2001 From: Michael <886344+codingo@users.noreply.github.com> Date: Mon, 9 Apr 2018 14:33:42 +1000 Subject: [PATCH] Update CONTRIBUTING.md --- CONTRIBUTING.md | 29 ++++++++++++++--------------- 1 file changed, 14 insertions(+), 15 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 40218f1..ae654a2 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -6,32 +6,32 @@ The follwing is a document describing the project structure of SubFinder subdoma ### Project Structure -SubFinder is written in golang. In order to contribute, you must have at least a little knowledge of golang. The authors have tried to keep the code as -simple and modular as possible. There can be flaws in the golang implementation or there may be many things which could be done better. If you find any such things, please -create an issue and we would be more than happy to implement your suggestions. A Pull Request would be more than appreciated :+1:. - -TThe document assumes you have installed SubFinder and are already loving it. +SubFinder is written in golang. The authors have tried to keep the code as simple and modular as possible. There can be flaws in the golang implementation or there may be many things which have identified that could be done better. Regardless, please +create an issue and we would be more than happy to implement your suggestions. Pull Requests are also very appreciated :+1:. +Core structure of the code is as follows: ``` subfinder - |-/libsubfinder-|-/sources|-/ask |-main.go -/crtsh |-config.json -/certspotter ``` -TODO :d + +Comments can be found throughout the majority of the code base explaining functionality of usage. ### Adding new Passive Sources Adding new passive sources to the tool is very easy. Every passive subdomain data source has it's own subpackge under `subfinder/libsubfinder/sources` package. -In order to add a new source, just create a new directory. For Example, if we are going to add `example` data source, these are the steps for that. + +In order to add a new source, just create a new directory. For Example, if we are going to add `example` data source, these are the steps involved: - Create `subfinder/libsubfinder/sources/example` directory. - Create a main file for your subpackage. For example, `example.go`. - Add `package example` to the top of the file as package name. -Passive sources follow a similar convention in SubFinder. Each passive source exports all its functionality through a Query function. -You can have as many functions in your data source but a main Query function is mandatory. It takes the current program state which is exported as -`subfinder/libsubfinder/helper.State` variable. It contains all your program state. Another argument it takes is a channel which is of type `subfinder/libsubfinder/helper.Result`. +Passive sources follow a similar convention in SubFinder. Each passive source exports all its functionality through a ```Query``` function. +You can have as many functions in your data source but a main ```Query``` function is mandatory. It takes the current program state which is exported as a ```subfinder/libsubfinder/helper.State``` variable. This contains all of your program state. Another argument it takes is a channel which is of type ```subfinder/libsubfinder/helper.Result```. + This channel will be used to return a type result which contains the results from our current run. The structure is something like this. ```golang type Result struct { @@ -41,15 +41,14 @@ type Result struct { ``` Each package must import helper package. A template for a basic data source is given in example data source. Feel free to modify it. -After making your changes, open the `subfinder/libsubfinder/engines/passive/passive.go` which is the main driver for passive discovery engine. +After making your changes, open the ```subfinder/libsubfinder/engines/passive/passive.go``` which is the main driver for passive discovery engine. - Import your example package in that file. `"subfinder/libsubfinder/sources/example"` -- Add a print functions with other printing functions already there `fmt.Printf("\n[-] Searching For Subdomains in PassiveTotal")` -- Create a goquery for your example `go example.Query(state, ch)` +- Add a print functions with other printing functions already there ```fmt.Printf("\n[-] Searching For Subdomains in PassiveTotal")` +- Create a goquery for your example `go example.Query(state, ch)``` - Increase number of sources by 1 in argument to buffered chanel and for loop for recieving results. -And you have created your own passive package. -Feel free to make a Pull Request and we'd be more than happy to add your changes and acknowledge you :+1: +And you will then have created your own passive package! Feel free to make a Pull Request and we'd be more than happy to add your changes and acknowledge you! :+1: