Asterisk Source
| Asterisk makefile ¶* _all: all
 * all: cleantest depend asterisk subdirs
 * cleantest:
 
cleantest:
        if cmp -s .cleancount .lastclean ; then echo ; else \
                $(MAKE) clean; cp -f .cleancount .lastclean;\
        fi
* depend:
 
depend: include/asterisk/version.h .depend defaults.h
        for x in $(SUBDIRS); do $(MAKE) -C $$x depend || exit 1 ; done
* asterisk:
 
asterisk: $(CYGLOADER) editline/libedit.a db1-ast/libdb1.a stdtime/libtime.a $(OBJS)
        build_tools/make_build_h > include/asterisk/build.h.tmp
        if cmp -s include/asterisk/build.h.tmp include/asterisk/build.h ; then echo ; else \
                mv include/asterisk/build.h.tmp include/asterisk/build.h ; \
        fi
        rm -f include/asterisk/build.h.tmp
        $(CC) -c -o buildinfo.o $(CFLAGS) buildinfo.c
        $(CC) $(DEBUG) $(ASTOBJ) $(ASTLINK) $(OBJS) buildinfo.o $(LIBEDIT) db1-ast/libdb1.a stdtime/libtime.a $(LIBS)
ASTOBJ=-o asterisk
OBJS=io.o sched.o logger.o frame.o loader.o config.o channel.o \
        translate.o file.o say.o pbx.o cli.o md5.o term.o \
        ulaw.o alaw.o callerid.o fskmodem.o image.o app.o \
        cdr.o tdd.o acl.o rtp.o manager.o asterisk.o \
        dsp.o chanvars.o indications.o autoservice.o db.o privacy.o \
        astmm.o enum.o srv.o dns.o aescrypt.o aestab.o aeskey.o \
        utils.o plc.o jitterbuf.o dnsmgr.o devicestate.o \
        netsock.o slinfactory.o ast_expr2.o ast_expr2f.o \
        cryptostub.o
* subdirs:
 
subdirs:
        for x in $(SUBDIRS); do $(MAKE) -C $$x || exit 1 ; done
 
 
 
 
 
 
 Asterisk Source ¶* acl.c
 Various sorts of access control* aescrypt.c This file contains the code for implementing encryption and decryption for AES (Rijndael) for block and key sizes of 16, 24 and 32 bytes. It can optionally be replaced by code written in assembler using NASM. For further details see the file aesopt.h* aeskey.c This file contains the code for implementing the key schedule for AES (Rijndael) for block and key sizes of 16, 24, and 32 bytes. See aesopt.h for further details including optimisation.* aestab.c * alaw.c
 u-Law to Signed linear conversion* app.c Convenient Application Routines* ast_expr2.c Written by Richard Stallman by simplifying the original so called ``semantic'' parser.* ast_expr2f.c 1.2. ¶Top level source file for Asterisk - the Open Source PBX. Implementation of PBX core functions and CLI interface. defaults.h:#define AST_CONFIG_FILE "/etc/asterisk/asterisk.conf" * ast_readconfig();
 
 [root@localhost asterisk]# asterisk -nvc Asterisk 1.2.4, Copyright (C) 1999 - 2006 Digium, Inc. and others. Created by Mark Spencer <markster@digium.com> Asterisk comes with ABSOLUTELY NO WARRANTY; type 'show warranty' for details. This is free software, with components licensed under the GNU General Public License version 2 and other licenses; you are welcome to redistribute it under certain conditions. Type 'show license' for details. ========================================================================= Asterisk Event Logger Started /var/log/asterisk/event_log Asterisk Dynamic Loader loading preload modules: Nov 26 13:51:28 NOTICE[11455]: cdr.c:1188 do_reload: CDR simple logging enabled.Asterisk PBX Core Initializing Registering builtin applications: [AbsoluteTimeout] [Answer] [BackGround] [Busy] [Congestion] [ImportVar] [Wait] [WaitExten] Asterisk Dynamic Loader Starting: [res_musiconhold.so] => (Music On Hold Resource) [res_adsi.so] => (ADSI Resource) [res_features.so] => (Call Features Resource) [app_url.so] => (Send URL Applications) [app_echo.so] => (Simple Echo Application) Asterisk Ready. *CLI>* init_logger() 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 astmm.c ¶Memory Management * autoservice.c
 Automatic channel service routines* buildinfo.c Build timestamp variables* callerid.c CallerID Generation support* cdr.c Call Detail Record API* channel.c Channel Management* chanvers.c Channel Variables* cli.c Standard Command Line Interface* config.c Configuration File Parser* cryptostub.c * db.c 
 ASTdb Management* devicestate.c Device state management* dlfcn.c * dns.c
 DNS Support for Asterisk* dnsmgr.c Background DNS update manager* dsp.c Convenience Signal Processing routines* enum.c ENUM Support for Asterisk* file.c Generic File Format Support.* frame.c Frame manipulation routines* fskmodem.c FSK Modulator/Demodulator* image.c Image Management* indications.c Tone Management* io.c I/O Managment (Derived from Cheops-NG)* jitterbuf.c jitterbuf: an application-independent jitterbuffer* loader.c Module Loader* logger.c Asterisk Logger* manager.c The Asterisk Management Interface - AMI* md5.c * muted.c
 Mute Daemon Specially written for Malcolm Davenport, but I think I'll use it too * Connects to the Asterisk Manager Interface, AMI, and listens for events * on certain devices. If a phone call is connected to one of the devices (phones) * the local sound is muted to a lower volume during the call.* netsock.c Network socket handling* pbx.c Core PBX routines.* plc.c SpanDSP - a series of DSP components for telephony* poll.c select(2)-based poll() emulation function for BSD systems.* privacy.c Privacy Routines* rtp.c Supports RTP and RTCP with Symmetric RTP support for NAT traversal.* say.c Say numbers and dates (maybe words one day too)* sched.c Scheduler Routines (from cheops-NG)* slinfactory.c A machine to gather up arbitrary frames and convert them to raw slinear on demand.* srv.c DNS SRV Record Lookup Support for Asterisk* strcompat.c Compatibility functions for strsep and strtoq missing on Solaris* tdd.c TTY/TDD Generation support* term.c Terminal Routines* translate.c Translate via the use of pseudo channels* ulaw.c u-Law to Signed linear conversion* utils.c Utility functions These are important for portability and security, so please use them in favour of other routines. Please consult the CODING GUIDELINES for more information. apps ¶* Where application modules are stored. This document will cover writing your own apps in a later section. 
 
    *  int load_module(void) This function is called when the module is loaded by the Asterisk Core. In this function you need to call functions such as ast_custom_function_register() to let Asterisk know exactly what services your module provides. Return 0 on success and non-zero on failure.
    * int unload_module(void) This function will be called when Asterisk is getting ready to unload your module. In this function, you should unregister any of your modules services and send soft hangups to any channels that are using your module. Return 0 on success, and non-zero upon failure. A failure will indicate to Asterisk that it is not possible at the moment to unload your module.
    * int usecount(void) Returns the number of threads, channels, etc. that are using your module. This will be shown in the output of CLI commands such as show modules. It is your responsibility to keep track of this number and hangup anything using your module upon unload. Asterisk has helper macros for this that will be described later. In some cases, when your module only provides a service for a very short time, you shouldn't need to worry about user counting. For example, pbx_functions.c always returns 0 when usecount(). In modules such as app_dial.c, user counting is very important because channels will spend most of their time under the control the app_dial.so module.
    * char *description(void) Returns a short, description of what the module does. This will be shown in the output of CLI commands such as show modules.
    * int reload(void) *Optional* This is called if someone types reload your_module.so or reload on the command line. This will give you the opportunity to have your module reload and re-cache any external data such as a configuration file. This is a good alternative to unloading and loading a module because any channels using your module will not need to be hung up. Return 0 on success and non-zero on failure.
    * char *key(void) This function should be programmed to return the value of ASTERISK_GPL_KEY which forces you to state that your extension is licensed under the GNU General Public License. If you are using the free edition of Asterisk and your module does not return ASTERISK_GPL_KEY verbatim, the module will not load. This feature was implemented because Asterisk is dual-licensed and needs a safe-guard to ensure that non-free modules written for Business Edition are not linked against the free edition of Asterisk. There will be more about this in the legal section.
* app_voicemail.c
 static char charset[32] = "ISO-8859-1"; sendmail get_folder get_folder2 notify_new_message forward_message vm_intro_en vm_instructions vm_options vm_authenticate vm_execmain load_config play_record_review * get_folder2
 
 
 
 adsi_logo, adsi_load_vmail, adsi_begin, adsi_login adsi_password, adsi_folders, adsi_message, adsi_delete adsi_status, adsi_status2, adsi_clear, adsi_goodbye res/res_adsi.c include/asterisk/adsi.h channels ¶* This is where the source lies for defining channel protocols such as SIP and IAX2. These modules register the channel protocol (known by Asterisk terminology as a "switch") with pbx.c by calling ast_register_switch(). 
 * chan_zap.c
 
 channel.h:#define AST_STATE_DOWN 0 channel.h:#define AST_STATE_RESERVED 1 channel.h:#define AST_STATE_OFFHOOK 2 channel.h:#define AST_STATE_DIALING 3 channel.h:#define AST_STATE_RING 4 channel.h:#define AST_STATE_RINGING 5 channel.h:#define AST_STATE_UP 6 channel.h:#define AST_STATE_BUSY 7 channel.h:#define AST_STATE_DIALING_OFFHOOK 8 channel.h:#define AST_STATE_PRERING 9 channel.h:#define AST_STATE_MUTE (1 << 16) * static int zt_call(struct ast_channel *ast, char *rdest, int timeout)
 
        if ((ast->_state == AST_STATE_BUSY)) {
                p->subs[SUB_REAL].needbusy = 1;
                ast_mutex_unlock(&p->lock);
                return 0;
        }
        if ((ast->_state != AST_STATE_DOWN) && (ast->_state != AST_STATE_RESERVED)) {
                ast_log(LOG_WARNING, "zt_call called on %s, neither down nor reserved\n", ast->name);
                ast_mutex_unlock(&p->lock);
                return -1;
        }
        switch(p->sig) {
        case SIG_FXOLS:
        case SIG_FXOGS:
        case SIG_FXOKS:
                ast_setstate(ast, AST_STATE_RINGING);
        case SIG_FXSLS:
        case SIG_FXSGS:
        case SIG_FXSKS:
                ast_setstate(ast, AST_STATE_DIALING);
        case 0:
                ast_setstate(ast, AST_STATE_UP);
 
        ast_setstate(ast, AST_STATE_UP);
* static struct ast_frame *zt_handle_event(struct ast_channel *ast)
 
 zaptel.h:#define ZT_EVENT_NONE 0 zaptel.h:#define ZT_EVENT_ONHOOK 1 zaptel.h:#define ZT_EVENT_RINGOFFHOOK 2 zaptel.h:#define ZT_EVENT_WINKFLASH 3 zaptel.h:#define ZT_EVENT_ALARM 4 zaptel.h:#define ZT_EVENT_NOALARM 5 zaptel.h:#define ZT_EVENT_ABORT 6 zaptel.h:#define ZT_EVENT_OVERRUN 7 zaptel.h:#define ZT_EVENT_BADFCS 8 zaptel.h:#define ZT_EVENT_DIALCOMPLETE 9 zaptel.h:#define ZT_EVENT_RINGERON 10 zaptel.h:#define ZT_EVENT_RINGEROFF 11 zaptel.h:#define ZT_EVENT_HOOKCOMPLETE 12 zaptel.h:#define ZT_EVENT_BITSCHANGED 13 zaptel.h:#define ZT_EVENT_PULSE_START 14 zaptel.h:#define ZT_EVENT_TIMER_EXPIRED 15 zaptel.h:#define ZT_EVENT_TIMER_PING 16 zaptel.h:#define ZT_EVENT_RINGBEGIN 18 zaptel.h:#define ZT_EVENT_POLARITY 17 zaptel.h:#define ZT_EVENT_PULSEDIGIT (1 << 16) /* This is OR'd with the digit received */ zaptel.h:#define ZT_EVENT_DTMFDOWN (1 << 17) /* Ditto for DTMF key down event */ zaptel.h:#define ZT_EVENT_DTMFUP (1 << 18) /* Ditto for DTMF key up event */ * static struct ast_frame *__zt_exception(struct ast_channel *ast)
 * struct ast_frame  *zt_read(struct ast_channel *ast)
 * static int zt_indicate(struct ast_channel *chan, int condition)
 * static struct ast_channel *zt_new(struct zt_pvt *i, int state, int startpbx, int index, int law, int transfercapability)
 * static void *ss_thread(void *data)
 codecs ¶* This is where the source for codecs such as ¥ì-law and GSM are stored. Codecs are encoding and compression algorithms utilized by switches. Although there are many types of switches, they all have the ability to use the same codecs. The core encoding method for Asterisk is AST_FORMAT_SLINEAR, in which non-compressed audio is sampled 8000 times a second, with 16-bit signed samples. Codecs call ast_register_translator() to provide Asterisk with callbacks to translate voice frames from SLINEAR (and others) to and from the codec. Constant IDs for codec formats are stored in asterisk/frame.h as well as a few other random places. 
 formats ¶* Formats are very similar to codecs, but they are used to read sound files. All formats register with the Asterisk core by calling ast_format_register().
 funcs ¶* Where custom dial plan function modules are stored. Custom functions are registered with ast_custom_function_register(). 
 zaptel ¶* fxo
 
 
 
 
 #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,10) #define zap_pci_module pci_register_driver #else #define zap_pci_module pci_module_init #endif* Makefile 
 
 
 
struct tone_zone {
        int zone;                                       /* Zone number */
        char country[10];                       /* Country code */
        char description[40];           /* Description */
        int ringcadence[ZT_MAX_CADENCE];        /* Ring cadence */
        struct tone_zone_sound tones[ZT_TONE_MAX];
};
* zonedata.c
 http://www.itu.int/ITU-T/inr/forms/files/tones-0203.pdf Korea (Republic of) Busy tone - 480+620 0.5 on 0.5 off Congestion tone - 480+620 0.3 on 0.2 off Dial tone - 350+440 continuous Recall dial tone - I 400//450 1.0 on 4.0 off Recall dial tone - II 400//450 1.0 on 2.0 off Intercept tone - 350+440 0.125 on 0.25 off 0.125 on 1.5 off Annex to ITU OB 781-E 14 COUNTRY/TONE FREQUENCY in Hz CADENCE in seconds Number unobtainable tone - 450 0.2 on 0.1 off 0.2 on 1.5 off Ringing tone - 440+480 1.0 on 2.0 off Warning tone - operator intervening 392/494/587 2x(0.5 on 0.5 on 1.5 on) Waiting tone - 350+440 0.25 on 0.25 off 0.25 on 3.25 off A "stuttered" or interrupted dial tone may mean that there is voice mail waiting, or may occur to confirm that a calling feature such as call forwarding has been activated. chan_zap ¶setup_zap(0) ¶
 
struct ast_category {
        char name[80];
        int ignored;                    /* do not let user of the config see this category */
        struct ast_variable *root;
        struct ast_variable *last;
        struct ast_category *next;
};
struct ast_config {
        struct ast_category *root;
        struct ast_category *last;
        struct ast_category *current;
        struct ast_category *last_browse;               /* used to cache the last category supplied via category_browse */
        int include_level;
        int max_include_level;
};
 
struct ast_variable {
        char *name;
        char *value;
        int lineno;
        int object;             /*!< 0 for variable, 1 for object */
        int blanklines;         /*!< Number of blanklines following entry */
        struct ast_comment *precomments;
        struct ast_comment *sameline;
        struct ast_variable *next;
        char stuff[0];
};
The [trunkgroups] section is for NFAS and GR-303
 connections, and it won¡¯t be discussed in this book. 
If you require this type of functionality, see the
 zapata.conf.sample file for more information.
The [channels] section determines the signaling method 
for hardware channels and their options. Once an option 
is defined, it is inherited down through the rest of the
file. A channel is defined using channel =>, and each channel definition inherits all the options defined above
 that line. If you wish to configure different options for different channels, remember that the options should be
 configured before the channel=> definition.
        while(v) {
                /* Create the interface list */
                if (!strcasecmp(v->name, "channel")
                        c = v->value;
                        chan = strsep(&c, ",");
                        while(chan) {
                                set start, finish
                                for (x=start;x<=finish;x++) {
                                        tmp = mkintf(x, cur_signalling, cur_radio, NULL, reload);
                                chan = strsep(&c, ",");
                        }
                v = v->next;
        }
 | Money will say more in one moment than the most eloquent lover can in years. | 














 


